- 相關(guān)推薦
PHP常見漏洞的防范措施
目前,基于PHP的網(wǎng)站開發(fā)已經(jīng)成為目前網(wǎng)站開發(fā)的主流,下面整理了一些PHP常見漏洞的防范措施,希望對大家有所幫助!
1、對于Session漏洞的防范
從前面的分析可以知道,Session攻擊最常見的就是會話劫持,也就是黑客通過各種攻擊手段獲取用戶的Session ID,然后利用被攻擊用戶的身份來登錄相應(yīng)網(wǎng)站。為此,這里可以用以下幾種方法進(jìn)行防范:一是定期更換Session ID,更換Session ID可以用PHP自帶函數(shù)來實(shí)現(xiàn);二是更換Session名稱,通常情況下Session的默認(rèn)名稱是PHPSESSID,這個(gè)變量一般是在cookie中保存的,如果更改了它的名稱,就可以阻檔黑客的部分攻擊;三是對透明化的Session ID進(jìn)行關(guān)閉處理,所謂透明化也就是指在http請求沒有使用cookies來制定Session id時(shí),Sessioin id使用鏈接來傳遞.關(guān)閉透明化Session ID可以通過操作PHP.ini文件來實(shí)現(xiàn);四是通過URL傳遞隱藏參數(shù),這樣可以確保即使黑客獲取了session數(shù)據(jù),但是由于相關(guān)參數(shù)是隱藏的,它也很難獲得Session ID變量值。
2、對SQL注入漏洞的防范
黑客進(jìn)行SQL注入手段很多,而且靈活多變,但是SQL注人的共同點(diǎn)就是利用輸入過濾漏洞。因此,要想從根本上防止SQL注入,根本解決措施就是加強(qiáng)對請求命令尤其是查詢請求命令的過濾。具體來說,包括以下幾點(diǎn):一是把過濾性語句進(jìn)行參數(shù)化處理,也就是通過參數(shù)化語句實(shí)現(xiàn)用戶信息的輸入而不是直接把用戶輸入嵌入到語句中。二是在網(wǎng)站開發(fā)的時(shí)候盡可能少用解釋性程序,黑客經(jīng)常通過這種手段來執(zhí)行非法命令;三是在網(wǎng)站開發(fā)時(shí)盡可能避免網(wǎng)站出現(xiàn)bug,否則黑客可能利用這些信息來攻擊網(wǎng)站;僅僅通過防御SQL注入還是不夠的,另外還要經(jīng)常使用專業(yè)的漏洞掃描工具對網(wǎng)站進(jìn)行漏洞掃描。
3、對腳本執(zhí)行漏洞的防范
黑客利用腳本執(zhí)行漏洞進(jìn)行攻擊的手段是多種多樣的,而且是靈活多變的,對此,必須要采用多種防范方法綜合的手段,才能有效防止黑客對腳本執(zhí)行漏洞進(jìn)行攻擊。這里常用的方法方法有以下四種。一是對可執(zhí)行文件的路徑進(jìn)行預(yù)先設(shè)定?梢酝ㄟ^safe_moade_exec_dir來實(shí)現(xiàn);二是對命令參數(shù)進(jìn)行處理,一般用escapeshellarg函數(shù)實(shí)現(xiàn);三是用系統(tǒng)自帶的函數(shù)庫來代替外部命令;四是在操作的時(shí)候進(jìn)可能減少使用外部命令。
4、對全局變量漏洞防范
對于PHP全局變量的漏洞問題,以前的PHP版本存在這樣的問題,但是隨著PHP版本升級到5.5以后,可以通過對php.ini的設(shè)置來實(shí)現(xiàn),設(shè)置ruquest_order為GPC。另外在php.ini配置文件中,可以通過對 Magic _quotes_runtime進(jìn)行布爾值設(shè)置是否對外部引人的數(shù)據(jù)中的溢出字符加反斜線。為了確保網(wǎng)站程序在服務(wù)器的任何設(shè)置狀態(tài)下都能運(yùn)行。可以在整個(gè)程序開始的時(shí)候用get_magic_quotes_runtime檢測設(shè)置狀態(tài)決定是否要手工處理,或者在開始(或不需要自動轉(zhuǎn)義的時(shí)候)用set_magic_quotes_runtime(0)關(guān)掉。
5、對文件漏洞的防范
對于PHP文件漏桐可以通過對服務(wù)器進(jìn)行設(shè)置和配置來達(dá)到防范目的。這里具體的操作如下:一是把PHP代碼中的錯誤提示關(guān)閉,這樣可以避免黑客通過錯誤提示獲取數(shù)據(jù)庫信息和網(wǎng)頁文件物理路徑;二是對open_basedir盡心設(shè)置,也就是對目錄外的文件操作進(jìn)行禁止處理;這樣可以對本地文件或者遠(yuǎn)程文件起到保護(hù)作用,防止它們被攻擊,這里還要注意防范Session文件和上載文件的攻擊;三是把safe-made設(shè)置為開啟狀態(tài),從而對將要執(zhí)行的命令進(jìn)行規(guī)范,通過禁止文件上傳,可以有效的提高PHP網(wǎng)站的安全系數(shù)。
【PHP常見漏洞的防范措施】相關(guān)文章:
PHP頁面漏洞分析的方法08-13
PHP常見面試題及解析08-14
了解常見的php的sql注入式攻擊08-12
PHP常見面試題及答案10-09
六個(gè)常見PHP安全性攻擊10-04
PHP中閉包的一些常見問題11-01
php采用ajax數(shù)據(jù)提交post與post常見方法總結(jié)08-08
什么是PHP PHP與ASP比較09-18