浅谈Cookie的工作机制及用途

一、什么是Cookie

在讲解Cookie的工作机制之前我们先来聊聊Cookie是什么。

维基百科的解释如下:

HTTP cookie ,简称cookie ,又称"网站/浏览+魔饼/魔片"等,是浏览网站时由网络服务器创建并由网页浏览器存放在用户计算机或其他设备的小文本文件。

它存在于网络传输的报文中,通常由客户端向服务器发出请求报文 后,服务端向客户端返回响应报文 ,而响应报文 中就含有Set-Cookie字段,客户端接收到该报文后会自动保存Set-Cookie字段的值到本地,这就是Cookie的值。

二、Cookie的工作机制

  • 服务器需要客户端保存的内容,放在 Set-Cookie 里返回,客户端会自动保存
  • 客户端保存的 Cookie,会在之后的所有请求 里都携带进 Cookie 里发回给服务器。(:客户端保存 Cookie 是按照服务器域名来分类的。例如 shop.com 发回的 Cookie 保存下来以后,在之后向 games.com 的请求中并不会携带。)
  • 客户端保存的 Cookie 在超时后会被删除、没有设置超时时间的 Cookie (称作 Session Cookie)在浏览器关闭后就会自动删除;另外,服务器也可以主动删除还未过期的客户端 Cookies。

三、Cookie的用途

3.1 管理登录状态、验证自动登录

我们每次将微信、QQ后台关闭后,在几天内重新打开都不用重新登录,这是为什么呢?

且看下图:

用户在首次登录的时候,会将用户名和密码从客户端传到服务器中,验证登录成功后服务器会发送响应报文(即上文第二副图的HTTP...123的文段),其中包含了Set-Cookie字段,我们上文说到的,它的值就是我们要保存在本地的Cookie值,也就是上图的session_id字段,而当下一次用户发送的报文(不含有用户名和密码)携带的Cookie中含有该session_id,且在服务器中可以找到相同的session_id,则证明用户登录有效(找不到的情况一般是因为session_id过期然后被服务器清理了,这个时候就得重新登录拿到新的session_id)。而正因为本地保存的Cookie中可以自动用来进行登录验证,就不必再次输入用户名密码登录,所以也便实现了每次关闭后再打开QQ或是微信后它们都是已登录状态。

3.2 保存用户的偏好、主题

通过Cookie可以保存用户的主题设置、偏好设置等,在下一次打开后网站或者App后就可以通过Cookie快速配置主题等。 (有点类似前面的自动登录验证)

3.3 分析用户行为

淘宝等网站是怎么做到根据你的最近浏览记录来推荐一些物品呢?

上图便可解释一部分是Cookie在帮他们作祟。

  • 当你向服务器发送一个请求的时候,服务器返回的内容中有需要第三方才能打开的内容时(如一些图片),传到客户端时会自动 调用第三方打开,而第三方返回的Set-Cookie中就会带有第三方的一些标签,如上面的client_id,接着跟其他内容保留在同一个Cookie里
  • 而下次客户端再访问那个服务器的时候就会传Cookie过去服务器,也就顺带把第三方的client_id一并传过去,而那个服务器接收到client_id时,它就知道该怎么做了(即推荐相关内容给你)。

四、参考资料

扔物线的相关课程及讲义pdf、维基百科,文中图源自扔物线的课程视频。

相关推荐
Summer不秃1 小时前
深入理解 Token 无感刷新:从并发雪崩到单例锁 + 请求队列的完整实现
前端·http
lunzi_08266 小时前
《图解HTTP》--第3章 HTTP报文内的HTTP信息
网络·网络协议·http
路由侠内网穿透8 小时前
本地部署开源 HTTP 服务器 OpenLiteSpeed 并实现外部访问
运维·服务器·网络·网络协议·http·开源
ppandss18 小时前
JavaWeb从0到1-DAY7-HTTP 请求与响应处理
网络·网络协议·http
Bat U10 小时前
JavaEE|网络原理HTTP和HTTPS
网络协议·http·https
Shota Kishi1 天前
基于 Solana Geyser gRPC 数据流的 pump.fun 代币铸造实时检测:流式架构与 HTTP/2 协议分析
网络协议·http·架构
许长安1 天前
rpc和http的区别
经验分享·笔记·网络协议·http·rpc
Co_Hui1 天前
HTTP协议
http
许长安1 天前
gRPC 数据包传输格式解析:从 Protobuf 到 HTTP/2
c++·经验分享·笔记·http·rpc
芋只因1 天前
HTTP & HTTPS 详解
网络协议·http·https