会话技术-jsessionid的持久化(十九)

本文介绍了一种通过设置Cookie的生存时间来确保Session信息在浏览器重启后仍可获取的方法。通过Servlet示例展示了如何创建并保存Session,同时设置JSESSIONID的Cookie以实现跨会话的数据持久化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当我们把浏览器关闭了之后,session依然存在。但是,再次打开浏览器去访问这个session,就拿不到了。是因为,我们的cookie(jsessionid)没有了。

cookie默认是会话级别,我们把cookie的生存时间设置久一些就好了。

package com.ken.session;

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class SessionServlet1 extends HttpServlet {
	private static final long serialVersionUID = 1L;

	protected void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		// 创建属于该客户端(会话)的私有的session区域
		/*
		 * request.getSession()方法内部会判断 该客户端是否在服务器已经存在session
		 * 如果该客户端在此服务器不存在session,那么就会创建一个新的session对象
		 * 如果该客户端在此服务器已经存在session,就会获得该session返回
		 */
		HttpSession session = request.getSession();

		session.setAttribute("name", "jerry");

		String id = session.getId();// 该session对象的编号id(JSESSIONID)

		// 手动创建一个存储JSESSIONID的Cookie,为该cookie设置持久化时间
		Cookie cookie = new Cookie("JSESSIONID", "id");
//		cookie.setPath("/cookieDemo/");
		cookie.setMaxAge(10 * 60);

		response.addCookie(cookie);

		response.getWriter().write("JSESSIONID:" + id);
	}

	protected void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值