本篇內(nèi)容主要講解“PHP網(wǎng)站常見(jiàn)的安全漏洞及防御方法有哪些”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“PHP網(wǎng)站常見(jiàn)的安全漏洞及防御方法有哪些”吧!
成都創(chuàng)新互聯(lián)公司主營(yíng)中江網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,成都App定制開(kāi)發(fā),中江h(huán)5小程序制作搭建,中江網(wǎng)站營(yíng)銷推廣歡迎中江等地區(qū)企業(yè)咨詢
對(duì)于PHP的漏洞,目前常見(jiàn)的漏洞有五種。分別是Session文件漏洞、SQL注入漏洞、腳本命令執(zhí)行漏洞、全局變量漏洞和文件漏洞。這里分別對(duì)這些漏洞進(jìn)行簡(jiǎn)要的介紹。
1、session文件漏洞
Session攻擊是黑客最常用到的攻擊手段之一。當(dāng)一個(gè)用戶訪問(wèn)某一個(gè)網(wǎng)站時(shí),為了免客戶每進(jìn)人一個(gè)頁(yè)面都要輸人賬號(hào)和密碼,PHP設(shè)置了Session和Cookie用于方便用戶的使用和訪向。
2、SQL注入漏洞
在進(jìn)行網(wǎng)站開(kāi)發(fā)的時(shí)候,程序員由于對(duì)用戶輸人數(shù)據(jù)缺乏全面判斷或者過(guò)濾不嚴(yán)導(dǎo)致服務(wù)器執(zhí)行一些惡意信息,比如用戶信息查詢等。黑客可以根據(jù)惡意程序返回的結(jié)果獲取相應(yīng)的信息。這就是月行胃的SQL注入漏洞。
3、腳本執(zhí)行漏洞
腳本執(zhí)行漏洞常見(jiàn)的原因是由于程序員在開(kāi)發(fā)網(wǎng)站時(shí)對(duì)用戶提交的URL參數(shù)過(guò)濾較少引起的,用戶提交的URL可能包含惡意代碼導(dǎo)致跨站腳本攻擊。腳本執(zhí)行漏洞在以前的PHP網(wǎng)站中經(jīng)常存在,但是隨著PHP版本的升級(jí),這些間題已經(jīng)減少或者不存在了。
4、全局變量漏洞
PHP中的變量在使用的時(shí)候不像其他開(kāi)發(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)非常的方便。
5、文件漏洞
文件漏洞通常是由于網(wǎng)站開(kāi)發(fā)者在進(jìn)行網(wǎng)站設(shè)計(jì)時(shí)對(duì)外部提供的數(shù)據(jù)缺乏充分的過(guò)濾導(dǎo)致黑客利用其中的漏洞在Web進(jìn)程上執(zhí)行相應(yīng)的命令。假如在 lsm.php中包含這樣一段代碼:include(b.”/aaa.php”.),這對(duì)黑客來(lái)說(shuō),可以通過(guò)變量b來(lái)實(shí)現(xiàn)遠(yuǎn)程攻擊,可以是黑客自已的 代碼,用來(lái)實(shí)現(xiàn)對(duì)網(wǎng)站的攻擊??梢韵蚍?wù)器提交a.php include=http://lZ7.0.0. 1/b.php,然后執(zhí)行b.php的指令。
從前面的分析可以知道,Session攻擊最常見(jiàn)的就是會(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)求沒(méi)有使用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變量值。
2、對(duì)SQL注入漏洞的防范
黑客進(jìn)行SQL注入手段很多,而且靈活多變,但是SQL注人的共同點(diǎn)就是利用輸入過(guò)濾漏洞。因此,要想從根本上防止SQL注入,根本解決措施就是加 強(qiáng)對(duì)請(qǐng)求命令尤其是查詢請(qǐng)求命令的過(guò)濾。具體來(lái)說(shuō),包括以下幾點(diǎn):一是把過(guò)濾性語(yǔ)句進(jìn)行參數(shù)化處理,也就是通過(guò)參數(shù)化語(yǔ)句實(shí)現(xiàn)用戶信息的輸入而不是直接把 用戶輸入嵌入到語(yǔ)句中。二是在網(wǎng)站開(kāi)發(fā)的時(shí)候盡可能少用解釋性程序,黑客經(jīng)常通過(guò)這種手段來(lái)執(zhí)行非法命令;三是在網(wǎng)站開(kāi)發(fā)時(shí)盡可能避免網(wǎng)站出現(xiàn)bug,否 則黑客可能利用這些信息來(lái)攻擊網(wǎng)站;僅僅通過(guò)防御SQL注入還是不夠的,另外還要經(jīng)常使用專業(yè)的漏洞掃描工具對(duì)網(wǎng)站進(jìn)行漏洞掃描。
3、對(duì)腳本執(zhí)行漏洞的防范
黑客利用腳本執(zhí)行漏洞進(jìn)行攻擊的手段是多種多樣的,而且是靈活多變的,對(duì)此,必須要采用多種防范方法綜合的手段,才能有效防止黑客對(duì)腳本執(zhí)行漏洞進(jìn) 行攻擊。這里常用的方法方法有以下四種。一是對(duì)可執(zhí)行文件的路徑進(jìn)行預(yù)先設(shè)定。可以通過(guò)safe_moade_exec_dir來(lái)實(shí)現(xiàn);二是對(duì)命令參數(shù)進(jìn) 行處理,一般用escapeshellarg函數(shù)實(shí)現(xiàn);三是用系統(tǒng)自帶的函數(shù)庫(kù)來(lái)代替外部命令;四是在操作的時(shí)候進(jìn)可能減少使用外部命令。
4、對(duì)全局變量漏洞防范
對(duì)于PHP全局變量的漏洞問(wèn)題,以前的PHP版本存在這樣的問(wèn)題,但是隨著PHP版本升級(jí)到5.5以后,可以通過(guò)對(duì)php.ini的設(shè)置來(lái)實(shí)現(xiàn),設(shè)置ruquest_order為GPC。另外在php.ini配置文件中,可以通過(guò)對(duì)Magic_quotes_runtime 進(jìn)行布爾值設(shè)置是否對(duì)外部引人的數(shù)據(jù)中的溢出字符加反斜線。為了確保網(wǎng)站程序在服務(wù)器的任何設(shè)置狀態(tài)下都能運(yùn)行??梢栽谡麄€(gè)程序開(kāi)始的時(shí)候用 get_magic_quotes_runtime檢測(cè)設(shè)置狀態(tài)決定是否要手工處理,或者在開(kāi)始(或不需要自動(dòng)轉(zhuǎn)義的時(shí)候)用 set_magic_quotes_runtime(0)關(guān)掉。
5、對(duì)文件漏洞的防范
對(duì)于PHP文件漏桐可以通過(guò)對(duì)服務(wù)器進(jìn)行設(shè)置和配置來(lái)達(dá)到防范目的。這里具體的操作如下:一是把PHP代碼中的錯(cuò)誤提示關(guān)閉,這樣可以避免黑客通過(guò) 錯(cuò)誤提示獲取數(shù)據(jù)庫(kù)信息和網(wǎng)頁(yè)文件物理路徑;二是對(duì)open_basedir盡心設(shè)置,也就是對(duì)目錄外的文件操作進(jìn)行禁止處理;這樣可以對(duì)本地文件或者遠(yuǎn) 程文件起到保護(hù)作用,防止它們被攻擊,這里還要注意防范Session文件和上載文件的攻擊;三是把safe-made設(shè)置為開(kāi)啟狀態(tài),從而對(duì)將要執(zhí)行的 命令進(jìn)行規(guī)范,通過(guò)禁止文件上傳,可以有效的提高PHP網(wǎng)站的安全系數(shù)。
到此,相信大家對(duì)“PHP網(wǎng)站常見(jiàn)的安全漏洞及防御方法有哪些”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
網(wǎng)頁(yè)題目:PHP網(wǎng)站常見(jiàn)的安全漏洞及防御方法有哪些
本文地址:http://muchs.cn/article30/iejsso.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、小程序開(kāi)發(fā)、微信小程序、網(wǎng)站建設(shè)、App開(kāi)發(fā)、域名注冊(cè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)