项目开发中遇到一个问题,保存第三方跳转过来的url所带的参数到cookie,并持久化到本地。如果使用Servlet 使用的api,会导致某些时候cookie无法存在本地的问题,因此本次修改,改为setHeader
最开始时,将过期日期的格式设置为 dd-MM-yyyy HH:mm:ss,但发现google console上面的过期时间是session,即该会话后,此cookie消失:
code1:
Calendar cal = Calendar.getInstance();
cal.add(Calendar.YEAR, 1);
Date date = cal.getTime();
Locale locale = Locale.CHINA;
SimpleDateFormat sdf = new SimpleDateFormat("dd-MM-yyyy HH:mm:ss", locale);
StringBuilder builder = new StringBuilder();
builder.append(name + "=" + value + "; ");
builder.append("Path=/; HttpOnly; ");
builder.append("Expires=" + sdf.format(date));
response.setHeader("Set-Cookie", builder.toString());
效果如图:
想了一下可能是时间格式 的问题,找了几篇文章,参考了一下
http://www.kancloud.cn/kancloud/http-cookies-explained/48328
https://github.com/alsotang/node-lessons/tree/master/lesson16
https://docs.oracle.com/javase/7/docs/api/java/text/SimpleDateFormat.html
将日期格式设置为 “EEE, d MMM yyyy HH:mm:ss Z”,但浏浏览器的上cookie的过期日期仍然为Session,
点开ResponseHeader中发现过期时间中时间格式里有乱码,应该是本地时间出问题了,因此在 SimpleDateFormat中加入入本地化参数us
code2:
Date date = DateUtils.addMonths(DateUtils.today(), 12);
SimpleDateFormat sdf = new SimpleDateFormat("EEE, d MMM yyyy HH:mm:ss Z", Locale.US);
StringBuilder builder = new StringBuilder();
builder.append(name + "=" + value + "; ");
builder.append("Path=/; HttpOnly; ");
builder.append("Expires=" + sdf.format(date));
response.setHeader("Set-Cookie", builder.toString());