Cookie和HttpSession

来源:互联网 发布:中国新歌声网络直播权 编辑:程序博客网 时间:2024/04/25 13:12

Cookie

  • 由服务器创建保存到客户端浏览器的一个键值对,Cookie是HTTP协议制定的!先由服务器保存Cookie到浏览器,再下次浏览器请求服务器时把上一次请求得到Cookie再归还给服务器
  • javaWeb中使用Cookie
    使用repsonse.addCookie(“cookie.name”,”cookie.value”)方法向浏览器保存Cookie
    使用request.getCookies()方法获取浏览器归还的Cookie(获得的是一个cookie的集合,具体用cookie.getName();cookie.gatvalue())
  • Cookie的maxAge:Cookie的最大生命,即Cookie可保存的最大时长,以秒为单位.
    • maxAge>0:浏览器会把Cookie保存到客户机硬盘上,有效时长为maxAge的值决定。
    • maxAge<0:Cookie只在浏览器内存中存在,当用户关闭浏览器时,浏览器进程结束,同时Cookie也就死亡了。
    • maxAge=0:浏览器会马上删除这个Cookie!
  • Cookie的path( Cookie的path默认值:当前访问路径的父路径。)
    • Cookie的path并不是设置这个Cookie在客户端的保存路径
    • Cookie的path由服务器创建Cookie时设置
    • 浏览器访问服务器的路径,如果包含某个Cookie的路径,那么就会归还这个Cookie。
  • Cookie的domain
    保证后缀都一样的可以共享Cookie
    设置domain为:cookie.setDomain(“.baidu.com”);
    设置path为:cookie.setPath(“/”);

HttpSession

在JavaWeb中,使用session来完成会话跟踪,session底层依赖Cookie技术。

  • HttpSession是由JavaWeb提供的,用来会话跟踪的类。session是服务器端对象,保存在服务器端!!!
  • HttpSession是Servlet三大域对象之一(request、session、application(ServletContext)),所以它也有setAttribute()、getAttribute()、removeAttribute()方法
  • Servlet中得到session对象:HttpSession session = request.getSession();
    Jsp中得到session对象:session是jsp内置对象之下,不用创建就可以直接使用!
  • session域相关方法:
    void setAttribute(String name, Object value);
    Object getAttribute(String name);
    void removeAttribute(String name);

session原理

  • 获取Cookie中的JSESSIONID:

    • 如果sessionId不存在,创建session,把session保存起来,把新创建的sessionId保存到Cookie中
    • 如果sessionId存在,通过sessionId查找session对象,如果没有查找到,创建session,把session保存起来,把新创建的sessionId保存到Cookie中
    • 如果sessionId存在,通过sessionId查找到了session对象,那么就不会再创建session对象了。
    • 返回session
      如果创建了新的session,浏览器会得到一个包含了sessionId的Cookie,这个Cookie的生命为-1,即只在浏览器内存中存在,如果不关闭浏览器,那么Cookie就一直存在。 下次请求时,再次执行request.getSession()方法时,因为可以通过Cookie中的sessionId找到session对象,所以与上一次请求使用的是同一session对象。
  • 服务器不会马上给你创建session,在第一次获取session时,才会创建!request.getSession();

  • request.getSession(false)、request.getSession(true)、request.getSession(),后两个方法效果相同,
    第一个方法:如果session缓存中(如果cookie不存在),不存在session,那么返回null,而不会创建session对象。

    HttpSession其他方法:

  • String getId():获取sessionId;
  • int getMaxInactiveInterval():获取session可以的最大不活动时间(秒),默认为30分钟。当session在30分钟内没有使用,那么Tomcat会在session池中移除这个session;
  • void invalidate():让session失效!调用这个方法会被session失效,当session失效后,客户端再次请求,服务器会给客户端创建一个新的session,并在响应中给客户端新session的sessionId;
  • boolean isNew():查看session是否为新。当客户端第一次请求时,服务器为客户端创建session,但这时服务器还没有响应客户端,也就是还没有把sessionId响应给客户端时,这时session的状态为新。
  • web.xml中配置session的最大不活动时间
 <session-config>        <session-timeout>30</session-timeout>    </session-config>
  • 如果客户端禁用了Cookie,那么就无法得到sessionId,那么session也就无用了
0 0
原创粉丝点击