htmlspecialchars()和htmlentities() 的区别

htmlspecialchars — 将以下特殊字符转换为 HTML 实体


这里写图片描述


<?php

$str="<script>alert('123')</script>";

echo htmlentities($str, ENT_QUOTES); 
//ENT_COMPAT - 默认。仅编码双引号。
//ENT_QUOTES - 编码双引号和单引号。
//ENT_NOQUOTES - 不编码任何引号。

//输出结果为&lt;script&gt;alert(&#039;123&#039;)&lt;/script&gt;gt;
//页面展示: <script>alert('123')</script>

htmlentities — Convert all applicable characters to HTML entities(将所有适用的字符转换为HTML实体)


<?php

$str="€'";
echo htmlentities($str, ENT_QUOTES); 
//ENT_COMPAT - 默认。仅编码双引号。
//ENT_QUOTES - 编码双引号和单引号。
//ENT_NOQUOTES - 不编码任何引号。 

//输出结果为&euro;&#039;   与htmlspecialchars()的区别就是将欧元字符也转义成实体了
//页面展示:€'

总结
htmlentities转换所有的html标记
htmlspecialchars只格式化& 、’、 “、 <、> 这几个特殊符号。
使用htmlentities不指定编码的话遇到中文会乱码

猜你喜欢

转载自blog.csdn.net/liuli9/article/details/82634715