zoukankan      html  css  js  c++  java
  • java.lang.IllegalArgumentException: Invalid character found in the request target. The valid charact

    线上环境中部署的 Tomcat 项目,出现部分页面无法打开的情况,但本地环境是好的。经过排查发现,本地 Tomcat版本为 7.0.77,而线上版本为 7.0.88。报错的具体描述为java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986

    描述

    Tomcat 的日志如下:

    INFO: Error parsing HTTP request header
    Note: further occurrences of HTTP header parsing errors will be logged at DEBUG level.
    java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986

    具体原因是,从 7.0.88 开始,Tomcat为了安全考虑,不在支持[,]这种参数传递方式了。解决办法如下,修改 $TOMCAT_HOME/conf/server.xml,新增 relaxedQueryChars="[,]"选项。

    1. 1
    2. 2
    3. 3
    1. <Connector port="8080" protocol="HTTP/1.1"
    2. connectionTimeout="20000"
    3. redirectPort="8444" relaxedQueryChars="[,]"/>
       

    报错:

    Note: further occurrences of HTTP header parsing errors will be logged at DEBUG level.  
    
    java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986……

    错误原因:

    当在浏览器中访问时 URL中带有特殊字符,如花括号冒号时,就会出现这个错误。

    例如:http://localhost:8080/index.do?{id:123}

    解决方法:

    1、去除URL中的特殊字符;

    3、使用 Post 方法提交数据

    4、更换低版本的Tomcat来规避这种问题。

    5、在 conf/catalina.properties  添加或者修改: 

      5.1  添加  tomcat.util.http.parser.HttpParser.requestTargetAllow=|{} 

    5.2  修改tomcat/conf/catalina.properties的配置文件
    Tomcat在 7.0.73, 8.0.39, 8.5.7 版本后,添加了对于http头的验证。
    具体来说,就是添加了些规则去限制HTTP头的规范性
    org.apache.tomcat.util.http.parser.HttpParser#IS_NOT_REQUEST_TARGET[]中定义了一堆not request target
    if(IS_CONTROL[i] || i > 127 || i == 32 || i == 34 || i == 35 || i == 60 || i == 62 || i == 92 || i == 94 || i == 96 || i == 123 || i == 124 || i == 125) {
    IS_NOT_REQUEST_TARGET[i] = true;
    }
    转换过来就是以下字符(对应10进制ASCII看):
    键盘上那些控制键:(<32或者=127)
    非英文字符(>127)
    空格(32)
    双引号(34)
    #(35)
    <(60)
    >(62)
    反斜杠(92)
    ^(94)
    TAB上面那个键,我也不晓得嫩个读(96)
    {(123)
    }(124)
    |(125)

    重启服务器后,解决问题。

       
  • 相关阅读:
    VS Code的常用备忘
    Echarts圆环,初始化时进度条效果
    nodejs 复制文件到 另一路径下 。可以在npm库看下mv 和 mvdir 有一点区别
    nginx启动报错(1113: No mapping for the Unicode character exists in the target multi-byte code page
    Echarts dataZome 横向移动动态显示数据
    flex布局时,会有兼容性问题,所以能少用flex布局的地方还是要避免下
    python 搭建 flask 和 orator框架开发
    直播 小测试
    对高并发的理解
    MySQL 中文分词原理
  • 原文地址:https://www.cnblogs.com/zouhong/p/11795603.html
Copyright © 2011-2022 走看看