在php中htmlspecialchars,將特殊字元轉(zhuǎn)成 HTML 格式,而htmlentities,將所有的字元都轉(zhuǎn)成 HTML 字串 了,下面我來分別簡單的介紹.
htmlentities用法,代碼如下:
- <html>
- <body>
- <?php
- $str = "John & 'Adams'";
- echo htmlentities($str, ENT_COMPAT);
- echo "<br />";
- echo htmlentities($str, ENT_QUOTES);
- //開源軟件:Vevb.com
- echo "<br />";
- echo htmlentities($str, ENT_NOQUOTES);
- ?>
- </body>
- </html>
- //瀏覽器輸出:
- John & 'Adams'
- John & 'Adams'
- John & 'Adams'
- //htmlspecialchars用法
- & (和) 轉(zhuǎn)成 &
- " (雙引號) 轉(zhuǎn)成 "
- < (小于) 轉(zhuǎn)成 <
- > (大于) 轉(zhuǎn)成 >
例,代碼如下:
- <html>
- <body>
- <?php
- $str = "John & 'Adams'";
- echo htmlspecialchars($str, ENT_COMPAT);
- echo "<br />";
- echo htmlspecialchars($str, ENT_QUOTES);
- echo "<br />";
- echo htmlspecialchars($str, ENT_NOQUOTES);
- ?>
- </body>
- </html>
他們的區(qū)別:
這兩個函數(shù)的功能都是轉(zhuǎn)換字符為HTML字符編碼,特別是url和代碼字符串,防止字符標(biāo)記被瀏覽器執(zhí)行,使用中文時沒什么區(qū)別,但htmlentities會格式化中文字符使得中文輸入是亂碼.
htmlentities轉(zhuǎn)換所有的html標(biāo)記,htmlspecialchars只格式化& ' " < 和 > 這幾個特殊符號,代碼如下:
- $str = '<a href="demo.php?m=index&a=index&name=中文">測試頁面</a>';
- echo 'htmlentities指定GB2312編碼:'.htmlentities($str,ENT_COMPAT,"GB2312").'';
- echo 'htmlentities未指定編碼:'.htmlentities($str).'';
- $str = '<a href="demo.php?m=index&a=index&name=中文">測試頁面</a>';
- echo htmlspecialchars($str).'';
效果,代碼如下:
htmlentities指定GB2312編碼:<a href="demo.php?m=index&a=index&name=中文">測試頁面</a>
htmlentities未指定編碼:<a href="demo.php?m=index&a=index&name=ÖÐÎÄ">²âÊÔÒ³Ãæ</a>
<a href="demo.php?m=index&a=index&name=中文">測試頁面</a>
新聞熱點
疑難解答