zoukankan      html  css  js  c++  java
  • golang https server分析

    https:

    HTTPS是http安全版本的实现,在http与tcp之间加了一层ssl/tls安全传输协议

    为了防止请求被监听、篡改、冒充,在tls实现过程中引入了数字证书机制,数字证书由第三方权威机构提供保证。

    数字证书原理是采用非对称加密生成一对公钥、私钥,服务端保存私钥,下发公钥给客户端,由于非对称加密计算量比较大,

    所以https通信过程中,通过客户端与服务端的握手交互产生三次随机码,从而生成一个相对安全的对称加密密码,密码通过非对称加密下发给客户端,从而完成加密通信

    https本质上还是tcp通信,所以https的捂手是在建立tcp连接后,进行的一系列校验而已,

    在处理tcp conn连接的过程中,会判断连接类型是不是tls类型,如果是会进入tlsConn.serverHandshake()握手过程。详细流程如下:

    下面分析一下golang中如何实现的https握手

    在建立tlsConn连接后,服务端新起一个goroutine处理,

    1. config.serverInitOnce.Do(config.serverInit) // 产生一个随机数作为通信凭证,下次通信时凭证校验通过后直接通信,校验不通过重新建立连接
    2. msg, err := c.readHandshake() // 解析clientHello信息,此时获取到由客户端生成的第一个随机数

    3. c.vers, ok = config.mutualVersion(hs.clientHello.vers) // 检查客户端与服务端tls版本是否一致

    4. _, err = io.ReadFull(config.rand(), hs.hello.random) // 服务端产生第二个随机数
    5. hs.setCipherSuite(id, supportedList, c.vers) // 确认加密算法
    6. 设置服务器证书

    hs.cert, err = config.getCertificate(&ClientHelloInfo{
    CipherSuites: hs.clientHello.cipherSuites,
    ServerName: hs.clientHello.serverName,
    SupportedCurves: hs.clientHello.supportedCurves,
    SupportedPoints: hs.clientHello.supportedPoints,
    });

    7. skx, err := keyAgreement.generateServerKeyExchange(config, hs.cert, hs.clientHello, hs.hello) // 生成服务端摘要信息
    8. c.writeRecord(recordTypeHandshake, helloDone.marshal()) //发送helloDone信息
    9. preMasterSecret, err := keyAgreement.processClientKeyExchange(config, hs.cert, ckx, c.vers) // 处理获取由客户端生成的第三个随机数
    10. hs.masterSecret = masterFromPreMasterSecret(c.vers, hs.suite, preMasterSecret, hs.clientHello.random, hs.hello.random) // 生成通信秘钥
    11. hs.finishedHash.Write() // 服务端发送最后一次确认请求

  • 相关阅读:
    阿里云mysql远程连不上
    php-fpm的pool php-fpm慢执行日志 open_basedir php-fpm进程管理
    重置mysql密码
    树莓派挂载ntfs优盘
    Nginx安装 默认虚拟主机 Nginx用户认证 Nginx域名重定向
    配置防盗链 访问控制Directory 访问控制FilesMatch
    dash视频服务器本地搭建 (初探)
    npm vue ivew vue-cli3
    一维数组转树形结构
    nginx Access-Control-Allow-Origin 多域名跨域设置
  • 原文地址:https://www.cnblogs.com/zongjiang/p/6619202.html
Copyright © 2011-2022 走看看