富文本编辑器过滤XSS攻击

考虑到富文本编辑器可以直接在源代码里面写js代码,所以本文通过java过滤器,和字符串替换来做简单的防止。

一、后台添加过滤器

<!-- 防止CSS跨站脚本攻击: 本参数仅对各标签库生效如spring taglib/jstl/freemarker等 -->
<context-param>
    <param-name>defaultHtmlEscape</param-name>
    <param-value>true</param-value>
</context-param>
<filter>
    <filter-name>XssSqlFilter</filter-name>
    <filter-class>org.cdc.web.xss.XssFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>XssSqlFilter</filter-name>
    <url-patten>/*</url-patten>
    <dispatcher>REQUEST</dispatcher>
</filter-mapping>
<!-- 防止CSS跨站脚本攻击 -->

二、替换特殊字符

private String cleanXSS(String value){
    // You'll need to remove the spaces from the html entities below
    value = value .replaceAll("<","& lt;").replaceAll(">","& gt;");
    value = value.replaceAll("\\(","& #40;").replaceAll("\\)","& #41;");
    value = value.replaceAll("'","& #39;");
    value = value.replaceAll("eval\\((.*)\\)","");
    value = value.replaceAll("[\\\"\\\'][\\s]*javascript:(.*)[\\\"\\\']","\"\"");
    value = value.replaceAll("script","");
    value = value.trim();
    return value;
}
本文出处:https://blog.csdn.net/pdy8023/article/details/80338957
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值