首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >strip_tags和htmlentities

strip_tags和htmlentities
EN

Stack Overflow用户
提问于 2011-04-26 17:18:17
回答 4查看 24.1K关注 0票数 11

我应该在strip_tags中使用htmlentities

我目前在向数据库添加内容时使用strip_tags,并考虑在输出时删除htmlentities;我希望在服务器上生成HTML时避免不必要的处理。

只使用strip_tags而不使用允许的标签安全吗?

EN

回答 4

Stack Overflow用户

发布于 2011-04-26 17:22:59

首先:只在需要时才使用转义方法。也就是说,如果你在数据库中插入一些东西,只对数据库进行转义,即应用mysql_real_escape_string (或PDO->quote或任何你正在使用的数据库层)。但是不要对输出应用任何转义。目前还没有strip_tags或类似的版本。这是因为您可能希望在其他地方使用存储在数据库中的数据,在那里HTML转义不是必需的,而只会使文本变得丑陋。

第二:你不应该使用strip_tags。它完全删除了标签。也就是说,用户没有得到与他输入的相同的输出。请改用htmlspecialchars。它将为用户提供相同的输出,但将使其无害。

票数 15
EN

Stack Overflow用户

发布于 2011-04-26 17:24:09

strip_tags将删除所有HTML标签:

代码语言:javascript
运行
复制
"<b>foo</b><i>bar</i>" --> "foobar"

htmlentities将对HTML中的特殊字符进行编码

代码语言:javascript
运行
复制
"a & b" --> "a &amp; b"
"<b>foo</b>" --> "&lt;b&gt;foo&lt;/b&gt;"

如果您使用htmlentities,那么当您将字符串输出到浏览器时,用户应该看到他们输入的文本,而不是HTML语言

代码语言:javascript
运行
复制
echo htmlentities("<b>foo</b>");

视觉效果为: foo

代码语言:javascript
运行
复制
echo strip_tags("<b>foo</b>");

结果: foo

票数 11
EN

Stack Overflow用户

发布于 2012-11-14 19:07:08

我不会使用htmlentities,因为它允许您按原样将字符串插入到数据库中。Yhis对账号详细信息或论坛都没有好处。

使用mysql_real_escape_string将数据插入数据库,使用strip_tags从数据库接收数据并回显到屏幕。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5788314

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档