服务器返回400错误

运维的项目,莫名其妙的有些接口报了400错误,和前端一起检查了传参格式、传参实体类是否一一对应等,因为入参有中文,顺带把编码格式也查了,但都没问题,而且最神奇的是,正式服该接口就报400错误,在自己搭建的测试服上跑完全相同的入参,就没问题,搞得头皮发麻,最后到处乱转博客时,看到有个人说,tomcat高版本可能导致url中含有特殊字符,而导致报400错误。

最后才想到,前几天因为等保检测的原因,运维组那边把tomcat7换成了8。(我是开发,因为这个项目比较难,才扔给我运维)
然后才让前端把url进行特殊处理测试了一下,发现OK了,然后确定是tomcat版本过高导致的。
确定问题后,就是咋解决,当时我提出了三个方法:
1、前端把所有url都进行处理。(前端容易砍死我,而且这个是祖传项目,不太好改)
2、跟业主那边商量,换回tomcat7。(这个项目等保一年一测,可以忽悠过去,但是出了安全问题,需要我们负责)
3、修改tomcat的配置。(我当时跟老大说我先试试第三个方法,如果不行再想办法)

第三个办法的解决方法就是:
配置tomcat的catalina.properties
添加或者修改:
tomcat.util.http.parser.HttpParser.requestTargetAllow=|{}
在这里插入图片描述
但是呢,这个方法是有限制的,这里tomcat的开发人员,是把所有特殊字符都限制了的,然后那些实际使用人员,讨价还价后,增加了可以使用 | { } 这个三个特殊符号,其他符号依旧不行。(我公司自己的框架,就有#这种特性符号。。。)

如果遇到这种情况,可以讨论修改tomcat配置后,前端对有特殊符号的url进行处理。
进行url跳转时可以整体使用encodeURI
例如:Location.href=encodeURI(“http://cang.baidu.com/do/s?word=百度&ct=21”);

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值