在php中htmlspecialchars, 將特殊字元轉成 HTML 格式,而htmlentities,將所有的字元都轉成 HTML 字串 了,下面我來分別簡單的介紹。
htmlentities用法
John & 'Adams'
John & 'Adams'
John & 'Adams'
htmlspecialchars用法
& (和) 轉成 &
" (雙引號) 轉成 "
< (小於) 轉成 <
> (大於) 轉成 >
例
他們的區別
這兩個函數的功能都是轉換字符為HTML字符編碼,特別是url和代碼字符串。防止字符標記被浏覽器執行。使用中文時沒什麼區別,但htmlentities會格式化中文字符使得中文輸入是亂碼
htmlentities轉換所有的html標記,htmlspecialchars只格式化& ' " < 和 > 這幾個特殊符號
代碼如下 復制代碼$str = '測試頁面';
echo 'htmlentities指定GB2312編碼:'.htmlentities($str,ENT_COMPAT,"GB2312").'';
echo 'htmlentities未指定編碼:'.htmlentities($str).'';
$str = '測試頁面';
echo htmlspecialchars($str).'';
效果:
代碼如下 復制代碼htmlentities指定GB2312編碼:測試頁面
htmlentities未指定編碼:²âÊÔÒ³Ãæ
測試頁面