错误信息如下:
Type Exception Report
Message An invalid domain [127.0.0.1:8080] was specified for this cookie
Description The server encountered an unexpected condition that prevented it from fulfilling the request.
Exception
java.lang.IllegalArgumentException: An invalid domain [127.0.0.1:8080] was specified for this cookie
org.apache.tomcat.util.http.Rfc6265CookieProcessor.validateDomain(Rfc6265CookieProcessor.java:198)
org.apache.tomcat.util.http.Rfc6265CookieProcessor.generateHeader(Rfc6265CookieProcessor.java:145)
org.apache.catalina.connector.Response.generateCookieString(Response.java:1019)
org.apache.catalina.connector.Response.addCookie(Response.java:967)
org.apache.catalina.connector.ResponseFacade.addCookie(ResponseFacade.java:386)
com.vrv.im.filter.SSOFilter.addCookie(SSOFilter.java:298)
com.vrv.im.filter.SSOFilter.doFilter(SSOFilter.java:165)
这是因为你本地的tomcat版本过高,你可以找到tomcat安装目录 context.xml
例如我的:
C:\Weijuer\Dev\apache-tomcat-8.5.24\conf\context.xml
添加代码,指定CookieProcessor为LegacyCookieProcessor而非Rfc6265CookieProcessor
一、原因分析:
Rfc6265CookieProcessor 使用的domain规则如下
1、必须是1-9、a-z、A-Z、. 、- (注意是-不是_)这几个字符组成
2、必须是数字或字母开头 (所以以前的cookie的设置为.i5a6.com 的机制要改为 i5a6.com 即可)
3、必须是数字或字母结尾
因为本案例中使用了[127.0.0.1:8080] 其中包含了“:”,所以挂逼了
二、解决之法:
<CookieProcessor className="org.apache.tomcat.util.http.LegacyCookieProcessor" />
添加后如下:
<?xml version="1.0" encoding="UTF-8”?>
<!-- The contents of this file will be loaded for each web application -->
<Context>
<!-- Default set of monitored resources. If one of these changes, the -->
<!-- web application will be reloaded. -->
<WatchedResource>WEB-INF/web.xml</WatchedResource>
<WatchedResource>${catalina.base}/conf/web.xml</WatchedResource>
<!-- Uncomment this to disable session persistence across Tomcat restarts -->
<!-- <Manager pathname="" /> -->
<!-- 添加代码 -->
<CookieProcessor className="org.apache.tomcat.util.http.LegacyCookieProcessor"/>
</Context>