计算机网络-WebSocket/DNS/Cookie/Session/Token/Jwt/Nginx
文章目录
- WebSocket
- DNS
- 什么是dns
- 域名解析
- 底层协议
- cookie/session
- Token/JWT
- Nginx
WebSocket
一种网络通信协议,允许在单个 TCP(半双工) 连接上进行全双工通信(客户端和服务器可同时双向传输数据)。
HTTP是基于请求-响应模式的,也就是说客户端发送一个请求,服务器返回一个响应,然后连接就关闭了。
如果服务器想主动给客户端发消息,比如实时更新数据,客户端必须不断地轮询服务器,这会浪费资源。
WebSocket就运用于实时通信方面,比如聊天应用或者在线游戏等。
DNS
什么是dns
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)
- 用户输入域名www.example.com,发给本地 DNS 服务器
- 本地域名服务器收到请求,如果缓存里有则直接返回,无则请求其根域名服务器
- 根域名服务器收到请求(发现是.com),将请求发送给顶级域名服务器
- 顶级域名服务器收到请求(发现是www.example.com),将请求发送给权威域名服务器
- 权威域名服务器查询后将对应的 IP 地址 X.X.X.X 告诉本地 DNS。
- 本地 DNS 再将 IP 地址返回客户端,客户端和目标建立连接。
底层协议
DNS 基于UDP协议实现。
- 无连接:UDP 不需要建立连接,直接发送请求,减少了通信延迟。
- 轻量级:DNS 查询和响应通常是小数据包,一个UDP包就能容纳
- 简单快速: UDP相比于TCP更简单,传输效率更高
cookie/session
HTTP协议是无状态的
服务器不会记住之前的请求。所以为了跟踪用户的状态,比如用户是否登录,就需要用到Cookie和Session。
存储会话信息或状态信息,服务器可以识别和跟踪特定用户的状态,以提供一定程度的状态保持功能
用户第一次访问网站时,服务器会创建一个Session,并生成一个唯一的Session ID,然后把这个ID通过Cookie发送给客户端。之后,客户端每次请求都会带上这个Cookie,服务器通过Session ID找到对应的Session,从而识别用户。
session
保存在服务器端的用户状态信息。
-
创建Session:用户首次访问时,服务器生成唯一Session ID(如
abc123
)。 -
传递Session ID:通过Cookie(或URL重写:将Session ID附加到URL
http://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个) | 无硬性限制(受服务器资源影响) |
典型用途 | 用户偏好、跟踪标识 | 登录状态、敏感数据(如购物车) |
举个例子:
用户登录流程:
- 用户提交用户名和密码。
- 服务器验证通过,创建Session(存储用户ID、角色)。
- 生成Session ID,通过Cookie发送到浏览器。
- 浏览器后续请求携带该Cookie,服务器验证Session维持登录状态。
- 用户退出时,服务器销毁Session,清除客户端Cookie。
如果客户端禁用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<localStorage
Cookie 适合用于在客户端和服务器之间传递数据、跨域访问和设置过期时间,而 LocalStorage 适合用于在同一域名下的不同页面之间共享数据,存储大量数据和永久存储数据。
Token/JWT
用户登录成功后,服务器生成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的服务器,导致用户需要重新登录。
- 需要Session共享机制,比如使用数据库或Redis来集中存储Session,这样所有服务器都能访问同一个Session存储。
- JWT是自包含的令牌,服务器不需要存储会话信息,每个服务器实例都可以独立验证JWT的签名,不需要查询共享的Session存储。
jwt令牌泄露
- 失效令牌:当检测到令牌失效,将该令牌标记为失效,服务器会拒绝操作失效令牌
- 刷新令牌:主动刷新令牌,并将旧令牌标记为失效
- 使用黑名单:将泄露的令牌加入黑名单,服务器会拒绝操作在黑名单种的令牌
Nginx
Web服务器、反向代理服务器及电子邮件代理服务器
-
Web服务器
直接托管HTML、CSS、JS、图片等静态文件
通过协议将动态请求(如PHP、Python)转发给后端应用服务器。
-
反向代理服务器
将客户端请求分发到多个后端服务器(如Tomcat、Node.js)
支持轮询、加权轮询、IP哈希、最小连接数等。
nginx负载均衡算法
应用层的nginx用于将客户端请求合理地分发到后端服务器集群。
- 轮询:按服务器列表顺序依次分发请求,循环往复。
- IP哈希:根据客户端IP地址计算哈希值,固定将同一IP的请求分发到同一服务器。
- URL哈希:根据访问的URL计算哈希值,固定将同一IP的请求分发到同一服务器。
- 最短响应时间:按照后端服务器的响应时间来分配请求,响应时间短的优先分配(发送到响应时间快的服务器)。
- 加权轮询:根据服务器权重分配请求,权重越高处理的请求越多(适用于后端服务器性能不同的场景)。
结合小林Coding不断学习中,感谢大家的观看>W<
相关文章:

计算机网络-WebSocket/DNS/Cookie/Session/Token/Jwt/Nginx
文章目录 WebSocketDNS什么是dns域名解析底层协议 cookie/sessionToken/JWTNginx WebSocket 一种网络通信协议,允许在单个 TCP(半双工) 连接上进行全双工通信(客户端和服务器可同时双向传输数据)。 HTTP是基于请求-响…...
功能“递归模式”在 C# 7.3 中不可用,请使用 8.0 或更高的语言版本的一种兼容处理方案
原程序: internal class ControllerParameterCreator : IParameterCreator {private Controller controller;public ControllerParameterCreator(Controller controller){this.controller controller;}public Parameter CreateSystem(string name, int unused){re…...
第4章-操作系统知识
存储管理 固定分区:一种静态分区方式请求分页存储管理覆盖技术:覆盖技术是指让作业中不同时运行的程序模块共同使用同一主存区域。...

将网页带格式转化为PDF
# 一、安装插件 SingleFile | 将完整的页面保存到一个 HTML 文件中 – 下载 🦊 Firefox 扩展(zh-CN) 打开火狐浏览器,安装上面的插件 # 二、下载html单文件 打开对应的网页,点击插件下载对应的html文件 # 三、打开…...

【ArcGIS】ArcGIS AI 助手----复现
github地址 korporalK/Archer-GIS-AI-Assitant:Archer 在 ArcGIS Pro 中将自然语言命令转换为自动化 GIS 工作流。它使用代理框架(计划-验证-执行)构建并由 LLM 提供支持,可简化空间分析、减少手动工作并使 GIS 更易于访问。Arch…...
使用 FFmpeg 将视频转换为高质量 GIF(保留原始尺寸和帧率)
在制作教程动图、产品展示、前端 UI 演示等场景中,我们经常需要将视频转换为体积合适且清晰的 GIF 动图。本文将详细介绍如何使用 FFmpeg 工具将视频转为高质量 GIF,包括: ✅ 保留原视频尺寸或自定义缩放✅ 保留原始帧率或自定义帧率✅ 使用调色板优化色彩质量✅ 降低体积同…...
《Java vs Go vs C++ vs C:四门编程语言的深度对比》
引言 从底层硬件操作到云端分布式系统,Java、Go、C 和 C 四门语言各自占据不同生态位。本文从设计哲学、语法范式、性能特性、应用场景等维度进行对比,为开发者提供技术选型参考。 一、设计哲学与历史定位…...

充电枪IEC62196/EN 62196测试内容
充电枪IEC62196/EN 62196测试内容 一、机械性能测试 插拔力测试 交流充电接口的插入/拔出力需≤100N,直流接口≤140N。若使用助力装置,操作力仍需满足上述要求。 测试方法:通过弹簧秤或专用试验机(如Sun-CB设备)测…...
有效的字母异位符--LeetCode
题目 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的 字母异位词。 示例 1: 输入: s "anagram", t "nagaram" 输出: true示例 2: 输入: s "rat", t "car" 输出: false 思路一:排序 t 是 s …...

SAP ERP 系统拆分的七大挑战
在企业变革或管理运营风险时,剥离IT系统能带来显著效益,但SAP ERP系统的复杂性使得这项工作充满挑战。如果管理不当,可能会导致数据不一致、运营中断、合规风险和意外成本。由于SAP ERP系统深度集成于企业核心业务流程中,其拆分工…...

AcrelEMS 3.0智慧能源管理平台:构建企业微电网数智化中枢
安科瑞电气顾强 在"双碳"目标驱动下,企业能源管理正从粗放式运营向精细化、智能化转型。AcrelEMS 3.0智慧能源管理平台以微电网为核心载体,通过"感知-分析-决策-控制"的全链路数字化能力,助力工商企业、医疗机构、教育机…...
【HTML-12】HTML表格常用属性详解:从基础到高级应用
表格是HTML中最强大且常用的元素之一,它能够以结构化的方式展示数据。本文将全面介绍HTML表格的常用属性,帮助您创建美观、响应式且语义化的数据表格。 1. HTML表格基础结构 在深入了解属性之前,我们先回顾一下HTML表格的基本结构ÿ…...

Word转PDF--自动生成目录
1-Word文档中已经包含自动生成的目录; 2-选择“文件”; 3-另存为,PDF; 4-选择“选项”按钮,在弹出的窗口中,勾选“创建书签时使用标题”。...
MySQL组合索引优化策略
优化MySQL组合索引需要综合考虑查询模式、索引结构及数据库特性。以下是关键优化策略及示例: 1. 遵循最左前缀原则 策略:确保查询条件包含组合索引最左侧列。示例:索引(a,b,c)生效场景:WHERE a1 AND b2 -- ✔️ 使用a和b W…...
Spring MVC 的的核心原理与实践指南
一、Spring MVC 概述 Spring MVC 是 Spring 框架中的一个重要模块,用于构建基于 Java 的 Web 应用程序。它遵循模型-视图-控制器(MVC)设计模式,提供了一种结构化的方式来开发灵活、松耦合的 Web 应用。 Spring MVC 的特点…...

轻量级视觉语言模型 Dolphin:高效精准的文档结构化解析利器
在数字化办公和学术研究日益普及的今天,如何高效、准确地处理各类文档图像成为了一个亟需解决的问题。Dolphin 应运而生,作为一款基于异构锚点提示的多模态文档图像解析模型,它不仅打破了传统手动整理文档的繁琐流程,更以远超主流…...

如何安全配置数据库(MySQL/PostgreSQL/MongoDB)
数据库是许多应用程序的核心组成部分,因此保护数据库的安全性至关重要。无论是MySQL、PostgreSQL还是MongoDB,都需要经过适当的安全配置才能防止潜在的安全威胁。本文将介绍如何安全配置这些流行的数据库管理系统,以确保数据的保密性、完整性…...

将 Docker 镜像从服务器A迁移到服务器B的方法
在日常工作中,我们有时会需要将服务器 A上的镜像上传至服务器B上,下面给出具体操作方式,以镜像 postgres:15 为例进行讲解。 首先在服务器A上拉取 镜像 postgres:15 ,命令如下: docker pull postgres:15下面再将服务…...
git merge解冲突后,add、continue提交
git merge解冲突后,add、continue提交 git merge操作冲突后,需要手动解冲突,解完冲突后,需要: git add . 然后,进入一般的正常git代码提交流程。 git合并‘merge’其他分支的个别文件到当前branch_gitbash 合并branc…...
Lines of Thought in Large Language Models
Lines of Thought in Large Language Models 《Lines of Thought in Large Language Models》(大语言模型中的思维链)聚焦于分析大语言模型(LLMs)在生成文本时,其内部向量轨迹的统计特性。 核心目标是揭示LLMs复杂的“思维过程”(即文本生成时的隐藏状态变化)能否被简…...
八股战神-JVM知识速查
1.JVM组成 JVM由那些部分组成,运行流程是什么? JVM是Java程序的运行环境 组成部分: 类加载器:加载字节码文件到内存 运行时数据区:包括方法区,堆,栈,程序计数器,本地…...
机试 | STL | string | 文字处理软件
题目: P5734 【深基6.例6】文字处理软件 - 洛谷 不使用库函数 #include<stdio.h> #include <iostream> #include<string> using namespace std;int main() {int q;//第一行输入一个正整数q,表示操作次数string content;//第二行输入一…...

运动规划实战案例 | 图解基于状态晶格(State Lattice)的路径规划(附ROS C++/Python仿真)
目录 1 控制采样 vs 状态采样2 State Lattice路径规划2.1 算法流程2.2 Lattice运动基元生成2.3 几何代价函数2.4 运动学约束启发式 3 算法仿真3.1 ROS C仿真3.2 Python仿真 1 控制采样 vs 状态采样 控制采样的技术路线源自经典的运动学建模思想。这种方法将机器人的控制指令空…...
深入浅出对抗学习:概念、攻击、防御与代码实践
深入浅出对抗学习:概念、攻击、防御与代码实践 近年来,深度学习在图像识别、自然语言处理等领域取得了巨大成功。然而,研究表明,这些看似强大的模型却异常脆弱,容易受到**对抗样本(Adversarial Examples&a…...

Neo4j(二) - 使用Cypher操作Neo4j
文章目录 前言一、Cypher简介二、数据库操作1. 创建数据库2. 查看数据库3. 删除数据库4. 切换数据库 三、节点、关系及属性操作1. 创建节点与关系1.1 语法1.2 示例 2. 查询数据2.1 语法2.2 示例 3. 更新数据3.1 语法3.2 示例 4. 删除节点与关系4.1 语法4.2 示例 5. 合并数据5.1…...

09、供应商管理数字化转型:从潜在评估到战略合作的系统化方法
在全球化竞争和供应链日益复杂的商业环境下,供应商管理已成为企业核心竞争力的关键组成部分。优秀的供应商管理体系不仅能确保物料和服务的稳定供应,更能成为企业创新、降本增效的战略资源。本文将系统性地介绍供应商管理的完整框架,从潜在供…...
AI时代新词-AI增强现实(AI - Enhanced Reality)
一、什么是AI增强现实(AI - Enhanced Reality)? AI增强现实(AI - Enhanced Reality)是指将人工智能(AI)技术与增强现实(Augmented Reality,简称AR)技术相结合…...

批量转存夸克网盘内容并分享实操教程
批量转存夸克网盘内容并分享 经常使用我AI工具(圈友互联AI)的应该在每日资源这里看到,会每天自动更新最新资源信息,这些资源是自动从各处爬取出来再批量转存进行分享处理的! 今天就和大家分享下,如何对夸克…...
Swagger与go-zero框架生成和展示API文档详解
在现代API开发中,清晰、准确的接口文档是前后端协作的重要基础。作为一款功能强大的Go语言微服务框架,go-zero提供了简便的方式来生成Swagger文档,极大地提高了API开发的效率与质量。今天,我们将深入探讨Swagger的作用以及如何通过…...

“安康杯”安全生产知识竞赛活动流程方案
一、竞赛组织部门:排水公司安全生产办公室 二、竞赛说明: 1、由安全生产办公室组编辑、整理,安全生产领导小组审核。竞赛时由公司领导及各部门负责人对本次知识竞赛进行监督评比,以保证竞赛活动的公平、公正。本次竞赛活动由闫红…...