国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
php 安全過濾
首頁 後端開發(fā) php教程 php 安全過濾_PHP教程

php 安全過濾_PHP教程

Jul 12, 2016 am 09:08 AM
android

php 安全過濾

/*ansic碼-Url碼表: http://www.w3school.com.cn/tags/html_ref_urlencode.html

-----------------------------------------------------------------------------------------------------------------

1、驗證過濾用戶的輸入

即使是最普通的字母數(shù)字輸入也可能是危險的,列舉幾個容易引起安全問題的字符:

!$ ^ & * ( ) ~ [ ] \ | { } ' " ; ? - `

在數(shù)據(jù)庫中可能有特殊意義的字符:

'" ; \

還有一些非打印字符:

字符\x00或者說ASCII 0,NULL或FALSE

字符\x10和\x13,或者說ASCII 10和13,\n \r

字符\x1a或者說ASCII 26,表示文件的結束

輸入錯誤的參數(shù)類型,也可能導致程序出現(xiàn)意想不到的錯誤。

輸入過多的參數(shù)值,可能導致溢出等錯誤。

2、對于文件的路徑與名稱的過濾

文件名中不能包含二進制數(shù)據(jù),否則可能引起問題。

一些系統(tǒng)允許Unicode多字節(jié)編碼的文件名,但是盡量避免,應當使用ASCII的字符。

雖然Unix系統(tǒng)幾乎可以在文件名設定中使用任何符號,但是應當盡量使用 - 和 _ 避免使用其他字符。

同時需要限定文件名的長度。

3、防止SQL注入

檢查用戶輸入的類型,當用戶輸入的為數(shù)字時可以使用如下方式:

使用is_int()函數(shù)(或is_integer()或is_long()函數(shù))

使用gettype()函數(shù)

使用intval()函數(shù)

使用settype()函數(shù)

檢查用戶輸入字符串的長度使用strlen()函數(shù)。

檢查日期或時間是否是有效的,可以使用strtotime()函數(shù)

4、防止XSS攻擊

xss攻擊一個常用的方法就是注入HTML元素執(zhí)行js腳本,php中已經(jīng)內(nèi)置了一些防御的函數(shù)(如htmlentities或者htmlspecialchars)

5、過濾用戶提交的URL

如果允許用戶輸入一個URL用來調(diào)用一個圖片或者鏈接,你需要保證他不傳入javascript:或者vbscript:或data:等非http協(xié)議。

可以使用php的內(nèi)置函數(shù)parse_url()函數(shù)來分割URL,然后做判斷。

6、防止遠程執(zhí)行--下表列出了跟Shell相關的一些字符:

遠程執(zhí)行通常是使用了php代碼執(zhí)行如eval()函數(shù),或者是調(diào)用了命令執(zhí)行如exec(),passthru(),proc_open(),shell_exec(),system()或popen()。

注入php代碼:php為開發(fā)者提供了非常多的方法可以來調(diào)用允許php腳本,我們就需要注意對用戶可控的數(shù)據(jù)進行過濾。

7、Shell命令執(zhí)行

PHP提供了一些可以直接執(zhí)行系統(tǒng)命令的函數(shù),如exec()函數(shù)或者 `(反引號)。

PHP的安全模式會提供一些保護,但是也有一些方式可以繞過安全模式:

1、上傳一個Perl腳本,或者Python或Ruby等,服務器支持的環(huán)境,來執(zhí)行其他語言的腳本可繞過PHP的安全模式。

2、利用系統(tǒng)的緩沖溢出漏洞,繞過安全模式。

跟Shell相關的一些字符:

名稱 字符 ASCII 16進制 URL編碼 HTML編碼

換行 10 \x0a %0a

感嘆號 ! 33 \x21 %21 !

雙引號 " 34 \x22 %22 "或"

美元符號 $ 36 \x24 %24 $

連接符 & 38 \x26 %26 &或amp

單引號 ' 39 \x27 %27 '

左括號 ( 40 \x28 %28 (

右括號 ) 41 \x29 %29 )

星號 * 42 \x2a %2a *

連字符號 - 45 \x2d %2d -

分號 ; 59 \x3b %3b ;

左尖括號

右尖括號 > 62 \x3e %3e >

問號 ? 63 \x3f %3f ?

左方括號 [ 91 \x5b %5b [

反斜線 \ 92 \x5c %5c \

右方括號 ] 93 \x5d %5d ]

插入符 ^ 94 \x5e %5e ^

反引號 ` 96 \x60 %60 `

左花括號 { 123 \x7b %7b {

管道符 | 124 \x7c %7c |

右花括號 } 125 \x7d %7d }

波浪號 ~ 126 \x7e %7e ~

-----------------------------------------------------------------------------------------------------------------

安全過濾函數(shù)代碼*/

