出现问题:
用户不同的请求在处理的时候需要使用其他请求中的数据该怎么办?
如何解决:
session技术
使用
创建session对象
HttpSession session =req.getsession();
存储数据到session中
session.setAttribute(String name,Object value);
获取session对象
HttpSession session =req.getSession();
获取session中的数据
session.getAttribute(String uname);注意:返回的object类型,需要强制转换
删除session中的数据
session.removeAttribute(String uname);注意:如果有数据则删除,没有则什么都不做。
流程
1 浏览器发起请求到Aservlet,在AServlet中使用req.getSession()获取Session对象,如果此次请求中没有SessionID则创建一个新的Session对象,如果有SessionID则将其对应的Sessionl返回(前提是该session对象没有到期).
2 校验session是否失效,存储数据到seesion对象中或者获取session中的数据或删除session中的数据.
作用
session解决了同一个用户不同请求的数据共享问题
特点
1 储存在服务器端
2 可以存储任意类型数据
3 通过sessionId来区分不同session对象
4 作用域在一次会话或session不失效
作用域
一次会话,session不失效则同一用户的任意请求获取的都是同一个session
举例:
//获取请求信息
String uname = req.getParameter("uname");
//创建session对象
HttpSession session = req.getSession();
//存储数据到session对象中
session.setAttribute("uname",uname);
System.out.println("ServletSession.service():"+session.getId());
//从session对象中获取数据
String uname1 = (String) session.getAttribute("uname");
设置有效期
1 在conf文件夹下的web.xml文件中父标签下修改文本可以设置有效期
2 session.setMaxInactiveInterval(分钟数);
强制销毁
session.invalidate();