【踩坑之路】tomcat8 cookie domain validation 问题修复方案

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

错误信息如下:

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] 其中包含了“:”,所以挂逼了

二、解决之法: 

添加后如下:








WEB-INF/web.xml
${catalina.base}/conf/web.xml





转载于:https://my.oschina.net/weijuer/blog/1602913

你可能感兴趣的:(【踩坑之路】tomcat8 cookie domain validation 问题修复方案)