Servlet(六)——Cookie对象

Cookie对象

Cookie是浏览器提供的一种技术, 通过服务器的程序能将一些只须保存在客户端, 或者在客户端进行处理的数据,放在本地的计算机上,不需要通过网络传输, 因而提高网页处理的效率, 并且能够减少服务器的负载,但是由于Cookie是服务器端保存在客户端的信息, 所以其安全性也是很差的。例如常见的记住密码则可以通过Cookie来实现。

有一个专门操作Cookie的类 javax.servlet.http.Cookie。 随着服务器端的响应发送给客户端, 保存在浏览器。当下次再访问服务器时把Cookie再带回服务器。

Cookie的格式:键值对用"="链接, 多个键值对间通过”;"隔开。

1.Cookie的创建的发送

通过 new Cookie(“key”,“value”);来创建一个 Cookie对象,要想将Cookie 随响应发送到客户端,需要先添加到response对象中, response.addCookie(cookie);此时该cookie 对象则随着响应发送至了客户端。在浏览器上可以看见。

// 创建Cookie对象  
Cookie cookie = new Cookie("uname","zhangsan"); 
// 发送Cookie对象  
response.addcookie(cookie);

F12查看
请添加图片描述

2.Cookie的获取

在服务器端只提供了一个 getCookies()的方法用来获取客户端回传的所有 cookie 组成的一个数组,如果需要获取单个 cookie 则需要通过遍历,getName()获取 cookie 的名称, getValue()获取 cookie 的值。

// 获取Cookie数组
Cookie[] cookies = request.getCookies(); // 判断数组是否为空
if (cookies != null && cookies.length > 0) { // 遍历Cookie数组
	for (Cookie cookie : cookies){
		System.out.print]n(cookie.getName());
		System.out.print]n(cookie.getValue());  
	}
}

3.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。

//到期时间:负整数(默认值-1。表示只在浏览器内存中存活,关闭浏览器失效)
Cookie cookie=new Cookie("uname1","zhangsan");
cookie.setMaxAge(-1);//关闭浏览器失效
resp.addCookie(cookie);

//到期时间:正整数(表示存活指定秒数,会将数据存在磁盘中)
Cookie cookie2=new Cookie("uname2","lisi");
cookie2.setMaxAge(30);
resp.addCookie(cookie2);


//到期时间:零(表示删除cookie)
Cookie cookie3=new Cookie("uname3","wangwu");
cookie2.setMaxAge(0);
resp.addCookie(cookie3);

4. Cookie的注意点

4.1 Cookie保存在当前浏览器中。

在一般的站点中常常有记住用户名这样一个操作 ,该操作只是将信息保存在本机上, 换电脑以后这些信息就无效了。而且cookie还不能跨浏览器。

4.2 Cookie存中文问题

Cookie中不能出现中文,如果有中文则通过 URLEncoder.encode()来进行编码, 获取时通过URLDecoder.decode()来进行解码。

 /*cookie存中文*/
 String name="姓名";
 String value="张三";
 //将中文通过URLEncoder进行编码
 name= URLEncoder.encode(name);
 value=URLEncoder.encode(value);

 //创建Cookie对象
 Cookie cookie=new Cookie(name,value);
 //响应cookie
 resp.addCookie(cookie);

 //获取cookie时,通过URLDecoder进行解码
 Cookie[] cookies=req.getCookies();
 //判断非空
 if(cookies !=null && cookies.length>0){
     //遍历
     for(Cookie cook:cookies){
         //解码
         System.out.println(URLDecoder.decode(cook.getName()));
         System.out.println(URLDecoder.decode(cook.getValue()));
     }
 }

4.3 同名Cookie问题

如果服务器端发送重复的Cookie那么会覆盖原有的Cookie

 //将原来已有的Cookie对象重新设置
 Cookie cookie1=new Cookie("name","value");
 resp.addCookie(cookie1);

4.4 浏览器存放Cookie的数量

不同的浏览器对Cookie也有限定,Cookie的存储有是上限的。Cookie是存储在客户端(浏览器)的,而且一般是由服务器端创建和设定。后期结合Session来实现回话跟踪。

5. Cookie的路径

Cookie的setPath设置cookie的路径, 这个路径直接决定服务器的请求是否会从浏览器中加载某些cookie。

情景一:当前服务器下任何项目的任意资源都可获取Cookie对象

/*当前项目路径为:s01*/
Cookie cookie = new Cookie("xxx","xxx");
//设置路径为"/", 表示在当前服务器下任何项目都可访问到Cookie对象cookie.setPath("/");
response.addCookie(cookie);

情景二:当前项目下的资源可获取Cookie对象(默认不设置Cookie的path)

/*当前项目路径为:s01*/
Cookie cookie = new Cookie("xxx","xxx");
//设置路径为"/s01", 表示在当前项目下任何项目都可访问到Cookie对象cookie.setPath("/s01");//默认情况, 可不设置path的值
response.addCookie(cookie);

情景三:指定项目下的资源可获取Cookie对象

/*当前项目路径为:s01*/
Cookie cookie = new Cookie("xxx","xxx");
//设置路径为"/s02", 表示在s02项目下才可访问到Cookie对象
cookie.setPath("/s02");//只能在s02项目下获取Cookie, 就算cookie是s01产生的,s01也不能获取它
response.addcookie(cookie);

情景四:指定目录下的资源可获取Cookie对象

/*当前项目路径为:s01 */
Cookie cookie = new Cookie("xxx","xxx");
//设置路径为"/s01/cook",表示在s02/cook目录下才可访问到Cookie对象cookie.setPath("/s01/cook");
response.addcookie(cookie);

如果我们设置path, 如果当前访问的路径包含了cookie的路径 (当前访问路径在cookie路径基础上要比cookie的范围小)cookie就会加载到req uest对象之中。
Cookie的路径指的是可以访问该cookie的顶层目录 ,该路径的子路径也可以访问该Cookie。

总结: 当访问的路径包含了cookie的路径时,则该请求将带上该cookie;如果访问路径不包含cookie路径,则该请求不会携带该cookie

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值