servelt的cookie操作

简介: servelt的cookie操作

Cookie对象


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

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

18.1.png

18.2.png


Cookie 的格式:键值对用“=”链接,多个键值对间通过“;”隔开。Cookie的创建和发送

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

F12 查看

18.3.png

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.println(cookie.getName());
        System.out.println(cookie.getValue());
   }
}

18.4.png

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对象指定时间后失效/

18.5.png

Cookie的注意点


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


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

3. 同名Cookie问题 如果服务器端发送重复的Cookie那么会覆盖原有的Cookie。

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

String name = "姓名";
String value = "张三";

// 通过 URLEncoder.encode()来进行编码

name = URLEncoder.encode(name);
value = URLEncoder.encode(value);

// 创建Cookie对象

Cookie cookie = new Cookie(name,value);

// 发送Cookie对象

response.addCookie(cookie);

// 获取时通过 URLDecoder.decode()来进行解码

URLDecoder.decode(cookie.getName());
URLDecoder.decode(cookie.getValue());

/* Cookie存中文 */
    String name = "姓名";
    String value = "张三";
    // 将中文通过URLEncoder进行编码
    name = URLEncoder.encode(name);
    value = URLEncoder.encode(value);
    // 创建Cookie对象
    Cookie cookie = new Cookie(name,value);
    // 响应Cookie
    response.addCookie(cookie);
    // 获取Cookie时,通过URLDecoder进行解码
    Cookie[] cookies = request.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()));
        }
    }
    // 将原来已有的Cookie对象重新设置
    Cookie cookie2 = new Cookie("name","zhangsan");//与cookie1里面的name不一样
    response.addCookie(cookie2);

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就会加载到request对象之中。 cookie的路径指的是可以访问该cookie的顶层目录,该路径的子路径也可以访问该cookie。 总结:当访问的路径包含了cookie的路径时,则该请求将带上该cookie;如果访问路径不包含 cookie路径,则该请求不会携带该cookie。

/* 当前服务器下任何项目的任意资源都可获取Cookie对象 */
Cookie cookie01 = new Cookie("cookie01","cookie01");
// 设置路径为"/",表示在当前服务器下任何项目都可访问到Cookie对象
cookie01.setPath("/");
response.addCookie(cookie01);
/* 当前项目下的资源可获取Cookie对象 (默认不设置Cookie的path) */
Cookie cookie02 = new Cookie("cookie02","cookie02");
// 默认不设置Cookie的path 或者 设置为当前站点名
cookie02.setPath("/s4");
response.addCookie(cookie02);
/* 指定项目下的资源可获取Cookie对象 */
Cookie cookie03 = new Cookie("cookie03","cookie03");
// 设置指定项目的站点名
cookie03.setPath("/sr03");
response.addCookie(cookie03);
/* 指定目录下的资源可获取Cookie对象 */
Cookie cookie04 = new Cookie("cookie04","cookie04");
// 设置指定项目的站点名
cookie04.setPath("/s4/c02");
response.addCookie(cookie04);

相关文章
|
6月前
|
存储 Web App开发 安全
Django中Cookie相关操作
Django中Cookie相关操作
|
存储 JavaScript
js -cookie的操作
cookie是存储在客户端浏览器中的一段文本信息。
|
6月前
|
存储 JavaScript 前端开发
JavaScript DOM 操作:解释一下 cookie、sessionStorage 和 localStorage 的区别。
Cookie是服务器发送至客户端的文本信息,会随每个请求发送回服务器,适合控制会话状态但可能暴露隐私。SessionStorage仅在当前会话中存储数据,关闭浏览器后清除,适合临时存储如登录状态。LocalStorage则持久保存数据,即使关闭浏览器也不会清除,适用于存储长期设置。三种方式各有侧重,应按需求选择。
45 0
|
6月前
|
存储 前端开发 Java
【源码共读】在前端如何操作 Cookie
【源码共读】在前端如何操作 Cookie
113 1
|
存储 JavaScript 前端开发
cookie相关操作
cookie相关操作
54 0
|
JavaScript 前端开发 Java
【JavaEE】使Cookie与Session失效-Servlet上传文件操作-优化表白墙
虽然Cookie和Session都是暂时存在的,不久就会被删掉,但是我们要退出登录的时候,就不能等待其自然消除了~
73 0
|
存储 前端开发 Java
【JavaEE】使Cookie与Session失效-Servlet上传文件操作-优化表白墙
虽然Cookie和Session都是暂时存在的,不久就会被删掉,但是我们要退出登录的时候,就不能等待其自然消除了~
105 0
|
测试技术
Selenium 操作表单元素、行为链、操作Cookie和页面等待
Selenium 操作表单元素、行为链、操作Cookie和页面等待
115 0
|
Java 开发者
Cookie操作|学习笔记
快速学习Cookie操作
Cookie操作|学习笔记
|
存储 安全 JavaScript
JavaScript操作Cookie——高级篇
JavaScript操作Cookie——高级篇
121 0