当前位置: 首页 > news >正文

HTTPS和TCP

  1. tcp的三次握手四次挥手机制
    1. TCP建立连接的过程:
      1. 第一次握手(客户端发送syn包到服务器):客户端发送syn包到服务器端,进入syn_send状态,等待服务器端确认
      2. 第二次握手(服务器返回syn+ack包给客户端):服务器端收到客户端的syn包,发送syn+ack包给客户端,进入syn_recv状态
      3. 第三次握手(客户端返回ack包给服务端):客户端收到服务器端的syn+ack包,发送个ack包到服务端,至此,客户端和服务端进入established状态
      4. 握手过程中传送的包不含任何数据,连接建立后才会开始传送数据,理想状态下,TCP连接一旦建立,在通信双方的任何一方主动关闭连接前,TCP连接都会一直保持下去
    2. TCP断开连接的过程:
      1. 第一次挥手:主动关闭方发送fin包到被动关闭方,告诉被动关闭方我不会再给你发送数据了
      2. 第二次挥手:被动关闭方收到syn包,发送ack给对方,确认序号为收到序号+1
      3. 第三次挥手:被动关闭方也发送fin包给主动关闭方,告诉对方我也不会给你发送数据了
      4. 第四次挥手:主动关闭方收到syn包,发送ack给对方,至此,完成四次挥手
  2. Https原理:
    1. HTTPS协议就是基于SSL的HTTP协议
    2. HTTPS使用与HTTP不同的端口(HTTP:80,HTTPS:443)
    3. 提供了身份验证与加密通信方法,被广泛用于互联网上安全敏感的通信
      1. 客户端发送请求https连接服务端
      2. 服务端返回证书(公钥)给客户端
      3. 客户端使用公钥对称密钥加密
      4. 客户端发送给服务端加密后的对称密钥
      5. 客户端发给服务端通过对称加密的密文通信
    4. 步骤详解:
      1. 客户端请求SSL连接,并将自己支持的加密规则发给网站
      2. 服务端将自己的身份信息以证书形式发回给客户端,证书里面包含了网站地址,加密公钥,以及证书的颁发机构
      3. 获得证书后,客户端要做一下工作:
        1. 验证证书合法性
        2. 如果证书受信任,客户端会生成一串随机数的密码,并用证书提供的公钥进行加密
        3. 将加密好的随机数发给服务端
      4. 获得到客户端发的加密了的随机数之后,服务端用自己的私钥进行解密,得到这个随机数,把这个随机数做为对称加密的密钥,(利用非对称加密传输对称加密的密钥)
      5. 之后服务端与客户端之间就可以用随机数对各自的信息进行加密,解密,
      6. 注意的是:证书是一个公钥,这个公钥是进行加密用的,而私钥是进行解密用的,公钥任何人都知道,私钥只有自己知道,这是非对称加密
      7. 而对称加密就是钥匙只有一把,我们都知道
      8. 之所以用到对称加密,是因为对称加密的速度更快,而非对称加密的可靠性更高
    5. 客户端请求->服务端发送证书(公钥)->客户端验证证书,并生成随机数,通过公钥加密后发送给服务端—>服务端用私钥解密出随机数–>对称加密传输数据

相关文章:

  • C++ 数据共享与保护学习记录【代码】
  • Unity 编辑器扩展 一键替换指定物体下的所有材质球
  • Android14 WMS-窗口绘制之relayoutWindow流程(一)-Client端
  • Java学习-JDBC(一)
  • 【数据结构】图论入门
  • 开发常用软件
  • PDF编辑与转换的终极工具智能PDF处理Acrobat Pro DC
  • Day14:响应式网页
  • java 原生http服务器 测试JS前端ajax访问实现跨域传post数据
  • 【Python爬虫单点登录实战】PyExecJS破解慧职教:过河源技术学院单点登录统一身份认证
  • 电脑开机出现英文字母,如何解决这个常见问题?
  • MAVEN:自定义模板Archetype的创建
  • 【java】速度搭建一个springboot项目
  • 计算机网络--应用层
  • BF16相比FP16的优点
  • 【跃迁之路】【519天】程序员高效学习方法论探索系列(实验阶段276-2018.07.09)...
  • Android单元测试 - 几个重要问题
  • Apache的80端口被占用以及访问时报错403
  • Intervention/image 图片处理扩展包的安装和使用
  • iOS筛选菜单、分段选择器、导航栏、悬浮窗、转场动画、启动视频等源码
  • nginx 负载服务器优化
  • Python十分钟制作属于你自己的个性logo
  • Service Worker
  • Spark学习笔记之相关记录
  • Spring思维导图,让Spring不再难懂(mvc篇)
  • Vue 2.3、2.4 知识点小结
  • 从地狱到天堂,Node 回调向 async/await 转变
  • 关于 Cirru Editor 存储格式
  • ------- 计算机网络基础
  • 数据库写操作弃用“SELECT ... FOR UPDATE”解决方案
  • 算法-插入排序
  • 携程小程序初体验
  • 如何用纯 CSS 创作一个货车 loader
  • # 20155222 2016-2017-2 《Java程序设计》第5周学习总结
  • # 详解 JS 中的事件循环、宏/微任务、Primise对象、定时器函数,以及其在工作中的应用和注意事项
  • $.ajax()方法详解
  • $GOPATH/go.mod exists but should not goland
  • ()、[]、{}、(())、[[]]命令替换
  • (007)XHTML文档之标题——h1~h6
  • (39)STM32——FLASH闪存
  • (6)设计一个TimeMap
  • (ZT)出版业改革:该死的死,该生的生
  • (动态规划)5. 最长回文子串 java解决
  • (非本人原创)我们工作到底是为了什么?​——HP大中华区总裁孙振耀退休感言(r4笔记第60天)...
  • (附源码)springboot猪场管理系统 毕业设计 160901
  • (附源码)计算机毕业设计SSM在线影视购票系统
  • (蓝桥杯每日一题)平方末尾及补充(常用的字符串函数功能)
  • (四)库存超卖案例实战——优化redis分布式锁
  • (四)七种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
  • (转)负载均衡,回话保持,cookie
  • (最全解法)输入一个整数,输出该数二进制表示中1的个数。
  • .equal()和==的区别 怎样判断字符串为空问题: Illegal invoke-super to void nio.file.AccessDeniedException
  • .NET CORE 3.1 集成JWT鉴权和授权2
  • .NET delegate 委托 、 Event 事件
  • .net mvc actionresult 返回字符串_.NET架构师知识普及