对cookie源码的粗浅认识
2021/8/11 20:07:04
本文主要是介绍对cookie源码的粗浅认识,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1.关于cookie对象的创建
cookie在实例化时只有一个有参构造函数,cookie没有set函数,只能通过这个有参构造进行键值对的设置
在将key和value存入cookie对象之前,会先进行验证:
如果之前有同key的cookie,会进行一个覆盖。
如果key输入不合法,例如为空则报异常
2.request.getCookies();的实现原理
每个页面除了可能存在的由程序员设置的cookie对象外,还有一个必定存在的页面自带的cookie——JSESSIONID,由服务器自动赋予浏览器。
如果我们使用request.getCookies();获取到页面的cookies对象数组,然后循环打印每一个cookies
那么我们会获取到如下的cookies
多次刷新下,每个cookie存的键值对的值不会变化,但是cookies本身会发生改变,这说明每次request.getCookies();返回的cookie对象都不一样,这就涉及到request.getCookies();方法的底层实现原理
整个方法的底层实现模拟如图,说明如下:
①String cookieString = request.getHeader("Cookie");
②String[] cookies = cookieString.split("; ");
③String[] cookieStr = s.split("=");
第一个方法是从请求头中获取到cookie属性的所有值,如图:
这里面包含页面的所有cookie,每个cookie用分号隔开,配合第二个方法进行字符串分割,就可以得到一个cookie键值对的数组,如注释那般,每个索引对应一个cookie键值对
进入循环后再配合第三个方法切分每个键值对,获得单独的key和value,再new一个cookie对象并存入值,然后把new的对象存入一个对象数组,循环完毕后把对象数组输出。
最终输出的cookies和直接使用request.getCookies();获得的cookie对象数组一样
这里面的关键点就是new对象 这就是为什么每次刷新时getCookies()返回的cookie地址(直接toString输出的字符串)都不一样的原因
3.cookie在浏览器和服务器之间传递的顺序
页面最开始加载后只有服务器给页面的一个储存ID的cookie
当我们执行了servlet中的方法——①创建cookie②发送cookie给页面 之后 页面就存在两种cookie request和response的
最后 刷新页面后,页面就只存在request cookie 用于浏览器传给服务器
当浏览器向服务器发送请求之后,服务器使用response.addCookie()添加cookie到浏览器上,此时cookie对象存储在浏览器上的response cookies中,当浏览器下一次发送其他请求时,在response cookie中的cookie会封装到消息头中,跟随整个请求头从浏览器传输到服务器上。这次请求完成之后,在浏览器上存储的cookie转移到request cookie中。
这篇关于对cookie源码的粗浅认识的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-05在 etcd 中怎么看有多少客户端在监视特定键 (watch)-icode9专业技术文章分享
- 2024-11-05uniapp 怎么实现返回上一页效果-icode9专业技术文章分享
- 2024-11-05UniApp 中则么实现检查一个 URL 是否以 "http://" 开头功能-icode9专业技术文章分享
- 2024-11-05怎么使用nslookup指定dns解析?-icode9专业技术文章分享
- 2024-11-05shopify 中 的 analyticsToken 一般多久过期?-icode9专业技术文章分享
- 2024-11-05array_intersect_key 有没有前后顺序-icode9专业技术文章分享
- 2024-11-05在 CodeIgniter 3.x 中,怎么批量插入返回值?-icode9专业技术文章分享
- 2024-11-05初学者必备:轻松入门TypeScript (ts)编程
- 2024-11-05TypeScript 入门教程:从零开始学习
- 2024-11-05TypeScript入门指南:从基础到实践