Linux 网络(8)

1.cookie

定义HTTP Cookie 是服务器发送到浏览器并本地保存的小块数据,后续向同一服务器发起请求时会自动携带,用于识别请求是否来自同一浏览器(如保持登录状态、记录用户偏好)。


工作原理

  1. 首次访问 :服务器在响应头中通过 Set-Cookie 字段发送 Cookie 到浏览器。
  2. 本地存储:浏览器按域名保存 Cookie。
  3. 后续请求 :浏览器自动在请求头的 Cookie 字段中携带保存的信息。

分类

  • 会话 Cookie:浏览器关闭后即失效。
  • 持久 Cookie:带有明确过期时间,可跨浏览器会话存在;以二进制或 sqlite 等格式存储为浏览器相关文件,

安全性

由于 Cookie 是存储在客户端的,因此存在被篡改或窃取的风险。
用途

用户认证和会话管理(最重要)

跟踪用户行为

缓存用户偏好等

比如在 chrome 浏览器下,可以直接访问:chrome://settings/cookies
认识****cookie

HTTP 存在一个报头选项:Set-Cookie, 可以用来进行给浏览器设置 Cookie
值。

在 HTTP 响应头中添加,客户端(如浏览器)获取并自行设置并保存
Cookie。

cpp 复制代码
C++
Set-Cookie: <name>=<value>
其中 <name> 是 Cookie 的名称,<value> 是 Cookie 的值。





C++
Set-Cookie: username=peter; expires=Thu, 18 Dec 2024 12:00:00
UTC; path=/; domain=.example.com; secure; HttpOnly

时间格式必须遵守 RFC 1123标准,具体格式样例:Tue, 01 Jan 2030 12:34:56
GMT 或者 UTC(推荐)。
关于其他可选属性的解释

expires=<date>要验证:设置 Cookie 的过期日期/时间。如果未指定此属
性,则 Cookie 默认为会话 Cookie,即当浏览器关闭时过期。

path=<some_path>要验证:限制 Cookie 发送到服务器的哪些路径。默认
为设置它的路径。

domain=<domain_name>了解即可:指定哪些主机可以接受该 Cookie。默
认为设置它的主机。

secure了解即可:仅当使用 HTTPS 协议时才发送 Cookie。这有助于防止
Cookie 在不安全的 HTTP 连接中被截获。
HttpOnly了解即可:标记 Cookie 为 HttpOnly,意味着该 Cookie 不能被
客户端脚本(如 JavaScript)访问。这有助于防止跨站脚本攻击(XSS)。
注意事项

每个 Cookie 属性都以分号(;)和空格( )分隔。

名称和值之间使用等号(=)分隔。

如果 Cookie 的名称或值包含特殊字符(如空格、分号、逗号等),则需要
进行 URL 编码。
Cookie****的生命周期
如果设置了 expires 属性,则 Cookie 将在指定的日期/时间后过期。

如果没有设置 expires 属性,则 Cookie 默认为会话 Cookie,即当浏览器
关闭时过期。
单独使用Cookie,有什么问题?

我们写入的是测试数据,如果写入的是用户的私密数据呢?比如,用户名密码,
浏览痕迹等。

本质问题在于这些用户私密数据在浏览器(用户端)保存,非常容易被人盗取,更
重要的是,除了被盗取,还有就是用户私密数据也就泄漏了。

2.session

定义HTTP Session 是服务器用于跟踪用户交互期间状态的机制,弥补了 HTTP 协议 "无状态"(每个请求独立)的缺陷,让服务器能记住用户信息。


工作原理

  1. 首次访问 :服务器为用户生成唯一的 Session ID,并通过 Cookie 发送到客户端。
  2. 后续请求 :客户端自动携带该 Session ID,服务器通过它识别用户并获取对应的会话信息。
  3. 存储方式:Session 信息通常存储在服务器的内存、数据库或缓存中。

安全性

  • 风险:Session ID 在客户端与服务器间传递,存在被窃取的可能。
  • 优势:仅泄露 Session ID 时,用户私密信息暂不直接暴露;便于服务端管理(如异地登录)。
  • 增强手段:通过 HTTPS 传输,或设置 Cookie 的 HttpOnlySecure 等属性提升安全性。

超时与失效

  • 可设置超时时间,超时后自动失效。
  • 服务器可主动使 Session 失效(如用户登出时)。

用途

  • 用户认证与会话管理。
  • 存储用户临时数据(如购物车内容)。
  • 实现分布式系统的会话共享(将数据存储在共享数据库或缓存中)。
相关推荐
2401_868534781 小时前
NFV:将安全设备部署到虚拟机上
网络
zhengfei6111 小时前
【渗透工具】Payloader — 渗透测试辅助平台(payload一键所有)
网络·安全·web安全
鼎讯信通2 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..2 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
跨境数据猎手3 小时前
大数据在电商行业的应用
大数据·运维·爬虫
Multipath7123 小时前
无人区不掉线:多链路聚合路由,为环塔拉力赛筑起“空中通讯走廊”
网络·5g·安全·无人机·实时音视频
linyanRPA4 小时前
影刀RPA店群自动化实战:多店铺活动自动报名与促销管理架构设计
运维·自动化·办公自动化·rpa·python脚本·爬虫自动化·店群自动化
mounter6254 小时前
现代 Linux 内存管理的演进与变革:从传统 LRU 到多代架构 MGLRU
linux·服务器·kernel
会Tk矩阵群控的小木4 小时前
安卓群控系统对于游戏工作室实战教程
android·运维·游戏·adb·开源软件·个人开发
赵渝强老师4 小时前
【赵渝强老师】Kubernetes(K8s)中的金丝雀升级
linux·docker·云原生·容器·kubernetes