Java:response.sendRedirect()如何能携带设定的cookie?

发布于 2022-09-06 09:19:16 字数 445 浏览 10 评论 0

有一个页面需要免登陆访问,所以我让客户端访问一个地址,地址在拦截器时转向一个方法,方法中需要先用httpclient获得session id,然后如下

Cookie cookie = new Cookie("JSESSIONID", jSessionId);
cookie.setMaxAge(0);
response.addCookie(cookie);   
String redirectUrl = request.getContextPath() + Global.getAdminPath() +  "/doCancel";
response.sendRedirect(redirectUrl);

redirectUrl是一个springmvc控制器的路径,指向一个模板jsp页面,
这就是最终需要免登陆访问的页面
在chrome调试看到,设定的cookie并没有带上
怎么回事?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

一世旳自豪 2022-09-13 09:19:16

1、把这段代码加上

cookie.setDomain(domain);
cookie.setPath("/");

2、转向的地址域名要和写入cookie的域(domain),在同一个域(例如:一级域 .baidu.com)下面

三月梨花 2022-09-13 09:19:16

你为什么要重新设置sessionId,什么场景

长梦不多时 2022-09-13 09:19:16

JSESSIONID是做为容器保留字的, 容器负责管理. 除非全部session都应用来管理, 否则不要重置,这本身也有安全问题. 可以做为参数加在URL后面

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文