今天发现一个问题,程序在本地运行好好地,打包到服务器,无论怎么加日志,更新打包,最后还是有问题,
一步一步定位问题,发现是cookie的问题。
服务端定义设置cookie的代码:
public void setCookie(HttpServletRequest request, HttpServletResponse response, String key,String value) {
Cookie cookie = new Cookie(key, value);// 创建一个cookie,cookie的名字是key
cookie.setDomain(request.getServerName());
cookie.setPath(request.getContextPath());
// 设置Cookie的有效期
cookie.setMaxAge(Constants.cookieMaxAge);
// cookie.setHttpOnly(true);
// 将cookie对象添加到response对象中,这样服务器在输出response对象中的内容时就会把cookie也输出到客户端浏览器
response.addCookie(cookie);
}
最开始是怀疑cookie没有在服务端写入,后来通过日志,发现服务端写入了,但是客户端怎么也取不到。以前做
web开发时遇到cookie的问题,基本就是域和路径的问题,但是本地运行没有问题,而且线上环境也没有问题,我开始
琢磨应该是别的问题,过期时间问题。
我们设置的时间是43200秒也就是12个小时,但是实际上看到进入首页,确实写入了cookie,但是过期时间是在服务
器时间的12小时之后,这里就是问题的重点。测试服务器时间设置的超前了。
最后发现测试环境的机器确实被人动过,时间改为了当天较早的时间,而我们的cookie过期时间是12个小时,即使
是12个小时即43200秒也是过了当前时间,后来修改测试环境时间为当前时间就好了,这样tomcat也不用重启。
修改服务器时间:
说明一点,如果在服务器端将cookie的httpOnly属性设置为true,也是会导致服务器写入了cookie,客户端取不到cookie。