Cookies

Cookies

Cookie 本质上是一个小文件,由浏览器创建/管理,保存在浏览器本地,即用户自己的电脑上。

当你访问一个网站/网址时,浏览器会「帮」你将这个文件的内容发送至服务端(Tomcat)。这个小文件的内容都是「名值(name-value)对」。只有浏览器本地有这个网站/网址的相关 Cookie(小文件),浏览器『一定』会把它的内容「帮」你发送到服务端。这个过程无需程序员参与,不受程序员的控制。

浏览器「帮」你发送的 Cookie,可能不止一个。服务端获得浏览器发送来的所有 Cookie 的方法是通过 request 对象的 getCookies()

Cookie(小文件)是由浏览器在本地创建,但是,它是由服务端「通知/要求」浏览器去创建时,才会创建的。

浏览器通常支持每个网站 20 个 cookies 。

注意

cookie 中不能直接存放中文,所以需要做相应的处理。常见处理办法是使用 URLEncoder 和 URLDecoder 将中文字符串编码/解码成URL格式编码字符串。

可以通过传递 name 和 value 两个参数给Cookie类的构造函数来创建一个 cookie。在创建完 cookie 之后,可以设置它的 maxAge 属性,这个属性决定了cookie 何时过期(单位为秒)。

要将 cookie 发送到浏览器,需要调用 HttpServletResponse 的 add() 方法。

服务器若要读取浏览器提交的 cookie,可以通过 HttpServletRequest 接口的 getCookie() 方法,该方法返回一个 Cookie 数组,若没有 cookies 则返回 null 。你需要遍历整个数组来查询某个特定名称的 cookie 。

注意

并没有一个直接的方法来删除一个 cookie,你只能创建一个同名的 cookie,并将 maxAge 设置为 0,并添加到 HttpServletResponse 中来「覆盖」原来的那个 cookie 。

Cookie 最大的问题在于用户可以通过设置禁用浏览器的 cookie 功能。

相关推荐
JMchen1238 分钟前
Android网络安全实战:从HTTPS到双向认证
android·经验分享·网络协议·安全·web安全·https·kotlin
m0_737302589 分钟前
安卓证书在线生成_免费一键制作apk打包 一键制作工具
网络协议·https·ssl
Zach_yuan12 分钟前
传输层之TCP/UDP 核心原理全解析:从协议基础到实战机制
linux·网络协议·tcp/ip·udp
阿钱真强道44 分钟前
13 JetLinks MQTT:网关设备与网关子设备 - 温控设备场景
python·网络协议·harmonyos
寻星探路7 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
王达舒19947 小时前
HTTP vs HTTPS: 终极解析,保护你的数据究竟有多重要?
网络协议·http·https
朱皮皮呀7 小时前
HTTPS的工作过程
网络协议·http·https
Binary-Jeff7 小时前
一文读懂 HTTPS 协议及其工作流程
网络协议·web安全·http·https
那就回到过去14 小时前
MPLS多协议标签交换
网络·网络协议·hcip·mpls·ensp
胖咕噜的稞达鸭19 小时前
网络基础:初识TCP/IP协议
网络·网络协议·tcp/ip