• 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)

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

       
  • 相关阅读:
    主从复制(多台服务器搭建环境)【十五】
    Linux中kill,pkill,killall和xkill命令汇总讲解
    redis持久化机制【十三】
    守护进程详解及创建,daemon()使用
    【small项目】MySQL第二天早上第一次连接超时报错,解决方法com.mysql.jdbc.exceptions.jdbc4.CommunicationsException:
    Redis事务【十二】
    乐观锁和悲观锁的区别
    Redis 命令与连接【十一】
    Redis 配置【十】
    DB_Links创建际删除
  • 原文地址:https://www.cnblogs.com/zouhong/p/11795603.html
Copyright © 2020-2023  润新知