java 中Cookie设置Expires的问题

  项目开发中遇到一个问题,保存第三方跳转过来的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());

效果如图:

174851_t13m_1383934.png

想了一下可能是时间格式 的问题,找了几篇文章,参考了一下

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());

180546_Cdxa_1383934.png


转载于:https://my.oschina.net/u/1383934/blog/619434

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值