IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> PHP 操作PDO 生成静态页面 -> 正文阅读

[PHP知识库]PHP 操作PDO 生成静态页面

防spl注入添加

<?php

	$name = $_POST['name'];
	$text = $_POST['text'];
	$static = $_POST['static'];
    $dbh = new \PDO("mysql:host=127.0.0.1;dbname=my6","root","root");

     	if (!empty($name)) {

     		# code...
     		 $sql = "INSERT INTO `article` (`time` ,`text`,`style`)VALUES (:login, :password,:style)";
     		/* 当调用 prepare() 时,查询语句已经发送给了数据库服务器,此时只有占位符 ? 发送过去,没有用户提交的数据;当调用到 execute()时,用户提交过来的值才会传送给数据库,他们是分开传送的,两者独立的,SQL攻击者没有一点机会。*/
        $stmt = $dbh->prepare($sql);  $stmt->execute(array(':login'=>$name,':password'=>$text,':style'=>$static));
        //返回添加行号
        // echo $dbh->lastinsertid();
        echo "ok";     
     	}

?>

PDO查询展示数据

<?php
$dbms = 'mysql';     //数据库类型
$host = 'localhost'; //数据库主机名
$dbName = 'my6';    //使用的数据库
$user = 'root';      //数据库连接用户名
$pass = 'root';          //对应的密码
$dsn = "$dbms:host=$host;dbname=$dbName";
$dbh = new PDO($dsn, $user, $pass); //初始化一个PDO对象
$sql = "SELECT * FROM `article`";
$stmt = $dbh->query($sql);
$row = $stmt->fetchAll(PDO::FETCH_ASSOC);
?>

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
 <?php foreach ($row as $value):?>
    <?php echo  $value['id']; ?>
   <div>
       <a href="day30p.php?aid=<?php echo $value['id']?>"><?php echo $value['time']?></a>
   </div>
 <?php endforeach; ?>
</body>
</html>

生成静态文件

if判断数据库里面的 style字段是否为1 如是1 则执行静态文件
在这里插入图片描述

<?php 

	$id = $_GET['aid'];
        $dbh = new \PDO("mysql:host=127.0.0.1;dbname=my6","root","root");
        $sql="select * from article  WHERE `id` = :login ";
		$stmt = $dbh->prepare($sql);  
		$stmt->execute(array(':login'=>$id));  
		$row = $stmt->fetch(PDO::FETCH_ASSOC);
		echo $row['style'];
		if ($row['style']==1){
			// ob_start — 打开输出控制缓冲
			ob_start();
			// ob_get_contents — 返回输出缓冲区的内容
				$file = ob_get_contents();
				// fopen — 打开文件或者 URL
			$f_file =fopen("article_$id.html","w");
			// fwrite — 写入文件(可安全用于二进制文件)
			fwrite($f_file,$file);
			// fclose — 关闭一个已打开的文件指针
			fclose($f_file);
		}
	
	?>
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<meta name="viewport" content="width=device-width, initial-scale=1.0">
	<title>Document</title>
</head>
<body>
	 <div>
        <label>标题</label>
        <div>
        <?php echo $row['time']?>
        </div>
    </div>
    <div>
        <label>内容</label>
        <div>
        <?php echo $row['text']?>
        </div>
    </div>
	

</body>
</html>

  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2021-08-01 14:18:04  更:2021-08-01 14:18:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/5 0:28:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码