Cookie

Cookie_第1张图片
cookie技术的原理

(1)当浏览器需要保存数据时,服务器首先获得要保存的数据,通过Set-Cookie响应头将要保存的数据发送给浏览器,让浏览器自己保存。浏览器收到后,会以Cookie的形式保存在浏览器内部。
(2)当浏览器下次再被访问服务器时,都会以Cookie请求头带着上次保存的Cookie信息,在服务器端,可以通过Cookie请求头获取之前发送给浏览器的数据,从而实现某些操作。
(3)Cookie是将会话中产生的数据保存在客户端,是客户端技术。

public class Cookie implements Cloneable, Serializable {
}

Cookie的API

SUN公司为了简化Cookie的操作,提供了一套Cookie的API.
1.创建Cookie对象

Cookie cookie=new Cookie(String name, String value);

2.将cookie添加到response响应中

(void) response.addCookie(cookie);
//将cookie添加到response响应中,可以多次调用该方法添加一个以上的cookie
//底层就是通过Set-Cookie响应头将数据发送给浏览器保存

3.获取请求中所有cookie组成的数组

//获取请求中的所有cookie(对象组成的数组)
Cookie[]cs=request.getCookies();

4.删除Cookie
Cookie的API中没有直接删除cooke的方法

可以通过设置cookie的最大存活时间来间接删除Cookie
我们再向浏览器发送一个同名,同虚拟路径(path)的cookie,同时设置Cookie的生存时间为0,再将cookie发送给浏览器
由于浏览器是根据cookie的名字+虚拟路径path来区分一样的cookie,又由于后发的cookie生存时间为0,浏览器收到后也会立即删除该cookie。

public int getMaxAge()

返回以秒为单位指定的 cookie 的最大生存时间,默认情况下,-1 指示该 cookie 将保留到浏览器关闭为止。 return 指定 cookie 的最大生存时间(以秒为单位)的整数;如果为负数,则表示该 cookie 保留到浏览器关闭为止

Cookie cookie=new Cookie("time","");
//2.设置cookie的path为当前web应用的虚拟路径
cookie.setPath(request.getContextPath()+"/");
//3.设置cookie的存活时间为0
cookie.setMaxAge(0);
//4.将cookie发送给浏览器
response.addCookie(cookie);

5.Cookie的常用方法
(1)String name = cookie.getName();
-获取cookie的名字
(2)String value = cookie.getValue();
-获取cookie的值
(3) void setValue(String newValue);
-设置cookie的值
(4)void setMaxAge(int expiry);
-设置cookie的存活时间
(5)void setPath(String uri) ;
-设置cookie的路径

setMaxAge()-设置cookie最大的存活时间

(1)如果没有设置该方法,cookie默认是会话级别的cookie(会话结束cookie就会过期),默认保存在浏览器的内存中,如果浏览器关闭,内存释放,cookie也会跟着销毁。
(2)如果设置该方法(值必须为正值),cookie会以文件的形式保存在浏览器的临时文件夹中(硬盘),如果浏览器再关闭,内存释放了,但是保存的cookie文件还在,cookie信息不回丢失,再次打开浏览器,访问服务器时还会带着保存的cookie信息。

setPath()-设置cookie的路径

如果希望浏览器在访问当前web应用下任何一个资源都能带着cookie,可以将cookiede的path设置为当前web应用的虚拟路径

cookie.setPath(request.getContextPath()+"/");

后面拼接上一根斜杠的作用是:如果当前web应用是缺省的Web应用,getContextPath()的返回值为"",但是路径的设置不能为"",所以后面要拼接上一根斜杠。

例子,在网页上显示上次访问时间

Cookie_第2张图片
package cookie;

import java.io.IOException;
import java.util.Date;

import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/*
 * 在网页中显示上次访问时间
 */
public class CookieDemo1 extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        response.setContentType("text/html;charset=utf-8");
        //1.获取本次访问时间
        String dateStr1 = new Date().toString();
        //2.将本次访问时间通过cookie发送给浏览器保存
        //response.setHeader("Set-Cookie", dateStr1);//传统方法,不推荐
        
        //>>创建Cookie对象
        Cookie cookie=new Cookie("time", dateStr1);
        //>>设置cookie的最大存活时间(单位是秒)
        cookie.setMaxAge(3600*24);
        //>>设置cookie的path为当前web应用的虚拟路径
        cookie.setPath(request.getContextPath()+"/");
        //>>将cookie添加到response响应中,发送给浏览器保存
        response.addCookie(cookie);//其实底层在调用response.setHeader("Set-Cookie", dateStr1);响应头
        
        
        //3.获取上一次访问的时间
        //>>获取请求中的所有cookie(对象组成的数组)
        Cookie[]cs=request.getCookies();
        //>>遍历所有cookie找出名称为time的cookie,获取上次访问时间
        String dateStr2=null;

        if(cs!=null)
        {
            for (Cookie c : cs) {
                if("time".equals(c.getName()))
                {
                    dateStr2=c.getValue();
                }
            }
        }
        if(dateStr2!=null)
        {
            //4.将上次访问时间发送给浏览器并显示在网页中
            response.getWriter().write("您上次访问时间为:"+dateStr2);
        }else{
            //5.没有上次访问时间,则响应第一次访问
            response.getWriter().write("您是第一次访问本网站");
        }
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        doGet(request, response);
    }

}

删除cookie

package cookie;

import java.io.IOException;

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

/*
 * 删除cookie
 */
public class CookieRemoved extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        //删除名称为time,path为当前web应用虚拟路径的cookie
        //1.创建一个名称为time的cookie
        Cookie cookie=new Cookie("time","");
        //2.设置cookie的path为当前web应用的虚拟路径
        cookie.setPath(request.getContextPath()+"/");
        //3.设置cookie的存活时间为0
        cookie.setMaxAge(0);
        //4.将cookie发送给浏览器
        response.addCookie(cookie);
        response.getWriter().write("Cookie delete Success");
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        doGet(request, response);
    }

}

你可能感兴趣的:(Cookie)