(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()的返回值为"",但是路径的设置不能为"",所以后面要拼接上一根斜杠。
例子,在网页上显示上次访问时间
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);
}
}