15_会话技术_Cookie

【简述】

会话可理解为:用户打开一个浏览器,点击多个超链接,访问服务器多个Web资源,然后关闭浏览器,整个过程成为一个会话。

【会话过程中我们要解决的一些问题】

* 每个用户与服务器进行交互的过程中,各自会有一些数据,程序要想办法保存每个用户的数据。

具体例子:用户点击超链接通过一个Servlet购买了一个商品,程序应该保存用户购买的商品,以便于用户点击结账Servlet时,结账的Servlet可以得到用户商品为用户结账。

【Cookie简述】

Cookie是客户端技术。程序把每个用户的数据以cookie的形式写给用户各自的浏览器。当用户使用浏览器再去访问服务器中的Web资源时,就会带着各自的数据去。这样Web资源处理的就是用户各自的数据了。

【Session简述】

Session是服务端技术,利用这个技术,服务器在运行时可以为每一个用户的浏览器创建一个其独享的Session对象,由于Session为用户浏览器独享,所以用户再访问服务器的Web资源时,就可以把各自的数据放在各自的Session中,当用户再去访问服务器中的其它Web资源时,其它Web资源再从用户各自的Session中取出数据为用户服务。

【Cookie API——javax.servlet.http.Cookie类】

  javax.servlet.http.Cookie类用于创建一个Cookie,response接口中也定义了一个addCookie方法,它用于在其响应头中增加一个相应的Set-Coookie头字段。

同样,request接口中也定义了一个getCookies方法,它用于获取客户端提交的Cookie。

[ 常用方法如下 ]

[1.构造Cookie对象]

public Cookie(String name,String value)  //构造Cookie对象

[2.设置cookie]

setValue()     与  getValue()         //设置和获取Cookie的值

setMaxAge() 与   getMaxAge()     //设置和获取Cookie的有效期

setPath()      与   getPath()         //设置和获取Cookie的有效访问路径

setDomain()  与   getDomain()

[3.发送cookie到浏览器端保存]

void response.addCookie(Cookie cookie);

[4.服务端接受cookie]

Cookie[] request.getCookie();    :接受cookie

getName()  //获取cookie的name

 [ 提示  关于setPath ]

* cookie.setPath("/");  可以在webapp(如果是Tomcat)文件夹下的所有应用共享Cookie

* cookie.setPath("/Helloservlet/");   指cookie只能在HelloServlet应用下获得,即便是产生这个Cookie的Web应用也不可以。

【Cookie原理】

1.服务器创建cookie对象,把回话数据存储到cookie对象中。

  new Cookie("name","value"); 

2.服务器发送cookie信息到浏览器。

  response.addCookie( cookie );

  [举例:响应头]set-cookie:name=Jack ( 隐藏发送了一个set-Cookie名称的响应头 )

3.浏览器得到服务器发送的cookie,然后保存在浏览器端。

4.浏览器在下次访问服务器时,会带着cookie信息

  [举例:请求头]cookie:name=jack   ( 隐藏带着一个叫cookie名称的请求头 )

5.服务器接收到浏览器带来的cookie信息

  request.getCookies();

【案例:利用Cookie技术获得用户上次登录的时间】

[ CookieDemo00.java ]

package com.Higgin.servlet;

import java.io.IOException;
import java.io.PrintWriter;
import java.text.SimpleDateFormat;
import java.util.Date;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/CookieDemo00")
public class CookieDemo00 extends HttpServlet {
    public CookieDemo00() {
        super();
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=UTF-8");
        
        PrintWriter out =response.getWriter();
        out.print("您上次访问的时间是:");   //打印到浏览器
        
        //1.获得用户的时间Cookie
        Cookie[] cookies=request.getCookies(); //读取浏览器发送请求中的Cookie对象
        for(int i=0;cookies!=null&&i<cookies.length;i++){
            if(cookies[i].getName().equals("lastAccessTime")){
                Long cookieValue=Long.parseLong(cookies[i].getValue());  //得到用户上次的访问时间戳
          out.print(cookieValue); //直接打印时间戳了! //Date date=new Date(cookieValue); //由于Tomcat的时间有点出错,暂时不用这种方式,直接用时间戳 //SimpleDateFormat dateFormat=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //out.print(dateFormat.format(date)); //打印到页面的是格式化后的时间 } } //2.给用户回送最新的访问时间 Cookie cookie=new Cookie("lastAccessTime",System.currentTimeMillis()+""); cookie.setMaxAge(60*5); //Cookie的寿命为5分钟 cookie.setPath("/HelloServlet"); response.addCookie(cookie); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { } }

[ 第一次访问 http://localhost:8080/HelloServlet/CookieDemo00  ]

 [ 5分钟内再次访问  第二次访问在5分钟内,所以是带着Cookie数据的 ] 

 

[ 5 分钟之后 访问 Cookie失效  效果等同于第一次访问]

【Cookie注意点】

* 一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(Name)和设置值(Value)。

* 一个Web站点可以给一个Web浏览器发送多个Cookie,一个Web浏览器也可以存储多个Web站点提供Cookie。

* cookie的数据类型只能保存非中文字符串类型的。可以保存多个cookie,浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie大小限制为4KB。

* 如果创建了一个Cookie,并将它发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),用户退出浏览器之后即被删除。若用户希望该cookie存储在磁盘上,则需要使用maxAge,并给出一个以秒为单位的时间。将最大时间设置为0即命令浏览器删除该Cookie。

* 注意,删除cookie时,path必须一致,否则将无法删除。

 【Cookie细节】

* void setPath( String uri ):设置cookie的有效访问路径。有效访问路径指的是cookie的有效路径保存在哪里,那么浏览器在有效路径下访问服务器时就会带着cookie信息,否则不带cookie信息。

* void setMaxAge( int expiry ):设置cookie的有效时间

  [ 正整数 ]:表示cookie保存在浏览器的缓存目录中(硬盘中),数值表示保存的时间。

  [ 负整数 ]:表示cookie的数据保存浏览器的内存中。浏览器关闭cookie就丢失了!

  [    零    ]:表示删除同名的cookie数据。

原文地址:https://www.cnblogs.com/HigginCui/p/5991112.html