PHP網(wǎng)站常見的安全漏洞以及解決方案
(文章來(lái)源:百家號(hào))
目前,基于PHP的網(wǎng)站開發(fā)已經(jīng)成為目前網(wǎng)站開發(fā)的主流,本文重點(diǎn)從PHP網(wǎng)站攻擊與安全防范方面進(jìn)行探究,旨在減少網(wǎng)站漏洞,希望對(duì)大家有所幫助!
一:常見PHP網(wǎng)站漏洞安全。
Session文件漏洞Session攻擊是黑客最常用到的攻擊手段之一。當(dāng)一個(gè)用戶訪問(wèn)某一個(gè)網(wǎng)站時(shí),為了免客戶每進(jìn)人一個(gè)頁(yè)面都要輸人賬號(hào)和密碼,PHP設(shè)置了Session和Cookie用于方便用戶的使用和訪向。SQL注入漏洞在進(jìn)行網(wǎng)站開發(fā)的時(shí)候, 程序員由于對(duì)用戶輸人數(shù)據(jù)缺乏全面判斷或者過(guò)濾不嚴(yán)導(dǎo)致服務(wù)器執(zhí)行一些惡意信息,比如用戶信息查詢等。黑客可以根據(jù)惡意程序返回的結(jié)果獲取相應(yīng)的信息。這就是所謂的SQL注入漏洞。腳本執(zhí)行漏洞腳本執(zhí)行漏洞常見的原因是由于程序員在開發(fā)網(wǎng)站時(shí)對(duì)用戶提交的URL參數(shù)過(guò)濾較少引起的,用戶提交的URL可能包含惡意代碼導(dǎo)致跨站腳本攻擊。
腳本執(zhí)行漏洞在以前的PHP網(wǎng)站中經(jīng)常存在,但是隨著PHP版本的升級(jí),這些間題已經(jīng)減少或者不存在了。全局變量漏洞PHP中的變量在使用的時(shí)候不像其他開發(fā)語(yǔ)言那樣需要事先聲明,PHP中的變量可以不經(jīng)聲明就直接使用,使用的時(shí)候系統(tǒng)自動(dòng)創(chuàng)建,而且也不需要對(duì)變量類型進(jìn)行說(shuō)明,系統(tǒng)會(huì)自動(dòng)根據(jù)上下文環(huán)境自動(dòng)確定變量類型。這種方式可以大大減少程序員編程中出錯(cuò)的概率,使用起來(lái)非常的方便。文件漏洞文件漏洞通常是由于網(wǎng)站開發(fā)者在進(jìn)行網(wǎng)站設(shè)計(jì)時(shí)對(duì)外部提供的數(shù)據(jù)缺乏充分的過(guò)濾導(dǎo)致黑客利用其中的漏洞在Web進(jìn)程上執(zhí)行相應(yīng)的命令。
二:PHP常見漏洞的防范措施。
對(duì)于Session漏洞的防范從前面的分析可以知道,Session攻擊最常見的就是會(huì)話劫持,也就是黑客通過(guò)各種攻擊手段獲取用戶的Session ID,然后利用被攻擊用戶的身份來(lái)登錄相應(yīng)網(wǎng)站。為此,這里可以用以下幾種方法進(jìn)行防范,定期更換Session ID,更換Session ID可以用PHP自帶函數(shù)來(lái)實(shí)現(xiàn);更換Session名稱,通常情況下Session的默認(rèn)名稱是PHPSESSID,這個(gè)變量一般是在cookie中保存的,如果更改了它的名稱,就可以阻檔黑客的部分攻擊;對(duì)透明化的Session ID進(jìn)行關(guān)閉處理,所謂透明化也就是指在http請(qǐng)求沒有使用cookies來(lái)制定Session id時(shí),Sessioin id使用鏈接來(lái)傳遞.關(guān)閉透明化Session ID可以通過(guò)操作PHP.ini文件來(lái)實(shí)現(xiàn)。
通過(guò)URL傳遞隱藏參數(shù),這樣可以確保即使黑客獲取了session數(shù)據(jù),但是由于相關(guān)參數(shù)是隱藏的,它也很難獲得Session ID變量值。對(duì)于SQL注入漏洞的防范黑客進(jìn)行SQL注入手段很多,而且靈活多變,但是SQL注人的共同點(diǎn)就是利用輸入過(guò)濾漏洞。因此,要想從根本上防止SQL注入,根本解決措施就是加強(qiáng)對(duì)請(qǐng)求命令尤其是查詢請(qǐng)求命令的過(guò)濾。具體來(lái)說(shuō),是把過(guò)濾性語(yǔ)句進(jìn)行參數(shù)化處理,也就是通過(guò)參數(shù)化語(yǔ)句實(shí)現(xiàn)用戶信息的輸入而不是直接把用戶輸入嵌入到語(yǔ)句中。在網(wǎng)站開發(fā)的時(shí)候盡可能少用解釋性程序,黑客經(jīng)常通過(guò)這種手段來(lái)執(zhí)行非法命令;在網(wǎng)站開發(fā)時(shí)盡可能避免網(wǎng)站出現(xiàn)bug,否則黑客可能利用這些信息來(lái)攻擊網(wǎng)站。