Struts2 S2-020绕过漏洞 解决终极方案

[终极解决方案 2014.04.24 14:00]

事实证明之前公布的所有解决方案[包括其他公司及组织公布的]再次被无情的bypass了,我们最终选择了修改底层代码来实现防御。阿里云安全的安全专家‘空虚浪子心’再次分享了他的方法:

修改struts源码


com.opensymphony.xwork2.interceptor.ParametersInterceptor


搜索下面方法:

  1.     public void setExcludeParams(String commaDelim) {
  2.         Collection<String> excludePatterns = ArrayUtils.asCollection(commaDelim);
  3.         if (excludePatterns != null) {
  4.             excludeParams = new HashSet<Pattern>();
  5.             for (String pattern : excludePatterns) {
  6.                 excludeParams.add(Pattern.compile(pattern));
  7.             }
  8.         }
  9.     }

修改为:

  1.     public void setExcludeParams(String commaDelim) {
  2.         Collection<String> excludePatterns = ArrayUtils.asCollection(commaDelim);
  3.         if (excludePatterns != null) {
  4.             excludeParams = new HashSet<Pattern>();
  5.             for (String pattern : excludePatterns) {
  6.                 excludeParams.add(Pattern.compile(pattern));
  7.             }
  8.         }
  9.         //s021 zhenzheteng
  10.         Pattern s021_1 = Pattern.compile("(.*\\.|^)class\\..*",Pattern.CASE_INSENSITIVE);
  11.         Pattern s021_2 = Pattern.compile(".*'class'.*",Pattern.CASE_INSENSITIVE);
  12.         Pattern s021_3 = Pattern.compile("(.*\\.|^)class\\[.*",Pattern.CASE_INSENSITIVE);
  13.         excludeParams.add(s021_1);
  14.         excludeParams.add(s021_2);
  15.         excludeParams.add(s021_3);
  16.     }

 

 防止对方删除,自己做笔记,源地址是http://bbs.anquan.org/forum.php?mod=viewthread&tid=40548&page=1&extra=#pid86828

 

 

先试试替换最终版本xwork-core-2.3.16.1.jar 不行 再使用以上 代码修改。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值