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

当我们把浏览器关闭了之后,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);
	}
}

你可能感兴趣的:(Servlet)