一种网络通信协议,允许在单个 TCP(半双工) 连接上进行全双工通信(客户端和服务器可同时双向传输数据)。
HTTP是基于请求-响应模式的,也就是说客户端发送一个请求,服务器返回一个响应,然后连接就关闭了。
如果服务器想主动给客户端发消息,比如实时更新数据,客户端必须不断地轮询服务器,这会浪费资源。
WebSocket就运用于实时通信方面,比如聊天应用或者在线游戏等。
DNS,全称是Domain Name System,域名系统,默认端口号53。
将易记的域名转换为计算机可识别的IP地址的分布式数据库系统。
域名结构如 :www.example.com.:
在域名中,越靠右的位置表示其层级越高
.
),全球仅有13组根服务器集群。.com
, .org
, .net
,或国家代码如.cn
, .uk
。example
在example.com
中)。mail.example.com
)。各服务器负责部分(举例:
根DNS(.)
顶级DNS(.com)
权威DNS(example.com)
DNS 基于UDP协议实现。
HTTP协议是无状态的
服务器不会记住之前的请求。所以为了跟踪用户的状态,比如用户是否登录,就需要用到Cookie和Session。
存储会话信息或状态信息,服务器可以识别和跟踪特定用户的状态,以提供一定程度的状态保持功能
用户第一次访问网站时,服务器会创建一个Session,并生成一个唯一的Session ID,然后把这个ID通过Cookie发送给客户端。之后,客户端每次请求都会带上这个Cookie,服务器通过Session ID找到对应的Session,从而识别用户。
session
保存在服务器端的用户状态信息。
创建Session:用户首次访问时,服务器生成唯一Session ID(如abc123
)。
传递Session ID:通过Cookie(或URL重写:将Session ID附加到URLhttp://site.com?sid=abc123
)发送给客户端。
客户端携带Session ID:后续请求包含Session ID。
服务器检索Session:根据Session ID查找服务器存储的会话数据。
cookie
保存在客户端(比如浏览器)的小型数据片段。
服务器生成:服务器通过HTTP响应头Set-Cookie
发送Cookie到浏览器。
浏览器存储:浏览器保存Cookie,后续请求自动通过Cookie
请求头发送回服务器。
服务器读取:服务器解析Cookie内容,识别用户状态。
HTTP/1.1 200 OK
Set-Cookie: session_id=abc123; Expires=Wed, 21 Oct 2023 07:28:00 GMT; Secure; HttpOnly; SameSite=Lax
特性 | Cookie | Session |
---|---|---|
存储位置 | 客户端(浏览器) | 服务器端 |
数据类型 | 文本(键值对) | 任意结构(对象、数组等) |
安全性 | 较低(可能被篡改或窃取) | 较高(数据在服务器,仅传递Session ID) |
容量限制 | 每个域名≤4KB,总数有限(约50个) | 无硬性限制(受服务器资源影响) |
典型用途 | 用户偏好、跟踪标识 | 登录状态、敏感数据(如购物车) |
举个例子:
用户登录流程:
如果客户端禁用cookie?
则session无法正常使用。通过以下2种方式解决:
1.
URL重写
:将Session ID附加到URL(http://site.com?sid=abc123)。2.
隐藏表单字段
:通过HTML表单传递Session ID,当表单提交时,Session ID随表单数据一起发送回服务器获取会话状态。
如果我把数据存储到 localStorage,和Cookie有什么区别?
- 存储容量: localStorage>Cookie
- 数据发送:Cookie自动(通过HTTP请求头的
Cookie
字段),localStorage不会- 生命周期:Cookie设置过期时间,localStorage永久存储(手动删除)
- 安全性:Cookie
Cookie 适合用于在客户端和服务器之间传递数据、跨域访问和设置过期时间,而 LocalStorage 适合用于在同一域名下的不同页面之间共享数据,存储大量数据和永久存储数据。
用户登录成功后,服务器生成Token并返回给客户端,客户端保存(通常在localStorage或Cookie中),每次请求API时在Authorization头中携带Token。服务器验证Token的有效性,并据此处理请求。
1.Token通常指的是一种用于身份验证的令牌(不同于cookie,token开发者手动添加)。当用户登录后,服务器生成一个Token返回给客户端,客户端在后续的请求中携带这个Token来证明自己的身份。这种方式不需要服务器保存会话信息,因此称为无状态(stateless)认证。
2.JWT,即JSON Web Token。JWT是一种具体的Token实现方式,它定义了一种紧凑且自包含的方式,用于在各方之间安全地传输信息作为JSON对象。
jwt通常由三部分组成:头部Header、载荷Payload和签名Signature。通过.
分隔。
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c
头部Header
说明Token类型及签名算法
{
"alg": "HS256",
"typ": "JWT"
}
载荷Payload
包含用户数据
{
"sub": "1234567890",
"name": "John Doe",
"admin": true,
"iat": 1516239022
}
签名Signature
也是三部分组成:通过base64编码后的Header和Payload(以.拼接)后,再将它们通过一遍加密算法,最终得到签名Signature.
这里可以看看我的另一篇文章Java中的jwt学习
jwt令牌解决集群部署
集群部署
将应用程序部署在多个服务器上,有多个应用服务器实例
在单服务器环境下,Session数据存储在服务器的内存中,但当扩展到多台服务器时,如果用户的请求被负载均衡器分发到不同的服务器,后续请求可能到达没有该用户Session的服务器,导致用户需要重新登录。
jwt令牌泄露
Web服务器、反向代理服务器及电子邮件代理服务器
Web服务器
直接托管HTML、CSS、JS、图片等静态文件
通过协议将动态请求(如PHP、Python)转发给后端应用服务器。
反向代理服务器
将客户端请求分发到多个后端服务器(如Tomcat、Node.js)
支持轮询、加权轮询、IP哈希、最小连接数等。
nginx负载均衡算法
应用层的nginx用于将客户端请求合理地分发到后端服务器集群。
结合小林Coding不断学习中,感谢大家的观看>W<