关于国密HTTPS 的那些事(二)
关于国密HTTPS 的那些事(二)
三. 需要解决的问题
前文我们了解了https,并梳理了国密https的流程。那么完成这些流程的目的是什么呢?又是怎么来保护数据的安全性呢?我们继续...
上文我们说到只有http通信的站点如同在“裸奔”,在客户端和服务端通信的时候有巨大的安全隐患。而安全隐患主要有三个方面:明文传输,数据篡改,站点劫持。
知道了问题,我们只需要对症下药:
明文传输 ->数据加密传输。
数据可篡改->数据完整性校验。
站点劫持->验证站点的身份。
还不够清楚,我们再深入一点,将上面的箭头继续往下衍生:
明文传输 ->数据加密传输- >需要一个只有客户端和服务端知道的对称秘钥(因为对称秘钥比非对称秘钥效率高)-->秘钥协商。
数据可篡改->数据完整性校验->对数据进行哈希计算并签名-->客户端和服务端采用同一种数据检验的算法。
站点劫持->验证站点的身份->客户端验证服务端提供的证书是否可信->证书由可信的CA机构颁发(如沃通CA等)。
差不多了,SSL/TLS协议的目的慢慢的就凸显出来了。知道了SSL/TLS的目的,我们再回过头看协议,理解起来就相对容易的多。
之前我们也说到了SSL/TLS协议都分为记录协议和握手协议,而他们目的就是服务客户端和服务端双方来来回回的进行数据通信。
先介绍他们的主要功能,如下:
记录层协议:将要发送的消息,把数据分块,压缩(可选),计算校验码HMAC,加密然后传输。接收到的数据经过解密、验证、解压缩重新封装然后传送给高层应用。
握手协议:主要用于客户端和服务端双方协商出供记录层使用的安全参数,进行身份验证以及向对方报告错误等。
接着我们来看SSL/TLS是如何达到自己的目的的,再此之前我们首先需要介绍另一个概念-- 加密套件 。
四.关于加密套件
如果将客户端和服务端比喻成“牛郎”和“织女”,那么加密套件就如同连接双方的“鹊桥”。
加密套件为什么如此重要呢?因为加密套件就定义了他们如何协商对称秘钥,采用哪种算法对数据进行校验以及签名,加密套件是双方建立连接的基础。
就是因为有了它,“牛郎”和“织女”才能顺顺利利的在七夕相遇。
我们看加密套件由那几部分组成,看下图。

除了协议部分,主要是由:秘钥交换和认证算法,加密算法 和摘要算法这四部分组成。
加密套件是协议里面约定的。每个加密套件都有一个ID号。比如0XC02C就是代表了上面的加密套件。
只有客户端和服务端有同样的加密套件(有交集),才能通过握手建立https通道。如客户端支持这个加密套件,服务端也支持这个加密套件,那么双方就可以选择双方都支持的这个加密套件进行握手。按加密套件中约定的算法进行数据加密,签名和交换。
我们在使用抓包工具的时候,就能看到在候客户端在Client_Hello里就携带了自己能支持的加密套件,为什么发送这么多呢?因为客户端也不知道服务端支持哪些加密套件,所以客户端先把自己支持的加密套件发送给服务端,让服务端根据自身的协议进行选择。在实际的应用中,如果客户端支持的加密套件很多,那么客户端会逐步的把所有支持的加密套件都发送给服务端,供服务端选择。此时客户端的独白是:“我已经尽力了,成不成就看缘分了”。服务端接收到客户端的加密套件后,如果正好有自己支持的加密套件--恭喜,配对成功(当然服务端也是有选择权的可以配置选择的优先级,当有遇到多个支持的加密套件时候优先选择一些安全性更高的加密套件)。如果客户端发送的加密套件服务端都不支持,那只能回复客户端,期待下一次的缘分了。所以,作为服务端,在保证安全的情况下,尽量支持多的套件和协议,这样才有更好的兼容性。
现在我们看到抓包工具中的一长串的加密套件,就不奇怪了。原来他们都是期待在茫茫人海中,被“选中”的一个,见下图。

