美文网首页
Servlet学习笔记(四)——Cookie和Session

Servlet学习笔记(四)——Cookie和Session

作者: Yinag | 来源:发表于2017-12-09 16:38 被阅读0次

    最近,学习注意力老是不集中,但是昨晚跟同学谈谈心了后,慢慢地状态回来了,是时候拼尽全力去争取自己想要的东西。有些事、人过了就过了,不再去叹息,也不回头。好的,接着上一章继续我们的故事:


    (一)重定向
    在重定向的情况下,总共对Web资源进行了两次请求
    第二次的request对象再也找不到第一次request域对象的请求内容了,因为整个请求过程完成后就会被清空。
    那么如何才能重新获得第一次request域对象的内容呢?

    servletContext域对象的存在使得这个问题迎刃而解

    1.在重定向的情况下,request域对象不能用了,因此我们用ServletContext域对象替代。
    ServletContext 域对象有如下特点:
    (1)ServletContext域对象的创建时期:在进行Web应用部署时,启动服务器就创建了。即,在第一次访问前ServletContext就创建完毕。
    (2)Tomcat中的每一个Web应用,都自己专属的ServletContext域对象。
    (3)一个Web应用下的所有web资源,全部共享自己所在区域的ServletContext域对象。
    (4)由Servlet引擎负责创建ServletContext域对象。
    (5)ServletContext域对象的销毁时期:当进行Web服务器停止或者重新部署应用时,原有的ServletContext域对象就被销毁掉。
    注意:关闭浏览器并不会使得ServletContext域对象被销毁
    2.ServletContext域对象的生命周期图

    生命周期
    (二)Cookie

    会话:用户打开一个浏览器,浏览点击了多个链接网址,访问多个web资源,直到关闭浏览器的整个过程,称之为一个会话过程。

    在用户浏览网页的过程中,难免会有些数据产生是需要服务器获得的。客户端和服务器之间会进行数据交互,在这里我们有两种保存会话数据的技术,各有各的优缺点。

    1.什么是Cookie?
    Cookie是客户端技术,创建于服务端。服务器把每个用户的数据以cookie的形式写给用户各自的浏览器。当用户使用该浏览器去访问服务端的时候就会带着自己的cookie去访问,从而达到了数据有记录且处理的是用户各自的数据的目的。

    方法:服务器向用户的浏览器写入set-cookie响应头

    • 一个网站的cookie对应着一个文件,有着多个cookie。如果一个文件被写满了,则可以写入另外一个文件中。
    • 一个浏览器可存入多个网站的cookie,每个网站只能寻找对应的cookie。
      如果cookie的缓存时间过期了,就算在浏览器的缓存区中,服务器也再也读取不到的。

    注意:cookie在代码中需要设置缓存时间,不然,执行完整个会话过程,不会有cookie的存在。

    //设置cookie的有效时间,单位为秒
    cookie.setMaxAge(1*24*60*60);
    
    
    cookie.setPath(request.getContextPath());//获取缓存的网站,请求的网站
    //将cookie输出给浏览器
    response.addCookie(cookie);
    

    4.cookie的细节
    (1)cookie的弊端:只能以key:value的形式进行存储,若有多个cookie时会显得很繁琐、不实用。
    (2)一个cookie只能标识一种信息,它至少含有一个能够标识该信息的标识名称和设置值。
    (3)一个Web站点(百度、新浪服务器)可以给一个Web浏览器多个cookie。一个Web浏览器可以接收多个Web站点的cookie。
    5.总结:浏览器存放cookie的数量是有限制的。如果创建了一个cookie,并将它发送到浏览器,默认的情况下,它是一个会话级别的cookie(即存储在浏览器的内存中)。当用户退出浏览器时,cookie即销毁。若想cookie有段存活时间,则需要设置缓存时间

    (三)HttpSession
    1.什么是HttpSession?
    HttpSession是一种服务端技术,创建于服务端,存储在服务端。每个浏览器都有在服务端独自共享的、属于自己的HttpSession。

    • 在Web开发过程中,服务器都会为每个用户的浏览器创建一个会话对象(session域对象),一个浏览器独占一个session对象(通常的,默认情况下)。
    • session对象有服务器创建,API:
    request.getSession();//创建得到session对象
    

    2.session域对象
    (1)API:request.getSession();
    有两层意思:

    • 如果服务器没有与客户端相对应的session,则创建session对象
    • 如果已有,表示获取原有的session。

    (2)同样,有着是域对象的常用方法。

    setAttribute;
    addAttribute;
    getAttribute;
    removeAttribute;
    

    (3)不管在转发或者是重定向的情况下,多个servlet共享同一个HttpSession对象


    3.域对象的创建、销毁时刻

    4.Session运行原理
    为什么除了首次请求之外每次请求都会发送这个cookie呢(在这里确切地说是发送这个jsessionid)?

    事实上当用户访问服务器的时候会为每一个用户开启一个session,浏览器是怎么判断这个session到底是属于哪个用户呢?jsessionid的作用就体现出来了:jsessionid就是用来判断当前用户对应于哪个session。换句话说服务器识别session的方法是通过jsessionid来告诉服务器该客户端的session在内存的什么地方。

    事实上jsessionid ==request.getSession().getId()


    session cookie

    相关文章

      网友评论

          本文标题:Servlet学习笔记(四)——Cookie和Session

          本文链接:https://www.haomeiwen.com/subject/pakuixtx.html