簡(jiǎn)單實(shí)用的PHP防注入類實(shí)例
本文實(shí)例講述了簡(jiǎn)單實(shí)用的PHP防注入類。分享給大家供大家參考。具體如下:
PHP防注入注意要過濾的信息基本是get,post,然后對(duì)于sql就是我們常用的查詢,插入等等sql命令了,下面我給各位整理兩個(gè)簡(jiǎn)單的例子,希望這些例子能給你網(wǎng)站帶來安全.
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;
}
}
?>
例子二,代碼如下:
/*************************
說明:
判斷傳遞的變量中是否含有非法字符
如$_POST、$_GET
功能:
防注入
*************************/
//要過濾的非法字符
$ArrFiltrate=array("'","or","and","union","where");
//出錯(cuò)后要跳轉(zhuǎn)的url,不填則默認(rèn)前一頁
$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)證開始
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ù)庫類
- 非常實(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)文章
PHP工廠模式、單例模式與注冊(cè)樹模式實(shí)例詳解
這篇文章主要介紹了PHP工廠模式、單例模式與注冊(cè)樹模式,結(jié)合實(shí)例形式工廠模式、單例模式與注冊(cè)樹模式的基本概念、原理、實(shí)現(xiàn)方法及使用技巧,需要的朋友可以參考下2019-06-06
echo, print, printf 和 sprintf 區(qū)別
echo, print, printf 和 sprintf 區(qū)別...2006-12-12
詳解:——如何將圖片儲(chǔ)存在數(shù)據(jù)庫里
詳解:——如何將圖片儲(chǔ)存在數(shù)據(jù)庫里...2006-12-12
php使用pdo連接mssql server數(shù)據(jù)庫實(shí)例
這篇文章主要介紹了php使用pdo連接mssql server數(shù)據(jù)庫的方法,以實(shí)例形式分析了php使用pdo連接mssql server數(shù)據(jù)庫的技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2014-12-12
PHP使用OCR技術(shù)識(shí)別圖片中的文字(無需接口)
tesseract-ocr是一個(gè)流行的開源OCR引擎庫,它使用C++編寫,?PHP作為一種流行的服務(wù)器端語言,也提供了一些ocr識(shí)別的庫和工具,可以通過tesseract-ocr識(shí)別PDF、JPEG、GIF、PNG等格式的圖像,?tesseract-ocr的最大特點(diǎn)是它是針對(duì)多語言設(shè)計(jì)的,可以識(shí)別世界上大部分語言的文本2024-04-04
屏蔽PHP默認(rèn)設(shè)置中的Notice警告的方法
很多時(shí)候其實(shí)寫出來的代碼的錯(cuò)誤可以忽略或者根本就不是錯(cuò)誤,PHP還是會(huì)顯示Notice警告,well接下來我們就來介紹一下屏蔽PHP默認(rèn)設(shè)置中的Notice警告的方法2016-05-05

