PHP里8個鮮為人知的安全函數(shù)分析
本文實例講述了PHP里8個鮮為人知的安全函數(shù)。分享給大家供大家參考。具體分析如下:
安全是編程非常重要的一個方面。在任何一種編程語言中,都提供了許多的函數(shù)或者模塊來確保程序的安全性。在現(xiàn)代網(wǎng)站應(yīng)用中,經(jīng)常要獲取來自世界各地用戶的輸入,但是,我們都知道“永遠不能相信那些用戶輸入的數(shù)據(jù)”。所以在各種的Web開發(fā)語言中,都會提供保證用戶輸入數(shù)據(jù)安全的函數(shù)。這里我們就來看看,在著名的開源語言PHP中有哪些有用的安全函數(shù)。
在PHP中,有些很有用的函數(shù)開源非常方便的防止你的網(wǎng)站遭受各種攻擊,例如SQL注入攻擊,XSS(Cross Site Scripting:跨站腳本)攻擊等。一起看看PHP中常用的、可以確保項目安全的函數(shù)。注意,這并不是完整的列表,是我覺得對于你的i項目很有的一些函數(shù)。
1. mysql_real_escape_string()
這個函數(shù)在PHP中防止SQL注入攻擊時非常有用。這個函數(shù)會對一些例如單引號、雙引號、反斜杠等特殊字符添加一個反斜杠以確保在查詢這些數(shù)據(jù)之前,用戶提供的輸入是干凈的。但要注意,你是在連接數(shù)據(jù)庫的前提下使用這個函數(shù)。
但是現(xiàn)在已經(jīng)不推薦使用mysql_real_escape_string()了,所有新的應(yīng)用應(yīng)該使用像PDO一樣的函數(shù)庫執(zhí)行數(shù)據(jù)庫操作,也就是說,我們可以使用現(xiàn)成的語句防止SQL注入攻擊。
2. addslashes()
這個函數(shù)的原理跟mysql_real_escape_string()相似。但是當在php.ini文件中,“magic_quotes_gpc“的值是“on”的時候,就不要使用這個函數(shù)。magic_quotes_gpc 的默認值是on,對所有的 GET、POST 和 COOKIE 數(shù)據(jù)自動運行 addslashes()。不要對已經(jīng)被 magic_quotes_gpc 轉(zhuǎn)義過的字符串使用 addslashes(),因為這樣會導(dǎo)致雙層轉(zhuǎn)義。你可以使用get_magic_quotes_gpc()函數(shù)來確定它是否開啟。
3. htmlentities()
這個函數(shù)對于過濾用戶輸入的數(shù)據(jù)非常有用。它會將一些特殊字符轉(zhuǎn)換為HTML實體。例如,用戶輸入<時,就會被該函數(shù)轉(zhuǎn)化為HTML實體<(<),輸入>就被轉(zhuǎn)為實體>.
4. htmlspecialchars()
在HTML中,一些特定字符有特殊的含義,如果要保持字符原來的含義,就應(yīng)該轉(zhuǎn)換為HTML實體。這個函數(shù)會返回轉(zhuǎn)換后的字符串,例如'&' (ampersand) 轉(zhuǎn)為'&'
ps:此處原文有誤,在此非常感謝瑾瑜 提出?,F(xiàn)已更正,另外附上此函數(shù)常見的轉(zhuǎn)換字符:
The translations performed are:
'&' (ampersand) becomes '&'
'”' (double quote) becomes '"' when ENT_NOQUOTES is not set.
“'” (single quote) becomes ''' (or ') only when ENT_QUOTES is set.
'<' (less than) becomes '<'
'>' (greater than) becomes '>'
5. strip_tags()
這個函數(shù)可以去除字符串中所有的HTML,JavaScript和PHP標簽,當然你也可以通過設(shè)置該函數(shù)的第二個參數(shù),讓一些特定的標簽出現(xiàn)。
6. md5()
從安全的角度來說,一些開發(fā)者在數(shù)據(jù)庫中存儲簡單的密碼的行為并不值得推薦。md5()函數(shù)可以產(chǎn)生給定字符串的32個字符的md5散列,而且這個過程不可逆,即你不能從md5()的結(jié)果得到原始字符串。
現(xiàn)在這個函數(shù)并不被認為是安全的,因為開源的數(shù)據(jù)庫可以反向檢查一個散列值的明文。你可以在這里找到一個MD5散列數(shù)據(jù)庫列表
7. sha1()
這個函數(shù)與md5()類似,但是它使用了不同的算法來產(chǎn)生40個字符的SHA-1散列(md5產(chǎn)生的是32個字符的散列)。也不要把絕對安全寄托在這個函數(shù)上,否則會有意想不到的結(jié)果。
8. intval()
先別笑,我知道這個函數(shù)和安全沒什么關(guān)系。intval()函數(shù)是將變量轉(zhuǎn)成整數(shù)類型,你可以用這個函數(shù)讓你的PHP代碼更安全,特別是當你在解析id,年齡這樣的數(shù)據(jù)時。
此處附上英文原文地址:http://www.pixelstech.net/article/1300722997-Useful-functions-to-provide-secure-PHP-application
希望本文所述對大家的PHP程序設(shè)計有所幫助。
相關(guān)文章
PHP error_log()將錯誤信息寫入一個文件(定義和用法)
PHP error_log()定義和用法,帶有二個簡單小例子加函數(shù)解釋2013-10-10php下關(guān)于中英數(shù)字混排的字符串分割問題
要用到短信平臺的緣故,短信每條又有字數(shù)的限制,而短信平臺的服務(wù)端又不會自己分析。短信平臺的后臺會自己分割,但api卻有沒這個功能。2010-04-04thinkphp Apache配置重啟Apache1 restart 出錯解決辦法
這篇文章主要介紹了thinkphp Apache配置重啟Apache1 restart 出錯解決辦法的相關(guān)資料,需要的朋友可以參考下2017-02-02PHP從二維數(shù)組得到N層分類樹的實現(xiàn)代碼
這篇文章主要介紹了PHP從二維數(shù)組得到N層分類樹的實現(xiàn)代碼,需要的朋友可以參考下2016-10-10PHP中調(diào)試函數(shù)debug_backtrace的使用示例代碼
debug_backtrace() 是一個很低調(diào)的函數(shù),很少有人注意過它,這篇文章主要給大家介紹了關(guān)于PHP中調(diào)試函數(shù)debug_backtrace的使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,感興趣的朋友們隨著小編來一起學習學習吧。2017-09-09PHP中error_reporting()函數(shù)的用法(修改PHP屏蔽錯誤)
一般在默認的普通PHP文件中輸出一個未定義聲明的變量是不會報錯誤的,但在codeigniter框架下卻要報錯誤,這對于想集成 添加 和 修改 頁面于一體的”懶人”很不方便,由于是初學者開始還想怎么在代碼中屏蔽這一錯誤提示呢.甚至用到了@,但聽很多人都說@會大大降低性能.2011-07-07