计算机网络-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
  • 二级域:用户注册的域名部分(如exampleexample.com中)。
  • 子域:进一步细分(如mail.example.com)。
域名解析

各服务器负责部分(举例:

根DNS(.)

顶级DNS(.com)

权威DNS(example.com)

  1. 用户输入域名www.example.com,发给本地 DNS 服务器
  2. 本地域名服务器收到请求,如果缓存里有则直接返回,无则请求其根域名服务器
  3. 根域名服务器收到请求(发现是.com),将请求发送给顶级域名服务器
  4. 顶级域名服务器收到请求(发现是www.example.com),将请求发送给权威域名服务器
  5. 权威域名服务器查询后将对应的 IP 地址 X.X.X.X 告诉本地 DNS。
  6. 本地 DNS 再将 IP 地址返回客户端,客户端和目标建立连接。

在这里插入图片描述

底层协议

DNS 基于UDP协议实现。

  • 无连接:UDP 不需要建立连接,直接发送请求,减少了通信延迟。
  • 轻量级:DNS 查询和响应通常是小数据包,一个UDP包就能容纳
  • 简单快速: UDP相比于TCP更简单,传输效率更高
cookie/session

HTTP协议是无状态的

服务器不会记住之前的请求。所以为了跟踪用户的状态,比如用户是否登录,就需要用到Cookie和Session。

存储会话信息或状态信息,服务器可以识别和跟踪特定用户的状态,以提供一定程度的状态保持功能

用户第一次访问网站时,服务器会创建一个Session,并生成一个唯一的Session ID,然后把这个ID通过Cookie发送给客户端。之后,客户端每次请求都会带上这个Cookie,服务器通过Session ID找到对应的Session,从而识别用户。

session

保存在服务器端的用户状态信息。

  1. 创建Session:用户首次访问时,服务器生成唯一Session ID(如abc123)。

  2. 传递Session ID:通过Cookie(或URL重写:将Session ID附加到URLhttp://site.com?sid=abc123)发送给客户端。

  3. 客户端携带Session ID:后续请求包含Session ID。

  4. 服务器检索Session:根据Session ID查找服务器存储的会话数据。

cookie

保存在客户端(比如浏览器)的小型数据片段。

  1. 服务器生成:服务器通过HTTP响应头Set-Cookie发送Cookie到浏览器。

  2. 浏览器存储:浏览器保存Cookie,后续请求自动通过Cookie请求头发送回服务器。

  3. 服务器读取:服务器解析Cookie内容,识别用户状态。

    HTTP/1.1 200 OK
    Set-Cookie: session_id=abc123; Expires=Wed, 21 Oct 2023 07:28:00 GMT; Secure; HttpOnly; SameSite=Lax
    
特性CookieSession
存储位置客户端(浏览器)服务器端
数据类型文本(键值对)任意结构(对象、数组等)
安全性较低(可能被篡改或窃取)较高(数据在服务器,仅传递Session ID)
容量限制每个域名≤4KB,总数有限(约50个)无硬性限制(受服务器资源影响)
典型用途用户偏好、跟踪标识登录状态、敏感数据(如购物车)

举个例子:

用户登录流程:

  1. 用户提交用户名和密码。
  2. 服务器验证通过,创建Session(存储用户ID、角色)。
  3. 生成Session ID,通过Cookie发送到浏览器。
  4. 浏览器后续请求携带该Cookie,服务器验证Session维持登录状态。
  5. 用户退出时,服务器销毁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
  1. 头部Header

    说明Token类型及签名算法

    {"alg": "HS256","typ": "JWT"
    }
    
  2. 载荷Payload

    包含用户数据

    {"sub": "1234567890","name": "John Doe","admin": true,"iat": 1516239022
    }
    
  3. 签名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用于将客户端请求合理地分发到后端服务器集群。

  1. 轮询:按服务器列表顺序依次分发请求,循环往复。
  2. IP哈希:根据客户端IP地址计算哈希值,固定将同一IP的请求分发到同一服务器。
  3. URL哈希:根据访问的URL计算哈希值,固定将同一IP的请求分发到同一服务器。
  4. 最短响应时间:按照后端服务器的响应时间来分配请求,响应时间短的优先分配(发送到响应时间快的服务器)。
  5. 加权轮询:根据服务器权重分配请求,权重越高处理的请求越多(适用于后端服务器性能不同的场景)。

在这里插入图片描述
结合小林Coding不断学习中,感谢大家的观看>W<

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/news/907140.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

单片机如何快速实现查看实时数据

在用 Keil 做调试的时候&#xff0c;最让人头秃的是什么&#xff1f; 不是写代码的BUG&#xff0c;而是&#xff1a;这个条件变量是什么情况&#xff1f;为什么没进入这个判断&#xff1f;我代码跑到哪里了&#xff1f; 其实本质上都是通过变量判断代码的执行顺序有没有问题 …

vue3:横线无限滚动(向左/向右),自定义UI

子组件 <template><div class"single-scroll-container" ref"container" mouseenter"pause" mouseleave"resume"><divclass"single-scroll-content":style"{ transform: translateX(${translateX}px) }…

Anthropic公司近日发布了两款新一代大型语言模型Claude Opus 4与Claude Sonnet 4

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

【机器人】复现 Embodied-Reasoner 具身推理 | 具身任务 深度推理模型 多模态场景 长远决策 多轮互动

Embodied-Reasoner 是一个多模态具身模型&#xff0c;它将 o1 的深度推理能力扩展到具身交互任务。 可以在 AI2THOR 仿真中执行复杂的任务&#xff0c;例如搜索隐藏物体、操纵 和 运输物品 具有以下的功能&#xff1a; &#x1f914; 深度推理能力&#xff0c;例如分析、空间…

使用 Qemu 调试 LoongArch 应用程序

1.编译 Qemu OS:Ubuntu 22.04 下载Qemu源码 git clone --depth1 https://gitlab.com/qemu-project/qemu.git编译 cd qemu mkdir build cd build ../configure --target-listloongarch64-linux-user,loongarch64-softmmu --prefixpwd/__install make && make instal…

Unity 游戏优化(持续更新中...)

垃圾回收 是什么&#xff1f; 垃圾回收&#xff08;Garbage Collection&#xff09;GC 工作机制 1、Unity 为用户生成的代码和脚本采用了自动内存管理。 2、小块数据&#xff08;如值类型的局部变量&#xff09;分配在栈上。大块数据和长期存储分配在托管堆上。 3、垃圾收集…

python和java差异:关键数据类型与容器

2.0. 对象的类型&#xff1a;可变 (Mutable) 与不可变 (Immutable) 在Python中&#xff0c;理解对象的可变性 (mutability) 是至关重要的&#xff0c;它影响着变量如何被修改、函数参数如何传递以及数据结构的行为。 不可变对象 (Immutable Objects): 大白话定义&#xff1a;…

DAY 33

知识点回顾&#xff1a; 1. PyTorch和cuda的安装 2. 查看显卡信息的命令行命令&#xff08;cmd中使用&#xff09; 3. cuda的检查 4. 简单神经网络的流程 a. 数据预处理&#xff08;归一化、转换成张量&#xff09; b. 模型的定义 i. 继承nn.Module类 ii. 定义…

Minktec 柔性弯曲传感器,灵敏捕捉坐姿弓背、精准监测行走姿态,守护儿童背部健康,为科学健身提供数据支撑,开启职业健康与背痛 AI 干预新方向。

Minktec弯曲形变传感器通过创新的技术设计&#xff0c;为各种弯曲和形变检测需求提供了精确的解决方案。其核心技术基于薄膜柔性传感器的应用&#xff0c;能够捕捉物体在三维空间中的动态变化。传感器内部结合了多点排列的应变元件和专有算法&#xff0c;实现了形状的实时重建。…

快递鸟接口费用解析:中小电商成本控制方案

中小电商企业在物流环节的成本控制&#xff0c;直接影响着整体运营效率和利润空间。作为国内主流的物流数据服务商&#xff0c;快递鸟API接口凭借其聚合查询、电子面单、轨迹跟踪等功能&#xff0c;成为众多电商企业的选择。但如何精准解析其收费模式&#xff0c;并制定科学的成…

maven 最短路径依赖优先

问题描述&#xff1a; 项目在升级大版本后出现了&#xff0c;两个不同模块所引用的同一个依赖包版本不同 module A 引用了 module B&#xff0c;module B 引用了 A_1.0.jar->B_1.0.jar->C_1.0.jar(C 为B 里面的包) 在执行 mvn dependency:tree 后发现&#xff1a; modul…

游戏引擎学习第314天:将精灵拆分成多个层

回顾并为今天的工作做准备 我们今天继续昨天开始的工作&#xff0c;现在我们要回到渲染中处理 Z 值的最终环节。我们目前已经有一个我们认为还算合理的排序方式&#xff0c;虽然可能还需要在接下来的过程中进行一些调整&#xff0c;但总体上已经有了一个明确的方向。 我们已经…

HashSet的基本概念

ashSet的基本概念 - HashSet 是C#中用于存储唯一元素的泛型集合类&#xff0c;它基于哈希表实现&#xff0c;具有快速查找、添加和删除元素的特性。 - 核心特点&#xff1a; - 不允许存储重复元素 - 元素无序排列 - 查找、添加、删除操作的平均时间复杂度为O(1) - 实现了 IEnum…

信号与系统10-综合案例:智能信号处理系统

第7课&#xff1a;综合案例——智能信号处理系统 1. 案例1&#xff1a;基于傅里叶变换与AI的语音信号分类系统 1.1 理论基础 傅里叶变换是信号处理的核心工具之一&#xff0c;能够将时域信号转换为频域表示&#xff08;如频谱图&#xff09;。语音信号的频域特征&#xff08…

详解Kubernetes Scheduler 的调度策略

详解Kubernetes Scheduler 的调度策略 在 Kubernetes(K8s)中,Scheduler(调度器) 负责 决定 Pod 应该运行在哪个 Node(节点)。 👉 调度器的目标是什么? ✅ 最大化资源利用率(让 CPU、内存等资源不浪费) ✅ 保证 Pod 运行在合适的 Node 上(避免超载、满足亲和性)…

在 ElementUI 中实现 Table 单元格合并

在 ElementUI 中实现 Table 单元格合并 在使用 ElementUI 的 Table 组件时&#xff0c;有时我们需要合并相邻的单元格&#xff0c;以提高表格的可读性和简洁性。下面是一个关于如何在 Table 中根据特定字段合并单元格的实现方法。 逻辑分析 spanMethod 方法&#xff1a;这是 …

小土堆pytorch--现有网络模型的使用及修改

现有网络模型的使用及修改 一级目录二级目录三级目录 现有网络模型的使用及修改1.VGG16模型VGG16网络模型简介**核心特点****网络结构细节****优缺点与应用****变种与后续发展** 2. 使用vgg16模型 一级目录 二级目录 三级目录 现有网络模型的使用及修改 1.VGG16模型 VGG16…

Oracle 正则表达式匹配(Oracle 11g)

1、连续2词汉字重复或3词汉字重复&#xff08;不会忽略符号&#xff09; ([^ \u4e00-\u9fa5\S]{2,3})\1 例如&#xff1a;阿富、 SELECT REGEXP_replace(阿富、阿富、 阿富汗、 , ([^ \u4e00-\u9fa5\S]{2,3})\1, 重复) FROM dual结果&#xff1a; 2、连续2词汉字重复或3词…

对话魔数智擎CEO柴磊:昇腾AI赋能,大小模型融合开启金融风控新范式

导读&#xff1a;#昇腾逐梦人# AI已经成为金融机构核心竞争力的关键要素。专注AI金融赛道的魔数智擎&#xff0c;通过大小模型融合&#xff0c;让AI成为银行的“金融风控专家”。 作者 | 小葳 图片来源 | 摄图 在AI涌向产业的时代赛跑中&#xff0c;开发者是绝对的主角。 昇腾…

IDEA使用Git进行commit提交到本地git空间后撤回到commit版本之前

一、前言 Git作为最流行和最全面的版本控制工具&#xff0c;非常好用&#xff0c;但是操作也会比SVN复杂一些。毕竟有得有失嘛&#xff0c;所以我选择Git&#xff0c;最近在工作中&#xff0c;一不小心吧一些无关紧要的文件commit了。还好在Push之前看到&#xff0c;不过就算P…