簡(jiǎn)單實(shí)用的PHP防注入類實(shí)例
本文實(shí)例講述了簡(jiǎn)單實(shí)用的PHP防注入類。分享給大家供大家參考。具體如下:
PHP防注入注意要過(guò)濾的信息基本是get,post,然后對(duì)于sql就是我們常用的查詢,插入等等sql命令了,下面我給各位整理兩個(gè)簡(jiǎn)單的例子,希望這些例子能給你網(wǎng)站帶來(lái)安全.
PHP防注入類代碼如下:
/**
* 參數(shù)處理類
* @author JasonWei
*/
class Params
{
public $get = array();
public $post = array();
function __construct()
{
if (!emptyempty($_GET)) {
foreach ($_GET as $key => $val) {
if (is_numeric($val)) {
$this->get[$key] = $this->getInt($val);
} else {
$this->get[$key] = $this->getStr($val);
}
}
}
if (!emptyempty($_POST)) {
foreach ($_POST as $key => $val) {
if (is_numeric($val)) {
$this->post[$key] = $this->getInt($val);
} else {
$this->post[$key] = $this->getStr($val);
}
}
}
}
public function getInt($number)
{
return intval($number);
}
public function getStr($string)
{
if (!get_magic_quotes_gpc()) {
$string = addslashes($string);
}
return $string;
}
public function checkInject($string)
{
return eregi('select|insert|update|delete|/*|*|../|./|union|into|load_file|outfile', $string);
}
public function verifyId($id = null)
{
if (!$id || $this->checkInject($id) || !is_numeric($id)) {
$id = false;
} else {
$id = intval($id);
}
return $id;
}
}
?>
例子二,代碼如下:
/*************************
說(shuō)明:
判斷傳遞的變量中是否含有非法字符
如$_POST、$_GET
功能:
防注入
*************************/
//要過(guò)濾的非法字符
$ArrFiltrate=array("'","or","and","union","where");
//出錯(cuò)后要跳轉(zhuǎn)的url,不填則默認(rèn)前一頁(yè)
$StrGoUrl="";
//是否存在數(shù)組中的值
function FunStringExist($StrFiltrate,$ArrFiltrate){
foreach ($ArrFiltrate as $key=>$value){
if (eregi($value,$StrFiltrate)){
return true;
}
}
return false;
}
//合并$_POST 和 $_GET
if(function_exists(array_merge)){
$ArrPostAndGet=array_merge($HTTP_POST_VARS,$HTTP_GET_VARS);
}else{
foreach($HTTP_POST_VARS as $key=>$value){
$ArrPostAndGet[]=$value;
}
foreach($HTTP_GET_VARS as $key=>$value){
$ArrPostAndGet[]=$value;
}
}
//驗(yàn)證開(kāi)始
foreach($ArrPostAndGet as $key=>$value){
if (FunStringExist($value,$ArrFiltrate)){
echo "<script language='javascript'>alert('傳遞的信息中不得包含{',or,and,union}等非法字符請(qǐng)您把他們換成{‘,OR,AND,UNION}');</script>";
if (emptyempty($StrGoUrl)){
echo "<scriptlanguage='javascript'>history.go(-1);</script>";
}else{
echo "<scriptlanguage='javascript'>window.location='".$StrGoUrl."';</script>";
}
exit;
}
}
/***************結(jié)束防止PHP注入*****************/
?>
希望本文所述對(duì)大家的PHP程序設(shè)計(jì)有所幫助。
- 9段PHP實(shí)用功能的代碼推薦
- 一個(gè)經(jīng)典實(shí)用的PHP圖像處理類分享
- 幾個(gè)實(shí)用的PHP內(nèi)置函數(shù)使用指南
- 一款簡(jiǎn)單實(shí)用的php操作mysql數(shù)據(jù)庫(kù)類
- 非常實(shí)用的PHP常用函數(shù)匯總
- 制作安全性高的PHP網(wǎng)站的幾個(gè)實(shí)用要點(diǎn)
- Thinkphp中的curd應(yīng)用實(shí)用要點(diǎn)
- 9個(gè)實(shí)用的PHP代碼片段分享
- PHP實(shí)用函數(shù)分享之去除多余的0
- 7個(gè)鮮為人知卻非常實(shí)用的PHP函數(shù)
- PHP實(shí)現(xiàn)簡(jiǎn)單實(shí)用的驗(yàn)證碼類
- 6個(gè)超實(shí)用的PHP代碼片段
- PHP判斷字符串長(zhǎng)度的兩種方法很實(shí)用
- PHPStrom中實(shí)用的功能和快捷鍵大全
- 四個(gè)PHP非常實(shí)用的功能
相關(guān)文章
file_get_contents獲取不到網(wǎng)頁(yè)內(nèi)容的解決方法
file_get_contents獲取不到網(wǎng)頁(yè)內(nèi)容的解決方法,需要的朋友可以參考一下2013-03-03PHP如何使用cURL實(shí)現(xiàn)Get和Post請(qǐng)求
這篇文章主要介紹了PHP如何使用cURL實(shí)現(xiàn)Get和Post請(qǐng)求,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07使用PHP實(shí)現(xiàn)實(shí)時(shí)數(shù)據(jù)可視化功能的示例詳解
實(shí)時(shí)數(shù)據(jù)可視化功能,是指在Web應(yīng)用程序開(kāi)發(fā)中,將服務(wù)器發(fā)送的實(shí)時(shí)數(shù)據(jù),本文將介紹如何使用PHP和前端框架實(shí)現(xiàn)實(shí)時(shí)數(shù)據(jù)可視化功能,需要的可以參考一下2023-07-07PHP 多維數(shù)組的排序問(wèn)題 根據(jù)二維數(shù)組中某個(gè)項(xiàng)排序
PHP 多維數(shù)組排序 根據(jù)二維數(shù)組中某個(gè)項(xiàng)排序,需要的朋友可以參考下。2011-11-11PHP+sqlite數(shù)據(jù)庫(kù)操作示例(創(chuàng)建/打開(kāi)/插入/檢索)
這篇文章主要介紹了PHP+sqlite數(shù)據(jù)庫(kù)操作的方法,簡(jiǎn)單分析了sqlite數(shù)據(jù)庫(kù)的功能及相關(guān)操作技巧,包括創(chuàng)建,打開(kāi),插入,檢索及錯(cuò)誤提示等,需要的朋友可以參考下2016-05-05