zoukankan      html  css  js  c++  java
  • Cookie

    1.Http协议与Cookie(了解)

      *Cookie是HTTP协议制定的!先由服务器保存Cookie到浏览器,在下次浏览器请求服务器时把上一次请求得到的Cookie归还给服务器

      *由服务器创建保存到客户端浏览器的一个键值对!服务器保存Cookie的响应头:Set-Cookie:aaa=AAA    Set-Cookie:bbb=BBB

        >response.addHeader("Set-Cookie","aaa=AAA");  response.addHeader("Set-Cookie","bbb=BBB");

      *当浏览器请求服务器时,会把该服务器保存的Cookie随请求发送给服务器。浏览器归还Cookie的请求头:Cookie:aaa=AAA;    bbb=BBB

      *Http协议规定(保证不给浏览器太大压力):

        >1个Cookie最大4KB

        >1个服务器最多向1个浏览器保存20个Cookie

        >1个浏览器最多可以保存300个Cookie

      *浏览器大战:因为浏览器竞争很激励,所以很多浏览器都会在一定范围内违反HTTP规定,但也不会让一个Cookie为4GB!

    2.Cookie的用途

      *服务器使用Cookie来跟踪客户端状态!

      *保存购物车(购物车中的商品不能用request保存,因为它是一个用户向服务器发送的多个请求信息)

      *显示上交登录名(也是一个用户多个请求)

    =========================Cookie是不能跨浏览器的!============================

    3.JavaWeb中使用Cookie

      *原始方式(了解):

        >使用response发送Set-Cookie响应头

        >使用request获取Cookie请求头

      *便捷方式(精通):

        >使用response.addCookie()方法向浏览器保存Cookie

        >使用request.getCookies()方法获取浏览器归还的Cookie

      Cookie例子:

        >一个jsp保存cookie,a.jsp

        >另一个jsp获取浏览器归还的cookie!b.jsp

    a.jsp

     1   <body>
     2     <h1>保存Cookie</h1>
     3     <%
     4         /* 也就是设置了响应头 */
     5         Cookie cookie1=new Cookie("aaa","AAA");
     6         response.addCookie(cookie1);
     7         
     8         
     9      %>
    10   </body>

    b.jsp

     1   <body>
     2     <h1>获取Cookie</h1>
     3     <%
     4         Cookie[] cookies=request.getCookies();//得到Cookie数组
     5         if(cookies!=null){//判断是否为空
     6             for(Cookie c:cookies){//循环打印Cookie,键值对
     7                 out.print(c.getName()+"="+c.getValue()+"<br/>");
     8             }
     9         }
    10      %>
    11   </body>

    在浏览器中请求http://localhost:8080/XJS_Cookie/cookie1/a.jsp结果:

    //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

    在浏览器中访问http://localhost:8080/XJS_Cookie/cookie1/b.jsp结果是:

    4.Cookie详解

      *Cookie不只有name和value两个属性

      *Cookie的maxAge(掌握):Cookie的最大生命,即Cookie可保存的最大时长。以秒为单位,例如:cookies.setMaxAge(60)表示这个Cookie会被浏览器保存到硬盘

        >maxAge>0:浏览器会把Cookie保存到客户端硬盘上,有效时长为maxAge的值决定。

        >maxAge<0:Cookie只在浏览器内存中存在,当用户关闭浏览器时,浏览器进程结束,同时Cookie也就死亡了。

        >maxAge=0:浏览器会马上删除这个Cookie!

    案例--Cookie的时间设置:

    //在浏览器中访问的路径:http://localhost:8080/XJS_JSP/cookie1/a.jsp

    1   <body>
    2     <h1>保存Cookie</h1>
    3     <%
    4         /* 也就是设置了响应头 */
    5         Cookie cookie1=new Cookie("aaa","AAA");
    6         cookie1.setMaxAge(60*60);
    7         response.addCookie(cookie1);
    8      %>
    9   </body>

     

      *Cookie的path(理解):

        >Cookie的path并不是设置这个Cookie在客户端的保存路径!!!

        >Cookie的path由服务器创建Cookie时设置

        >当浏览器访问服务器的某个路径时,需要归还哪些Cookie给服务器呢?这由Cookie的path决定。

        >浏览器访问服务器的路径,如果包含某个Cookie的路径,那么就会归还这个Cookie。

        >例如:

          <>aCookie.path=/day11_1/; bCookie.path=/day11_1/jsps/;  cCookie.path=/day11_1/jsps/cookie/;

          <>访问:/day11_1/index.jsp时,归还:aCookie

          <>访问:/day11_1/jsps/a.jsp时,归还:aCookie、bCookie

          <>访问:/day11_1/jsps/cookie/b.jsp时,归还:aCookie、bCookie、cCookie

        >Cookie的path默认值:当前访问路径的父路径。例如:在访问/day11_1/jsps/a.jsp时,响应的cookie(在这个a.jsp页面中设置cookie),那么这个cookie的默认path为/day11_1/jsps/

      *Cookie的domain(了解)  域

        >domain用来指定Cookie的域名!当多个二级域中共享Cookie时才有用。

        >例如:www.baidu.com、zhidao.baidu.com、news.baidu.com、tieba.baidu.com之间共享Cookie时可以使用domain---跨域共享Cookie

        >设置domain为:cookie.setDomain(".baidu.com");

        >设置path为:cookie.setPath("/");

    ===============================================

  • 相关阅读:
    第十次作业
    java第九次作业
    优秀的计算机编程类博客 和 文章
    SQLAlchemy使用总结
    Go Web
    beego
    项目注意事项
    爬虫
    Linux笔记
    计算机英语
  • 原文地址:https://www.cnblogs.com/xjs1874704478/p/10843539.html
Copyright © 2011-2022 走看看