码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • TLS 协议研究


    文章目录

      • 协议定义
      • 抓包分析
        • ClientHello
        • ServerHello
        • Certificate
        • Server Key Exchange
        • Client Key ExChange
        • New Session Ticket
      • 证书
        • X.509
        • 证书链
          • 根认证机构的建立
          • 单级认证机构证书签署
          • 二级及以上认证机构的建立
          • 证书品牌
          • 系统内置信任证书
          • 申请Let's Encrypt 证书
      • 参考

    协议定义

    在这里插入图片描述
    由图可知, TLS协议从在TCP协议建立连接完成之后, 然后开始TLS握手协议;由图可知,TLS 握手阶段经历 ClientHello, ServerHello,Certificate, ServerHelloDone, ClientKeyExchange, ChangeCipherSpec阶段;
    在这里插入图片描述
    那么TLS 协议格式是什么样的?又是完成传输安全的目标的?
    在这里插入图片描述

    ContentType
    十六进制十进制含义
    0×1420ChangeCipherSpec
    0×1521Alert
    0×1622Handshake
    0×1723Application
    0×1824Heartbeat
    Version
    十六进制MajorMinor含义
    0x03000x030x00SSL 3.0
    0x03010x030x01TLS 1.0
    0x03020x030x02TLS 1.1
    0x03040x030x04TLS 1.3

    TLS 采用非对称加密和对称加密结合的方式保证传输安全, 它以非对称加密的方式产生对成加密的临时密钥
    在这里插入图片描述
    在这里插入图片描述

    TLS Handshake protocol MessageType
    十六进制十进制含义
    0x000HelloRequest
    0x011ClientHello
    0x022ServerHello
    0x044NewSessionTicket
    0x088EncryptedExtensions
    0x0b11Certificate
    0x0c12ServerKeyExchange
    0x0d13CertificateRequest
    0x0e14ServerHelloDone
    0x0f15CertificateVerify
    0x1016ClientKeyExchange
    0x1420Finished

    抓包分析

    在这里插入图片描述

    ClientHello

    在这里插入图片描述

    • Random: 客户端随机数
    • Cipher Suites: 供服务端选择的加密算法列表

    ServerHello

    在这里插入图片描述

    • Random: 服务端随机数
    • Cipher Suite: TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 (0xc02f)

    Certificate

    在这里插入图片描述

    Server Key Exchange

    在这里插入图片描述

    Client Key ExChange

    在这里插入图片描述

    New Session Ticket

    在这里插入图片描述

    证书

    X.509

    在这里插入图片描述
    X.509 是公钥基础设施(PKI)的标准格式。 X.509证书就是基于国际电信联盟(ITU)制定的X.509标准的数字证书。X.509证书主要用于识别互联网通信和计算机网络中的身份,保护数据传输安全。证书是个好东西,就是贵!!
    在这里插入图片描述

    证书链

    根认证机构的建立

    在这里插入图片描述

    单级认证机构证书签署

    在这里插入图片描述

    二级及以上认证机构的建立

    在这里插入图片描述
    由图可知,证书签署的流程是

    根证书 --> 二级证书--> 三级证书 --> ..... --> 服务器证书
    它是一条完整的链,称之为 "证书链"
    证书品牌

    在这里插入图片描述

    系统内置信任证书

    在这里插入图片描述

    申请Let’s Encrypt 证书
    // 通过DNS验证域名所有权,申请通配符证书
    certbot certonly --manual --preferred-challenges dns -d *.richard.pub -d richard.pub --server https://acme-v02.api.letsencrypt.org/directory     
    
    • 1
    • 2

    在这里插入图片描述在这里插入图片描述

    查看证书
    certbot certificates
    
    • 1

    在这里插入图片描述

    参考

    Transport Layer Security
    Wikipedia

  • 相关阅读:
    基于Java+vue前后端分离高校社团管理系统设计实现(源码+lw+部署文档+讲解等)
    爬虫爬取mp3文件例子
    英语语法强化
    R语言使用qcauchy函数生成柯西分布分位数函数数据、使用plot函数可视化柯西分布分位数函数数据(Cauchy distribution)
    oracle学习88-oracle之基本的过滤和排序数据
    CSDN里的常用网址(2)
    ASEMI整流桥SKBPC3516,SKBPC3516参数,SKBPC3516应用
    《Android Studio开发实战 从零基础到App上线(第3版)》出版后记
    js JSON.stringify 对象转字符串
    zip()并行迭代多个序列
  • 原文地址:https://blog.csdn.net/cugriver/article/details/126495775
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号