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

错误信息如下:

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>

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值