What is `StringEscapeUtils.escapeHtml4` does?

StringEscapeUtils.escapeHtml4 作用是将特殊字符转换为它们对应的HTML实体形式,从而防止这些字符在网页中被解析为HTML标签脚本,有助于防止跨站脚本攻击(XSS, Cross-Site Scripting)

依赖

xml 复制代码
<!--org.apache.commons.text.StringEscapeUtils-->
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-text</artifactId>
    <version>1.10.0</version>
</dependency>

样例

xml 复制代码
< 将被转义为 &lt;
> 将被转义为 &gt;
& 将被转义为 &amp;
双引号 (") 会被转义为 &quot;
单引号 (') 在HTML4中通常不转义,但在严格模式下或者为了兼容XHTML,可能会转义为 &#39;
csharp 复制代码
String unescaped = "<script>alert('XSS');</script>";

String escaped = StringEscapeUtils.escapeHtml4(unescaped);
# 结果: &lt;script&gt;alert(&#39;XSS&#39;);&lt;/script&gt;

对于现代Web应用来说,建议使用更全面的安全策略来防止XSS攻击,而不仅仅是依赖于这种简单的转义操作。

相关推荐
⑩-1 天前
@Vaild
java·javaee
Han.miracle1 天前
Spring Boot 后端分层开发实战:从 MVC 到三层架构详解
java
invicinble1 天前
it系统全链路思考
java
steel80881 天前
SSM与Springboot是什么关系? -----区别与联系
java·spring boot·后端
白云如幻1 天前
【JDBC】集合、反射和泛型复习
java·开发语言
数据中穿行1 天前
Java编译与类加载错误全指南
java
未秃头的程序猿1 天前
深入浅出MySQL事务:从ACID到Spring失效场景,2026最新实战指南
java·后端
程序员Terry1 天前
还在用 if-else 做兼容?三分钟学会适配器模式,让你的代码更优雅
java·设计模式
佩奇大王1 天前
P2118 排列字母
java·开发语言·算法
东离与糖宝1 天前
告别 Python!Java 本地部署 Qwen 3.5 实战,Ollama + Spring Boot 保姆级教程
java·人工智能