/**

* 安全過濾輸入[jb]

*/

function check_str($string, $isurl = false)

{

$string= preg_replace('/[\\x00-\\x08\\x0B\\x0C\\x0E-\\x1F]/','',$string); //去掉控制字符

$string= str_replace(array("\0","%00","\r"),'',$string);//\0表示ASCII 0x00的字符,通常作為字符串結束標志;這三個都是可能有害字符

empty($isurl)&& $string =preg_replace("/&(?!(#[0-9]+|[a-z]+);)/si",'&',$string);//HTML里面可以用xx;來對一些字符進行編碼,比如 (空格), ? Unicode字符等,A(?!B) 表示的是A后面不是B,所以作者想保留 ?類似的 HTML編碼字符,去掉其他的問題字符

$string= str_replace(array("%3C",'

$string= str_replace(array("%3E",'>'),'>',$string);

$string= str_replace(array('"',"'","\t",' '),array('“','‘','',' '),$string);

returntrim($string);

}

/**

* 安全過濾類-過濾javascript,css,iframes,object等不安全參數(shù) 過濾級別高

* @param string $value 需要過濾的值

* @return string

*/

function fliter_script($value) {

$value=preg_replace("/(javascript:)?on(click|load|key|mouse|error|abort|move|unload|change|dblclick|move|reset|resize|submit)/i","&111n\\2",$value);

$value= preg_replace("/(.*?)/si","",$value);

$value= preg_replace("/(.*?)/si","",$value);

$value= preg_replace ("http://iesU", '', $value);

return$value;

}

/**

* 安全過濾類-過濾HTML標簽

* @param string $value 需要過濾的值

* @return string

*/

function fliter_html($value) {

if(function_exists('htmlspecialchars')) return htmlspecialchars($value);

returnstr_replace(array("&", '"', "'", ""), array("&", "\"", "'",""), $value);

}

/**

* 安全過濾類-對進入的數(shù)據(jù)加下劃線 防止SQL注入

* @param string $value 需要過濾的值

* @return string

*/

function fliter_sql($value) {

$sql= array("select", 'insert', "update", "delete","\'", "\/\*","\.\.\/", "\.\/","union", "into", "load_file","outfile");

$sql_re=array("","","","","","","","","","","","");

returnstr_replace($sql, $sql_re, $value);

}

/**

* 安全過濾類-通用數(shù)據(jù)過濾

* @param string $value 需要過濾的變量

* @return string|array

*/

function fliter_escape($value) {

if(is_array($value)) {

foreach($value as $k => $v) {

$value[$k]= self::fliter_str($v);

}

}else {

$value= self::fliter_str($value);

}

return$value;

}

/**

* 安全過濾類-字符串過濾 過濾特殊有危害字符

* @param string $value 需要過濾的值

* @return string

*/

function fliter_str($value) {

$badstr= array("\0", "%00", "\r", '&', ' ','"', "'", "", " ", "%3C", "%3E");

$newstr= array('', '', '', '&', ' ', '"', ''', "", " ","");

$value = str_replace($badstr, $newstr, $value);

$value =preg_replace('/&((#(\d{3,5}|x[a-fA-F0-9]{4}));)/', '&\\1', $value);

return$value;

}

/**

* 私有路勁安全轉化

* @param string $fileName

* @return string

*/

function filter_dir($fileName) {

$tmpname= strtolower($fileName);

$temp= array(':/',"\0", "..");

if(str_replace($temp, '', $tmpname) !== $tmpname) {

returnfalse;

}

return$fileName;

}

/**

* 過濾目錄

* @param string $path

* @return array

*/

public function filter_path($path) {

$path= str_replace(array("'",'#','=','`','$','%','&',';'), '', $path);

returnrtrim(preg_replace('/(\/){2,}|(\\\){1,}/', '/', $path), '/');

}

/**

* 過濾PHP標簽

* @param string $string

* @return string

*/

public function filter_phptag($string) {

returnstr_replace(array(''), array('', '?>'), $string);

}

/**

* 安全過濾類-返回函數(shù)

* @param string $value 需要過濾的值

* @return string

*/

public function str_out($value) {

$badstr= array("", "%3C", "%3E");

$newstr= array("", "");

$value = str_replace($newstr, $badstr, $value);

returnstripslashes($value); //下劃線

}

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1055558.htmlTechArticlephp 安全過濾 /*ansic碼-Url碼表: http://www.w3school.com.cn/tags/html_ref_urlencode.html -----------------------------------------------------------------------------------...
本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權的內(nèi)容,請聯(lián)絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1600
29
PHP教程
1501
276
新報告對傳聞中的三星 Galaxy S25、Galaxy S25 Plus 和 Galaxy S25 Ultra 相機升級進行了嚴厲的評估 新報告對傳聞中的三星 Galaxy S25、Galaxy S25 Plus 和 Galaxy S25 Ultra 相機升級進行了嚴厲的評估 Sep 12, 2024 pm 12:23 PM

最近幾天,Ice Universe 不斷披露有關 Galaxy S25 Ultra 的詳細信息,人們普遍認為這款手機將是三星的下一款旗艦智慧型手機。除此之外,洩密者聲稱三星只計劃升級一臺相機

三星 Galaxy S25 Ultra 洩漏了第一張渲染圖,傳聞中的設計變化被曝光 三星 Galaxy S25 Ultra 洩漏了第一張渲染圖,傳聞中的設計變化被曝光 Sep 11, 2024 am 06:37 AM

OnLeaks 現(xiàn)在與 Android Headlines 合作,首次展示了 Galaxy S25 Ultra,幾天前,他試圖從他的 X(以前的 Twitter)粉絲那裡籌集到 4,000 美元以上的資金,但失敗了。對於上下文,嵌入在 h 下面的渲染圖像

IFA 2024 | TCL 的 NXTPAPER 14 在性能上無法與 Galaxy Tab S10 Ultra 相媲美,但在尺寸上幾乎可以與之媲美 IFA 2024 | TCL 的 NXTPAPER 14 在性能上無法與 Galaxy Tab S10 Ultra 相媲美,但在尺寸上幾乎可以與之媲美 Sep 07, 2024 am 06:35 AM

除了發(fā)布兩款新智慧型手機外,TCL 還發(fā)布了一款名為 NXTPAPER 14 的新 Android 平板電腦,其大螢幕尺寸是其賣點之一。 NXTPAPER 14 採用 TCL 標誌性品牌霧面液晶面板 3.0 版本

Vivo Y300 Pro 在 7.69 毫米纖薄機身中配備 6,500 mAh 電池 Vivo Y300 Pro 在 7.69 毫米纖薄機身中配備 6,500 mAh 電池 Sep 07, 2024 am 06:39 AM

Vivo Y300 Pro剛剛全面亮相,它是最薄的中階Android手機之一,配備大電池。準確來說,這款智慧型手機厚度僅為 7.69 毫米,但配備 6,500 mAh 電池。這與最近推出的容量相同

三星 Galaxy S24 FE 預計將以低於預期的價格推出,有四種顏色和兩種記憶體選項 三星 Galaxy S24 FE 預計將以低於預期的價格推出,有四種顏色和兩種記憶體選項 Sep 12, 2024 pm 09:21 PM

三星尚未就何時更新其 Fan Edition (FE) 智慧型手機系列提供任何提示。目前來看,Galaxy S23 FE 仍然是該公司的最新版本,於 2023 年 10 月年初推出。

新報告對傳聞中的三星 Galaxy S25、Galaxy S25 Plus 和 Galaxy S25 Ultra 相機升級進行了嚴厲的評估 新報告對傳聞中的三星 Galaxy S25、Galaxy S25 Plus 和 Galaxy S25 Ultra 相機升級進行了嚴厲的評估 Sep 12, 2024 pm 12:22 PM

最近幾天,Ice Universe 不斷披露有關 Galaxy S25 Ultra 的詳細信息,人們普遍認為這款手機將是三星的下一款旗艦智慧型手機。除此之外,洩密者聲稱三星只計劃升級一臺相機

iQOO Z9 Turbo Plus:可能增強的系列旗艦產(chǎn)品已開始預訂 iQOO Z9 Turbo Plus:可能增強的系列旗艦產(chǎn)品已開始預訂 Sep 10, 2024 am 06:45 AM

OnePlus的姊妹品牌iQOO的2023-4年產(chǎn)品週期可能即將結束;儘管如此,該品牌已宣布 Z9 系列的開發(fā)尚未結束。它的最終版,也可能是最高端的 Turbo+ 變體剛剛按照預測發(fā)布。時間

小米紅米 Note 14 Pro Plus 上市,成為首款配備 Light Hunter 800 相機的高通 Snapdragon 7s Gen 3 智慧型手機 小米紅米 Note 14 Pro Plus 上市,成為首款配備 Light Hunter 800 相機的高通 Snapdragon 7s Gen 3 智慧型手機 Sep 27, 2024 am 06:23 AM

Redmi Note 14 Pro Plus 現(xiàn)已正式成為去年 Redmi Note 13 Pro Plus 的直接後繼產(chǎn)品(亞馬遜售價 375 美元)。正如預期的那樣,Redmi Note 14 Pro Plus與Redmi Note 14和Redmi Note 14 Pro一起成為Redmi Note 14系列的主角。李

See all articles