一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - PHP里8個鮮為人知的安全函數分析

PHP里8個鮮為人知的安全函數分析

2020-08-21 12:28PHP教程網 PHP教程

這篇文章主要介紹了PHP里8個鮮為人知的安全函數,較為詳細的分析了addslashes、htmlentities、htmlspecialchars及md5等函數在PHP程序設計安全中所起到重要作用,非常具有實用價值,需要的朋友可以參考下

本文實例講述了PHP里8個鮮為人知的安全函數。分享給大家供大家參考。具體分析如下:

安全是編程非常重要的一個方面。在任何一種編程語言中,都提供了許多的函數或者模塊來確保程序的安全性。在現代網站應用中,經常要獲取來自世界各地用戶的輸入,但是,我們都知道“永遠不能相信那些用戶輸入的數據”。所以在各種的Web開發語言中,都會提供保證用戶輸入數據安全的函數。這里我們就來看看,在著名的開源語言PHP中有哪些有用的安全函數。

在PHP中,有些很有用的函數開源非常方便的防止你的網站遭受各種攻擊,例如SQL注入攻擊,XSS(Cross Site Scripting:跨站腳本)攻擊等。一起看看PHP中常用的、可以確保項目安全的函數。注意,這并不是完整的列表,是我覺得對于你的i項目很有的一些函數。

1. mysql_real_escape_string()

這個函數在PHP中防止SQL注入攻擊時非常有用。這個函數會對一些例如單引號、雙引號、反斜杠等特殊字符添加一個反斜杠以確保在查詢這些數據之前,用戶提供的輸入是干凈的。但要注意,你是在連接數據庫的前提下使用這個函數。
但是現在已經不推薦使用mysql_real_escape_string()了,所有新的應用應該使用像PDO一樣的函數庫執行數據庫操作,也就是說,我們可以使用現成的語句防止SQL注入攻擊。

2. addslashes()

這個函數的原理跟mysql_real_escape_string()相似。但是當在php.ini文件中,“magic_quotes_gpc“的值是“on”的時候,就不要使用這個函數。magic_quotes_gpc 的默認值是on,對所有的 GET、POST 和 COOKIE 數據自動運行 addslashes()。不要對已經被 magic_quotes_gpc 轉義過的字符串使用 addslashes(),因為這樣會導致雙層轉義。你可以使用get_magic_quotes_gpc()函數來確定它是否開啟。

3. htmlentities()

這個函數對于過濾用戶輸入的數據非常有用。它會將一些特殊字符轉換為HTML實體。例如,用戶輸入<時,就會被該函數轉化為HTML實體<(&lt),輸入>就被轉為實體&gt.

4. htmlspecialchars()

在HTML中,一些特定字符有特殊的含義,如果要保持字符原來的含義,就應該轉換為HTML實體。這個函數會返回轉換后的字符串,例如'&' (ampersand) 轉為'&amp'

ps:此處原文有誤,在此非常感謝瑾瑜  提出。現已更正,另外附上此函數常見的轉換字符:

The translations performed are:
 '&' (ampersand) becomes '&amp;'
 '”' (double quote) becomes '&quot;' when ENT_NOQUOTES is not set.
 “'” (single quote) becomes '&#039;' (or &apos;) only when ENT_QUOTES is set.
 '<' (less than) becomes '&lt;'
 '>' (greater than) becomes '&gt;'

5. strip_tags()

這個函數可以去除字符串中所有的HTML,JavaScript和PHP標簽,當然你也可以通過設置該函數的第二個參數,讓一些特定的標簽出現。

6. md5()

從安全的角度來說,一些開發者在數據庫中存儲簡單的密碼的行為并不值得推薦。md5()函數可以產生給定字符串的32個字符的md5散列,而且這個過程不可逆,即你不能從md5()的結果得到原始字符串。
現在這個函數并不被認為是安全的,因為開源的數據庫可以反向檢查一個散列值的明文。你可以在這里找到一個MD5散列數據庫列表

7. sha1()

這個函數與md5()類似,但是它使用了不同的算法來產生40個字符的SHA-1散列(md5產生的是32個字符的散列)。也不要把絕對安全寄托在這個函數上,否則會有意想不到的結果。

8. intval()

先別笑,我知道這個函數和安全沒什么關系。intval()函數是將變量轉成整數類型,你可以用這個函數讓你的PHP代碼更安全,特別是當你在解析id,年齡這樣的數據時。

此處附上英文原文地址:http://www.pixelstech.net/article/1300722997-Useful-functions-to-provide-secure-PHP-application

希望本文所述對大家的PHP程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 99精品热线在线观看免费视频 | 国四虎影永久 | 欧美日韩高清完整版在线观看免费 | 亚洲国产99在线精品一区69堂 | 韩国三级年轻小的胰子完整 | 人人爽人人香蕉 | 国产精品久久久天天影视香蕉 | 日本高清va不卡视频在线观看 | 帅小伙和警官同性3p | 亚洲国产成人久久午夜 | 成人国产精品一级毛片视频 | 999精品视频这里只有精品 | 国产欧美日韩综合二区三区 | 男人女人日批 | poronovideos极度变态 | 国产高清视频一区二区 | 日本午夜大片免费观看视频 | 日韩精品成人在线 | 日韩精品一二三区 | 亚洲国产精品高清在线 | 日本 片 成人 在线 日b视频免费 | 亚洲 欧美 清纯 校园 另类 | 日韩国产成人 | 国产成人免费观看在线视频 | 亚洲国产精品二区久久 | 性bbwbbwbbwbbw撒尿 | 免费在线观看网址入口 | 无人在线观看免费高清视频播放 | 毛片在线观看网站 | 人体欣赏孕妇季玥图片 | 国产自拍偷拍自拍 | 亚洲品质自拍视频网站 | 视频一区在线免费观看 | 欧美同性videos | 色老头oldmoneyvideos | 天堂伊人 | 国产亚洲精品自在线亚洲情侣 | 亚洲精品中文字幕在线 | 成成人看片在线 | 国产在线精品亚洲第一区香蕉 | 俄罗斯伦理片 |