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 功能。

相关推荐
刘孬孬沉迷学习34 分钟前
5G网络gNB与核心网(5GC)连接架构及传输协议
网络·网络协议·tcp/ip·5g·架构·udp·信息与通信
lang201509281 小时前
WebSocket子协议STOMP
网络·websocket·网络协议
饺子大魔王的男人1 小时前
3秒传输GB级文件:FastSend让P2P共享告别云存储依赖
网络·网络协议·p2p
tonydf2 小时前
如何正确统计网络用户数量?别再被连接数和独立IP骗了!
后端·网络协议
我叫汪枫4 小时前
《HTTP 实战:常用调试工具与抓包技巧》
网络·网络协议·http
googleccsdn5 小时前
ENSP Pro Lab笔记:配置STP/RSTP/MSTP(4)
网络·笔记·网络协议
奋斗的蛋黄6 小时前
TCP 和 UDP 的核心区别:从原理到场景的全面解析
网络协议·tcp/ip·udp
七月稻草人6 小时前
Rust 中的路由匹配与参数提取:类型安全的 HTTP 路径解析艺术
安全·http·rust
普普通通的南瓜7 小时前
金融交易防护:国密 SSL 证书在网银与移动支付中的核心作用
网络·网络协议·安全·arcgis·gitlab·ssl·源代码管理