首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JAVA Esapi编码器

JAVA Esapi编码器
EN

Stack Overflow用户
提问于 2016-11-07 13:31:17
回答 2查看 2.4K关注 0票数 0

你好,我使用ESAPI编码和解码字符串以避免脚本攻击,我使用它的方式如下:

代码语言:javascript
复制
   public static String encode(String value) {
    if (value == null) {
        return null;
    }
    Encoder encoder = ESAPI.encoder();
    return encoder.encodeForHTML(encoder.canonicalize(value));
}

问题是,如果我传递带有"%“符号的字符串,并使用StringEscapeUtils unescapeHtml进行解码,那么它会将"%”更改为�,是否应该使用不同的方法来消除转义呢?

EN

回答 2

Stack Overflow用户

发布于 2016-11-07 13:38:44

我认为这似乎是ESAPI默认编码器规范化方法的一个问题,刚刚在提到的GitHub链接https://github.com/ESAPI/esapi-java/issues/1中发现了一个问题跟踪器。

票数 0
EN

Stack Overflow用户

发布于 2016-11-08 05:47:26

问题在于您在这里使用Encoder.canonicalize()时所做的事情。规范化是在输入验证之前,而不是在输出之前。

这里只使用编码方法,不要使用canonicalize方法。

关于规范化的其他明智建议:

  1. 不要持久化规范化值。只使用它来执行验证逻辑。意思是,RawInput->Canonicalize>Validate。如果验证,持久化/处理原始值。
  2. 该方法的主要优点是检测混合或多重编码攻击。
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40466439

复制
相关文章

相似问题

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