Cookie
Cookie只对当前浏览器有效,当浏览器进程关闭时,它也关闭。
在系统文件中保存需要设置最大有效期
每一个Cookie都有domain属性
domain=www.baidu.com
domain=www.sina.com
dimain=localhost
Cookie中的domain属性与请求的主机名一致,这个Cookie会封装在消息头字段中,发送到服务器端
//把请求信息中封装的账号或者昵称保存到Cookie中
//从请求信息中获取用户的账号和昵称
String name=request.getParameter("name");
String nickName=request.getParameter("nickName");
if(name==null || nickName==null){
out.println("请输入姓名和昵称");
return;
}
//创建Cookie对象,保存会话状态
Cookie cookie1=new Cookie("name",name);
cookie1.setMaxAge(24*60*60);// 设置最大有效期
Cookie cookie2=new Cookie("nickName",nickName);
//将Cookie对象添加到响应消息头字段
System.out.println(cookie1.getName()+cookie1.getValue());
cookie1.setDomain(".localhost");
System.out.println(cookie1.getDomain());
cookie1.setPath("/");
response.addCookie(cookie1);
response.addCookie(cookie2);
out.println("欢迎访问本页面");
//将请求消息中封装的消息对象将Cookie获取并读取出来
Cookie cookies[]=request.getCookies();
if(cookies != null){
//读取所有的Cookie
for(int i=0;i<cookies.length;i++){
System.out.println(cookies[i].getName()+":"+cookies[i].getValue()+":"+cookies[i].getMaxAge()+":"+cookies[i].getDomain());
}
}
//判断是否是第一次访问此站点
Cookie[] cookies=request.getCookies();
if(cookies != null){
for(int i=0;i<cookies.length;i++){
//通过循环读取去每一个参数
String last=cookies[i].getName();//上一次的访问时间
if("last_time".equals(last)){
out.println("你是老用户,上一次访问的时间是"+cookies[i].getValue());
break;
}
}
}else{
out.println("你是第一次访问这个站点");
}
Cookie cookie=new Cookie("last_time",new Date(System.currentTimeMillis()).toString());
cookie.setMaxAge(30*24*60*60); // 设置最大有效期
response.addCookie(cookie);
Set-Cookie2响应头字段
1、Set-Cookie2头字段用于指定WEB服务器向客户端传送的Cookie内容,但是按照Netscape规范实现Cookie功能的WEB服务器,使用的是Set-Cookie头字段,两者的语法和作用类似。
2、Set-Cookie2头字段中设置的cookie内容是具有一定格式的字符串,它必须以Cookie的名称和设置值开头,格式为“名称=值”,后面可以加上0个或多个以分号(;)和空格分隔的其它可选属性,属性格式一般为“属性名=值”。
举例:Set-Cookie2: user=it315; Version=1; Path=/
3、 除了“名称=值”对必须位于最前面外,其它的可选属性的先后顺序可以任意。
4、 Cookie的名称只能由普通的英文ASCII字符组成,浏览器不用关心和理解Cookie的值部分的意义和格式,只要WEB服务器能理解值部分的意义就行。
5、 大多数现有的WEB服务器都是采用某种编码方式将值部分的内容编码成可打印的ASCII字符,RFC 2965规范中没有明确限定编码方式。
Set-Cookie2头字段中的属性
1、 Comment=value
2、 Discard
3、 Domain=value
例如:Set-Cookie2: user=it315; Version=1; Path=/; Domain=.it315.org
4、 Max-Age=value
5、 Path=value
6、 Port[="portlist"]
7、 Secure
8、 Version=value
Cookie请求头字段
1、 浏览器使用Cookie请求头字段将Cookie信息回送给WEB服务器。
2、 多个Cookie信息通过一个Cookie请求头字段回送给WEB服务器。
3、 浏览器根据下面的几个规则决定是否发送某个Cookie信息:
ü 请求的主机名是否与某个存储的Cookie的Domain属性匹配;
ü 请求的端口号是否在该Cookie的Port属性列表中;
ü 请求的资源路径是否在该Cookie的Path属性指定的目录及子目录中;
ü 该Cookie的有效期是否已过。
4、 Cookie请求头字段中的每个Cookie之间用逗号(,)或分号(;)分隔。
5、 在Cookie请求头字段中除了必须有“名称=值”的设置外,还可以有Version、Path、Domain、Port等几个属性。
6、 在Version、Path、Domain、Port等属性名之前,都要增加一个“$”字符作为前缀。
7、 Version属性只能出现一次,且要位于Cookie请求头字段设置值的最前面,如果需要设置某个Cookie信息的 Path、Domain、Port等属性,它们必须位于该Cookie信息的“名称=值”设置之后。
8、 Path属性指向子目录的Cookie排在Path属性指向父目录的Cookie之前。
举例:Cookie: $Version=1; Course=Java; $Path=/it315/lesson; Course=vc; $Path=/it315
在Servlet程序中使用Cookie
1、 Servlet API中提供了一个javax.servlet.http.Cookie类来封装Cookie信息,它包含有生成Cookie信息和提取Cookie信息的各个属性的方法。
2、 Cookie类的方法:
ü 构造方法: public Cookie(java.lang.String name,java.lang.String value)
ü getName方法
ü setValue与getValue方法
ü setMaxAge与getMaxAge方法
ü setPath与getPath方法
ü setDomain与getDomain方法
ü setVersion与getVersion方法
ü setComment与getComment方法
ü setSecure与getSecure方法
3、 HttpServletResponse接口中定义了一个addCookie方法,它用于在发送给浏览器的HTTP响应消息中增加一个Set-Cookie响应头字段。
4、 HttpServletRequest接口中定义了一个getCookies方法,它用于从HTTP请求消息的Cookie请求头字段中读取所有的Cookie项。