1.Cookie对象
Cookie是浏览器提供的一种技术,通过服务器的程序能将一些只须保存在客户端,或者在客户端进行处理的数据,放在本地的计算机上,不需要通过网络传输,因而提高网页处理的效率,并且能够减少服务器的负载,但是由于Cookie是服务器端保存在客户端的信息,所以其安全性也是很差的。例如常见的记住密码则可以通过
Cookie来实现。
有一个专门操作Cookie的类javax.servlet.http.Cookie。随着服务器端的响应发送给客户端,保存在浏览器。当下次再访问服务器时把Cookie商带回服务器。
Cookie的格式:键值对用“=“链接,多个键值对间通过”;“隔开。
2.Cookie的创建的发送
通过new Cookie("key " “value”);来创建一个Cookie对象,要想将Cookie随响应发送到客户端,需要先添加到response对象中,response.addCookie(cookie);此时该cookie对象则随着响应发送至了客户端。在浏览器上可以看见。
//创建cookie对象
cookie cookie = new cookie( "uname" , "zhangsan");//发送cookie对象
response.addcookie(cookie);
3.Cookie的获取
在服务器端只提供了一个getCookies()的方法用来获取客户端回传的所有cookie组成的一个数组,如果需要获取单个cookie则需要通过遍历,getName()获取Cookie的名称,getValue()获取Cookie的值。
//获取Cookie数组
Cookie[] cookies =request.getCookies();
//判断cookies是否为空
if(cookies !=null && cookies.length>0) {
//遍历Cookie数组
for(Cookie cookie :cookies ){
String name = cookie.getName();
String value = cookie.getValue();
System.out.println("名称:"+name+"值:"+value);
}
4.Cookie设置到期时间
除了Cookie的名称和内容外,我们还需要关心一个信息,到期时间,到期时间用来指定该cookie何时失效。默认为当前浏览器关闭即失效。我们可以手动设定 cookie的有效时间(通过到期时间计算),通过
setMaxAge(int time);方法设定cookie 的最大有效时间,以秒为单位。
到期时间的取值
- 负整数
若为负数,表示不存储该cookie。
cookie 的 maxAge 属性的默认值就是-1,表示只在浏览器内存中存活,一旦天团浏觉器窗口,那么 cooKIe 就会消失。 - 正整数
若大于0的整数,表示存储的秒数。
表示cookie对象可存活指定的秒数。当生命大于0时,浏览器会把Cookie保存到硬盘上,就算关闭浏览器,就算重启客户端电脑,cookie 也会存活相应的时间。 - 零
若为0,表示删除该cookie。
cookie生命等于0是一个特殊的值,它表示 cookie被作废! 也就是说,如果原来浏览器已经保存了这个Cookie,那么可以通过Cookie的setMaxAge(0)来删除这个Cookie。无论是在浏览器内存中,还是在客户端硬盘上都会删除这个Cookie。
设置Cookie对象指定时间后失效
/*到期时间:负整数(默认值-1.表示只在浏览器内存中存活,关闭浏览器失效)*/
Cookie cookie01 = new Cookie("uname01", "lijiaqi");
cookie01.setMaxAge(-1);//关闭浏览器失效
response.addCookie(cookie01);
/*到期时间:正整数(表示存活指定秒数,会将数据存在磁盘中)*/
Cookie cookie02 = new Cookie("uname02", "xinyouzhi");
cookie02.setMaxAge(30);//cookie存活30秒
response.addCookie(cookie02);
/*到期时间:零(表示删除cookie) */
Cookie cookie03 = new Cookie("uname03", "erlvde");
cookie03.setMaxAge(0);//删除cookie
response.addCookie(cookie03);