PHP使用PDO實(shí)現(xiàn)mysql防注入功能詳解
本文實(shí)例講述了PHP使用PDO實(shí)現(xiàn)mysql防注入功能。分享給大家供大家參考,具體如下:
1、什么是注入攻擊
例如下例:
前端有個(gè)提交表格:
<form action="test.php" method="post"> 姓名:<input name="username" type="text"> 密碼:<input name="password" type="password"> <input type="submit" value="登陸"> </form>
后臺(tái)的處理如下:
<?php $username=$_POST["username"]; $password=$_POST["password"]; $age=$_POST["age"]; //連接數(shù)據(jù)庫(kù),新建PDO對(duì)象 $pdo=new PDO("mysql:host=localhost;dbname=phpdemo","root","1234"); $sql="select * from login WHERE username='{$username}' AND password='{$password}' "; echo $sql; $stmt=$pdo->query($sql); //rowCount()方法返回結(jié)果條數(shù)或者受影響的行數(shù) if($stmt->rowCount()>0){ echo "登陸成功!"};
正常情況下,如果你輸入姓名為小王,密碼xiaowang,會(huì)登陸成功,sql語(yǔ)句如下:select * from login WHERE username='小王' AND password='xiaowang'
登陸成功!
但是如果你輸入姓名為 ' or 1=1 #,密碼隨便輸一個(gè),也會(huì)登陸成功,sql語(yǔ)句為:select * from login WHERE username='' or 1=1 #' AND password='xiaowang'
登陸成功!
可以看到username='' or 1=1,#注釋調(diào)了之后的password語(yǔ)句,由于 1=1恒成立,因此這條語(yǔ)句會(huì)返回大于1的結(jié)果集,從而使驗(yàn)證通過(guò)。
2、使用quote過(guò)濾特殊字符,防止注入
在sql語(yǔ)句前加上一行,將username變量中的‘等特殊字符過(guò)濾,可以起到防止注入的效果
//通過(guò)quote方法,返回帶引號(hào)的字符串,過(guò)濾調(diào)特殊字符 $username=$pdo->quote($username); $sql="select * from login WHERE username={$username} AND password='{$password}' "; echo $sql; $stmt=$pdo->query($sql); //rowCount()方法返回結(jié)果條數(shù)或者受影響的行數(shù) if($stmt->rowCount()>0){ echo "登陸成功!"; };
sql語(yǔ)句為:select * from login WHERE username='\' or 1=1 #' AND password='xiaowang'
可以看到“'”被轉(zhuǎn)義\',并且自動(dòng)為變量$username加上了引號(hào)
3、通過(guò)預(yù)處理語(yǔ)句傳遞參數(shù),防注入
//通過(guò)占位符:username,:password傳遞值,防止注入 $sql="select * from login WHERE username=:username AND password=:password"; $stmt=$pdo->prepare($sql); //通過(guò)statement對(duì)象執(zhí)行查詢語(yǔ)句,并以數(shù)組的形式賦值給查詢語(yǔ)句中的占位符 $stmt->execute(array(':username'=>$username,':password'=>$password)); echo $stmt->rowCount();
其中的占位符也可以為?
//占位符為? $sql="select * from login WHERE username=? AND password=?"; $stmt=$pdo->prepare($sql); //數(shù)組中參數(shù)的順序與查詢語(yǔ)句中問(wèn)號(hào)的順序必須相同 $stmt->execute(array($username,$password)); echo $stmt->rowCount();
4、通過(guò)bind綁定參數(shù)
bindParam()方法綁定一個(gè)變量到查詢語(yǔ)句中的參數(shù):
$sql="insert login(username,password,upic,mail) values(:username,:password,:age,:mail)"; $stmt=$pdo->prepare($sql); //第三個(gè)參數(shù)可以指定參數(shù)的類型PDO::PARAM_STR為字符串,PDO::PARAM_INT為整型數(shù) $stmt->bindParam(":username",$username,PDO::PARAM_STR); $stmt->bindParam(":password",$password,PDO::PARAM_STR); $stmt->bindParam(":age",$age,PDO::PARAM_INT); //使用bindValue()方法綁定一個(gè)定值 $stmt->bindValue(":mail",'default@qq.com'); $stmt->execute(); echo $stmt->rowCount();
使用問(wèn)號(hào)做占位符:
$sql="insert login(username,password,mail) values(?,?,?)";//注意不是中文狀態(tài)下的問(wèn)號(hào)? $stmt=$pdo->prepare($sql); //按照?的順序綁定參數(shù)值 $stmt->bindParam(1,$username); $stmt->bindParam(2,$password); $stmt->bindValue(3,'default@qq.com'); $stmt->execute(); echo $stmt->rowCount();
使用其中bindValue()方法給第三個(gè)占位符綁定一個(gè)常量'default@qq.com',它不隨變量的變化而變化。
bindColumn()方法綁定返回結(jié)果集的一列到變量:
$sql='SELECT * FROM user'; $stmt=$pdo->prepare($sql); $stmt->execute(); $stmt->bindColumn(2,$username); $stmt->bindColumn(4,$email); while($stmt->fetch(PDO::FETCH_BOUND)){ echo '用戶名:'.$username.",郵箱:".$email.'<hr/>'; }
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫(kù)技巧總結(jié)》、《php+mysqli數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
上一篇:PHP中用Trait封裝單例模式的實(shí)現(xiàn)
欄 目:PHP編程
下一篇:淺析PHP中的 inet
本文標(biāo)題:PHP使用PDO實(shí)現(xiàn)mysql防注入功能詳解
本文地址:http://mengdiqiu.com.cn/a1/PHPbiancheng/11014.html
您可能感興趣的文章
- 04-02關(guān)于txt數(shù)據(jù)庫(kù)php的信息
- 04-02php本站才可以請(qǐng)求數(shù)據(jù) php本地?cái)?shù)據(jù)庫(kù)
- 04-02網(wǎng)頁(yè)里php操作數(shù)據(jù)庫(kù) php網(wǎng)頁(yè)例子
- 04-02php打印請(qǐng)求數(shù)據(jù) php打印輸出結(jié)果
- 04-02php數(shù)據(jù)庫(kù)地址 phpstudy 數(shù)據(jù)庫(kù)
- 04-02php插入數(shù)據(jù)庫(kù)為亂碼 php連接數(shù)據(jù)庫(kù)亂碼
- 04-02php數(shù)據(jù)庫(kù)數(shù)據(jù)相加 php數(shù)據(jù)庫(kù)添加數(shù)據(jù)語(yǔ)句
- 04-02php數(shù)據(jù)庫(kù)輸入變量 php里輸出數(shù)據(jù)庫(kù)數(shù)據(jù)函數(shù)
- 04-02數(shù)據(jù)權(quán)限架構(gòu)思路php 數(shù)據(jù)權(quán)限設(shè)計(jì)方案
- 04-02php如何用導(dǎo)入數(shù)據(jù) php用來(lái)導(dǎo)入其他文件的語(yǔ)句


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02php本站才可以請(qǐng)求數(shù)據(jù) php本地?cái)?shù)據(jù)庫(kù)
- 04-02關(guān)于txt數(shù)據(jù)庫(kù)php的信息
- 04-02php打印請(qǐng)求數(shù)據(jù) php打印輸出結(jié)果
- 04-02網(wǎng)頁(yè)里php操作數(shù)據(jù)庫(kù) php網(wǎng)頁(yè)例子
- 04-02php插入數(shù)據(jù)庫(kù)為亂碼 php連接數(shù)據(jù)庫(kù)亂
- 04-02php數(shù)據(jù)庫(kù)地址 phpstudy 數(shù)據(jù)庫(kù)
- 04-02php數(shù)據(jù)庫(kù)數(shù)據(jù)相加 php數(shù)據(jù)庫(kù)添加數(shù)據(jù)
- 04-02數(shù)據(jù)權(quán)限架構(gòu)思路php 數(shù)據(jù)權(quán)限設(shè)計(jì)方
- 04-02php數(shù)據(jù)庫(kù)輸入變量 php里輸出數(shù)據(jù)庫(kù)數(shù)
- 04-02php如何用導(dǎo)入數(shù)據(jù) php用來(lái)導(dǎo)入其他文
隨機(jī)閱讀
- 01-10delphi制作wav文件的方法
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-11Mac OSX 打開(kāi)原生自帶讀寫NTFS功能(圖文