好了,今天就聊这么多。下文我们接着揭露协议中握手双方的来来回回的背后,到底还隐藏了哪些不为人知的秘密!
关于国密HTTPS 的那些事(二)的更多相关文章
- 关于国密HTTPS 的那些事(一)
关于国密HTTPS 的那些事(一) 随着<密码法>密码法的颁布与实施,国密的应用及推广终于有法可依.而对于应用国密其中的一个重要组成部分----国密HTTPS通信也应运而生.为了大家更好的 ...
- Linux实现树莓派3B的国密SM9算法交叉编译——(二)miracl库的测试与静态库的生成
先参考这篇文章 Linux实现树莓派3B的国密SM9算法交叉编译——(一)环境部署.简单测试与eclipse工程项目测试 部署好环境,并简单测试交叉编译环境是否安装成功,最后实现在Eclipse上进行 ...
- Linux实现树莓派3B的国密SM9算法交叉编译——(三)国密SM9算法实现
先参考这篇文章 Linux实现树莓派3B的国密SM9算法交叉编译——(二)miracl库的测试与静态库的生成 进行miracl库的交叉编译测试,并生成miracl静态链接库. 这篇文章主要介绍基于mi ...
- C#.NET 国密SM3withSM2签名与验签 和JAVA互通
C# 基于.NET FRAMEWORK 4.5 JAVA 基于 JDK1.8 一.要点 1.签名算法:SM3withSM2. 2.签名值byte[] 转字符串时,双方要统一,这里是BASE64. 二. ...
- 谈谈PBOC3.0中使用的国密SM2算法
转载请注明出处 http://blog.csdn.net/pony_maggie/article/details/39780825 作者:小马 一 知识准备 SM2是国密局推出的一种他们自己说具有自主 ...
- 国产芯片任重道远 国科微SSD主控芯片的“追赶之路”(不能只提供一颗芯片,而是要将芯片、国密算法、固件Firmware、BIOS和操作系统紧密联系在一起,变成完整解决方案交给行业用户,才能真正体现自身的价值)
集微网消息,“中国芯”战略之路道阻且长,踏入这个赛道的攻坚者们需要十年如一日的技术突破,需要集合产业势能,共同协作,方能建立中国核心技术真正的竞争力. 国产化之路任重道远,SSD芯片初见成效 信息时代 ...
- bouncycastle 国密SM2 API的使用
摘要:本文不对SM2做过多的介绍,主要介绍java bouncycastle库关于SM2的相关API的使用及注意事项 1. SM2 签名: 注意: 1)签名格式ASN1(描述了一种对数据进行表示.编码 ...
- Hyperledger Fabric密码模块系列之BCCSP(五) - 国密算法实现
Talk is cheap, show me your code. 代码也看了,蛋也扯了,之后总该做点什么.响应国家政策,把我们的国密算法融合进去吧-- 先附两张bccsp下国密算法的设计实现图. ...
- Bytom国密网说明和指南
比原项目仓库: Github地址:https://github.com/Bytom/bytom Gitee地址:https://gitee.com/BytomBlockchain/bytom 国密算法 ...
随机推荐
- 在已有Win7/10系统电脑中加装Ubuntu18.04(安装双系统)
准备一台有Win7/10的电脑. 为Ubuntu预留硬盘空间.最好在硬盘最后保留一个空闲分区.(Ubuntu会自动安装到后面的空闲分区) 用Universal USB Installer制作安装盘(U ...
- js调试之firbug
说下几种方法吧: 1.用alert 这个最最直观 把你想要的内容弹出来给你看,但是要看哪里 就要在哪里加,比较麻烦 2.用firefox 或者chrome浏览器 里面有debug工具的 3.如果想用i ...
- client-go实战之一:准备工作
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- Springboot 整合通用mapper和pagehelper展示分页数据(附github源码)
简介 springboot 设计目的就是为了加速开发,减少xml的配置.如果你不想写配置文件只需要在配置文件添加相对应的配置就能快速的启动的程序. 通用mapp 通用mapper只支持对单表的操作,对 ...
- 使用Keepalived实现Nginx的自动重启及双主热备高可用
1.概述 之前我们使用Keepalived实现了Nginx服务的双机主备高可用,但是有几个问题没有解决,今天一起探讨一下. 1)在双机主备机制中,Keepalived服务如果宕了,会自动启用备机进行服 ...
- Django分页组件——Paginator
from django.core.paginator import Paginator #导入Paginator objects = ['john','paul','george','ringo',' ...
- NRF52832空中升级DFU
Secure DFU环境搭建 升级原理,加密原理在此不做描述,详情参考http://www.cnblogs.com/iini/p/9314246.html 1.工具一览 gcc-arm-none-ea ...
- Spring-图解
- LeetCode通关:连刷十四题,回溯算法完全攻略
刷题路线:https://github.com/youngyangyang04/leetcode-master 大家好,我是被算法题虐到泪流满面的老三,只能靠发发文章给自己打气! 这一节,我们来看看回 ...
- golang接口类型判断 VS 接口类型查询
接口类型判断:接口.(类型) 1.类型查询:查询接口数据对应的类型是否是指定的类型 2.类型转化:如果是指定类型,就将数据转化为接口类型查询: 1.reflect.TypeOf(接口) 2.接口.(T ...