浅谈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、维基百科,文中图源自扔物线的课程视频。

相关推荐
gywl2 小时前
openEuler VM虚拟机操作(期末考试)
linux·服务器·网络·windows·http·centos
某柚啊3 小时前
Windows开启IIS后依然出现http error 503.the service is unavailable
windows·http
_oP_i3 小时前
HTTP 请求Media typetext/plain application/json text/json区别
网络协议·http·json
yang_shengy3 小时前
【JavaEE】网络(6)
服务器·网络·http·https
ihengshuai5 小时前
HTTP协议及安全防范
网络协议·安全·http
码农丁丁10 小时前
[前端]HTTP库Axios
前端·网络协议·http·aixos
等一场春雨13 小时前
403 Forbidden HTTP 响应状态码
网络·网络协议·http
青灯文案116 小时前
前端 HTTP 请求由 Nginx 反向代理和 API 网关到后端服务的流程
前端·nginx·http
小林熬夜学编程18 小时前
【Linux网络编程】第十四弹---构建功能丰富的HTTP服务器:从状态码处理到服务函数扩展
linux·运维·服务器·c语言·网络·c++·http
njnu@liyong1 天前
图解HTTP-HTTP报文
网络协议·计算机网络·http