使用PHP 5.6進行開發任務時,轉義是其中一個需要嚴格注意的方面之一。無論是在數據插入數據庫或者是直接輸出到用戶界面,都應該謹慎對待這一問題,確保數據不會被惡意腳本利用。
首先,一般的轉義函數都是以addslashes()為代表。這個函數能將一些雙引號(")、單引號(')、反斜桿(\)等特殊字符進行轉義。舉個例子,以單引號為例:
輸出結果為:She said, \\'I\\'m leaving.\\' 這樣就把原來的字符串中的單引號轉義了。
除此之外,有時候還需要考慮安全性更高層次的轉義。一般而言,htmlentities()函數就是實現這種目的的好幫手。它不僅可以轉義鍵盤常用的特殊字符,而且也將HTML中可能引起攻擊的字符轉義。例如:
鏈接"; $str = htmlentities($str, ENT_QUOTES, 'UTF-8'); echo $str; ?>
這樣做可以將特殊字符進行HTML轉義。輸出結果為:點擊這個<a href='#' onClick='alert("hello")'>鏈接</a>
最后還有一個值得注意的點是,在使用MySQL存儲數據的時候,需要使用mysqli_real_escape_string()來對SQL特殊字符進行轉義。例如:
這樣就可以避免用戶惡意利用$name中的特殊字符刪除整張表的情況發生。
綜上所述,轉義在PHP 5.6開發中是一個非常重要的問題。在操作數據庫、輸出界面、處理用戶的輸入等過程中都需要注意對字符進行轉義,防止惡意用戶攻擊造成數據泄露或者其他安全問題。
上一篇php 5.6 配置
下一篇php 5.6.0安裝