JavaWeb温习之Session对象
2017-03-30 16:28
489 查看
1. Session简单介绍
在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务。2. Session和Cookie的主要区别
Cookie是把用户的数据写给用户的浏览器。Session技术把用户的数据写到用户独占的session中。
Session对象由服务器创建,开发人员可以调用request对象的getSession方法得到session对象。
3. session实现原理
3.1、服务器是如何实现一个session为一个用户浏览器服务的
服务器创建session出来后,会把session的id号,以cookie的形式回写给客户机,这样,只要客户机的浏览器不关,再去访问服务器时,都会带着session的id号去,服务器发现客户机浏览器带session id过来了,就会使用内存中与之对应的session为之服务。可以用如下的代码证明:1 package xdp.gacl.session; 2 3 import java.io.IOException; 4 import javax.servlet.ServletException; 5 import javax.servlet.http.HttpServlet; 6 import javax.servlet.http.HttpServletRequest; 7 import javax.servlet.http.HttpServletResponse; 8 import javax.servlet.http.HttpSession; 9 10 public class SessionDemo1 extends HttpServlet { 11 12 public void doGet(HttpServletRequest request, HttpServletResponse response) 13 throws ServletException, IOException { 14 15 response.setCharacterEncoding("UTF=8"); 16 response.setContentType("text/html;charset=UTF-8"); 17 //使用request对象的getSession()获取session,如果session不存在则创建一个 18 HttpSession session = request.getSession(); 19 //将数据存储到session中 20 session.setAttribute("data", "孤傲苍狼"); 21 //获取session的Id 22 String sessionId = session.getId(); 23 //判断session是不是新创建的 24 if (session.isNew()) { 25 response.getWriter().print("session创建成功,session的id是:"+sessionId); 26 }else { 27 response.getWriter().print("服务器已经存在该session了,session的id是:"+sessionId); 28 } 29 } 30 31 public void doPost(HttpServletRequest request, HttpServletResponse response) 32 throws ServletException, IOException { 33 doGet(request, response); 34 } 35 }
request.getSession()方法内部新创建了Session之后一定是做了如下的处理
1 //获取session的Id 2 String sessionId = session.getId(); 3 //将session的Id存储到名字为JSESSIONID的cookie中 4 Cookie cookie = new Cookie("JSESSIONID", sessionId); 5 //设置cookie的有效路径 6 cookie.setPath(request.getContextPath()); 7 response.addCookie(cookie);
4. 浏览器禁用Cookie后的session处理
通常需要用URL重写来解决这种问题response.encodeRedirectURL(java.lang.String url) 用于对sendRedirect方法后的url地址进行重写
response.encodeURL(java.lang.String url)用于对表单action和超链接的url地址进行重写
而且response.encodeRedirectURL(java.lang.String url) 和response.encodeURL(java.lang.String url)是两个非常智能的方法,当检测到浏览器没有禁用cookie时,那么就不进行URL重写了
5. session对象的创建和销毁时机
在程序中第一次调用request.getSession()方法时就会创建一个新的Session,可以用isNew()方法来判断Session是不是新创建的,session对象默认30分钟没有使用,则服务器会自动销毁session,在web.xml文件中可以手工配置session的失效时间1 <?xml version="1.0" encoding="UTF-8"?> 2 <web-app version="2.5" 3 xmlns="http://java.sun.com/xml/ns/javaee" 4 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 5 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 6 http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> 7 <display-name></display-name> 8 9 <welcome-file-list> 10 <welcome-file>index.jsp</welcome-file> 11 </welcome-file-list> 12 13 <!-- 设置Session的有效时间:以分钟为单位--> 14 <session-config> 15 <session-timeout>15</session-timeout> 16 </session-config> 17 18 </web-app>
当需要在程序中手动设置Session失效时,可以手工调用session.invalidate方法,摧毁session。
1 HttpSession session = request.getSession(); 2 //手工调用session.invalidate方法,摧毁session 3 session.invalidate();
相关文章推荐
- java_web初学笔记之<Jsp四个域对象page/request/session/application>
- JavaWeb温习之Cookie对象
- JAVA_WEB Struts2学习:Struts2解耦、耦合方式获取request、session、aplication对象
- 【JavaWeb-20】3种对象状态以及相互转化、一级缓存和快照、Session其他API、一对多配置和操作、cascade
- 【javaweb:session】session域对象中保存的数据在什么范围内有效?一次会话!!
- java web 项目中通过session 统计在线访问人数
- web对象page、request、session、application的生命周期
- java 程序中获取session/request/response/上下文路径等对象
- Java Web_JSP内置对象
- 关于java web 开发中session过期的理解
- 【MVC设计模式】赵雅智_JavaWeb技术之--面向对象设计模式
- 【java web 学习笔记】java的集合对象
- 错误:非静态的字段、方法或属性“System.Web.UI.Page.Session.get”要求对象引用
- 转:java web中的cookie and session
- 【JavaWeb】Session
- JAVA_WEB之Session防止表单重复提交
- JavaWeb体系结构的理解-3.JSP内置对象
- 错误:非静态的字段、方法或属性“System.Web.UI.Page.Session.get”要求对象引用
- JAVA Web开发中 JSP隐式对象
- [原]Java web学习系列之 Java web开发中的jsp九种内置对象