Session技术细节详解:
一、java.lang.String getId() : 得到session编号
1、代码详解:
2、细节详解:
二、两个getSession方法:
1、getSession(true) 等同于 getSession() : 创建或得到session对象。没有匹配的session编号,自动创建新的session对象。
2、getSession(false): 得到session对象。没有匹配的session编号,返回null。
三、void setMaxInactiveInterval(int interval) : 设置session的有效时间
session对象销毁时间:
1、默认情况30分钟后服务器自动回收
2、修改session回收时间
session.setMaxInactiveInterval(20);
3、全局修改session有效时间
四、手动销毁session对象
void invalidate() : 销毁session对象
五、如何避免浏览器的JSESSIONID的cookie随着浏览器关闭而丢失的问题?
答:
package sram.session;
import java.io.IOException;
import java.io.PrintWriter;
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 SessionDemo1 extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
HttpSession session = request.getSession();
/**
* 手动发送一个硬盘保存的cookie给浏览器
*/
Cookie c = new Cookie("JSESSIONID",session.getId());
c.setMaxAge(60*60);
response.addCookie(c);
session.setAttribute("name", "Endeavor");
System.out.println("保存成功!");
}
}