TLS/SSL 协议详解 (29) 国密SSL协议

TLS/SSL 协议详解 (29) 国密SSL协议测试服务器:https://47.89.249.43:4433/(测试时,先将本机时间设置为2018年7月之前(我证书过期了),然后使用360国密浏览器访问。360国密浏览器会在TLS握手失败后才会发起GMSSL握手,所以访问较慢。出现访问不了的情况,请清除360国密浏览器所有缓存,重启浏览器后再访问)源码在https://github.com/mrpre/atls上可以获得…

大家好,又见面了,我是你们的朋友全栈君。

测试服务器:https://www.mrpre.com:4433/  (已经过期,不要测试了)

(测试时,先将本机时间设置为2018年7月之前(我证书过期了),然后使用360国密浏览器访问。360国密浏览器会在TLS握手失败后才会发起GMSSL握手,所以访问较慢。出现访问不了的情况,请清除360国密浏览器所有缓存,重启浏览器后再访问)

源码在 https://github.com/mrpre/atls 上可以获得

GM/T 没有单独规范 SSL协议的文件,而是在SSL VPN技术规范中定义了国密SSL协议。

规范号:GM/T 0024-2014

TLS/SSL 协议详解 (29) 国密SSL协议

这里主要讲的是国密SSL协议和标准的TLS协议之间的区别,根据这些区别,完全可以实现国密SSL握手、通讯,实现效果见文末。

1:协议号

    TLS协议号为0x0301 0x0302 0x0303,分别表示TLS1.0 1.1 1.2

    而国密SSL版本号为0x0101,其参考了TLS1.1。

    故本篇没有描述的握手、加密细节等全部参考TLS 1.1,本篇只罗列GM SSL 与 标准 TLS 之间的区别。

Client hello报文如下:

TLS/SSL 协议详解 (29) 国密SSL协议

 Wireshark是无法解析的该报文的(不知道新版本是否能够解析),若想解析,还需要手动把pcap报文中version对应的字段修改成通用的0x03xx,wireshark方能解析。

故该规范定义的SSL协议被称为 国密SSL 1.1。具体参考规范6.3.2.1。

2:加密算法

国密SSL定义了多个加密套件,见6.4.4.1.1

TLS/SSL 协议详解 (29) 国密SSL协议

实际上,若加密各个阶段(非对称、对称、摘要)都替换成国密标准的,较主流的是如下2个

 1:ECC_SM4_SM3 

 2:ECDHE_SM4_SM3 

 IBC并没有研究过,这里不再详细说明。

注意 ,ECDHE_SM4_SM3 必须要求双向认证。

 ECC 对应的是标准的RSA,切勿被ECC迷惑,这个ECC并不和标准的椭圆曲线密钥交换算法类似,而是和RSA类似。服务器发送ECC公钥(在证书中)到客户端,客户端拿ECC公钥加密随机数给服务器(client key exchange)。

3:PRF算法

PRF算法和TLS 1.2类似,唯一区别:TLS1.2下,PRF算法为SHA256,而GM SSL的算法为SM3。

4:server key exhcnage

标准的server key exchange计算方式是

DH_sign(client_random + server_random + hash_in)

而国密SSL下server key exchange计算方式略有不同

Sm2_sign(lient_random + server_random +hash_len + hash_in)

国密规范如下描述 server key exchange:

Case ECC:

    Digitally-signed struct

    {

        Opaque client_random[32];

        Opaque server_random[32];

        Opaque ASN.1Cert<1, 2^24-1>;

    }

Case ECDHE:

    ServerECDHEParams params

    Digitally-signed struct

    {

        Opaque client_random[32];

        Opaque server_random[32];

        ServerECDHEParams params

    }

总结一下,

(1):

标准TLS server key exchange是椭圆曲线参数+对该报文的签名,签名时的hash是2个随机数加该报文本身。

(2):

国密SSL的ECC的server key exchange只是签名,由于本身不包含任何参数,故签名时的hash是2个随机数加上加密证书(注意国密规范描述证书时采用的尖括号的描述,即证书前需要加上长度信息表示)。具体签名算法使用的是sm2。

(3):

国密SSL的ECDHE证书和标准TLS就一样了,只是签名算法使用的是sm2。

Sm2签名需要一个ID,规范中建议为”1234567812345678”。实现上,都使用该值。

5:finished报文

标准TLS对finished使用标准的SHA1、SHA256、SHA384等进行hash运算,国密SSL中,hash运算为smx。Hash运算完成后,就使用上面描述的prf算法进行计算。

6:certificate报文

 国密规范定义发送证书时需要发送两个证书,签名证书和加密证书(双证书体系)。

与标准TLS报文格式一样,只是第一个证书是签名证书,第二个证书是加密证书。

我没有找到国密SSL规范定义怎么发送证书链的。

7:效果

使用360国密浏览器后,实现效果如下:

TLS/SSL 协议详解 (29) 国密SSL协议

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137062.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月2日 下午5:00
下一篇 2022年6月2日 下午5:00


相关推荐

  • implementation和api的区别

    implementation和api的区别关于 implementati 和 api 的区别 一共分为两个方面 一 编译范围关于这一部分 参考官网 说的很清楚 implementati Gradle 会将依赖项添加到编译类路径 并将依赖项打包到构建输出 不过 当您的模块配置 implementati 依赖项时 会让 Gradle 了解您不希望该模块在编译时将该依赖项泄露给其他模块 也就是说 其他模块只有在运行时才能

    2026年3月17日
    2
  • 最实用的高并发任务执行架构设计 | 架构篇

    最实用的高并发任务执行架构设计 | 架构篇目录前言高并发任务执行架构需求场景业务架构设计技术架构设计初始设计演化阶段一演化阶段二演化阶段三代码设计总结前言随着互联网与软件的发展,除了程序员,架构师也是越来越火的职业。他们伴随着项目的整个生命过程,他们更像是传统工业的设计师,将项目当做生命一般细心雕琢。目前对于项目架构而言,基本都会需要设计的几个架构。1、业务架构项目或者产品的市场定位、需求范围、作用场景都是需要在项目启动初期进行系统性分析的。在设计业务架构中,架构师还需要明

    2022年5月26日
    43
  • 基于 ThinkPHP5+Bootstrap 的后台开发框架 FastAdmin

    基于 ThinkPHP5+Bootstrap 的后台开发框架 FastAdmin

    2021年10月18日
    44
  • mysql databus_Databus架构分析与初步实践(for mysql)(上篇)

    mysql databus_Databus架构分析与初步实践(for mysql)(上篇)作者:徐和东description:目前关于databus的相关资料较少,特别是针对mysql的文档尤为稀少。本篇文章中介绍了databus相关组件及实现原理,初步实现了databus对mysql数据库的数据抓取,希望对后续使用者能提供一定的参考作用。categories:后端date:2017/5/24tags:DatabusForMysql低延迟数据抓取数据库日志挖掘1.简介…

    2022年10月16日
    8
  • skiplist 跳跃表详解及其编程实现

    skiplist 跳跃表详解及其编程实现skiplist 介绍跳表 skipList 是一种随机化的数据结构 基于并联的链表 实现简单 插入 删除 查找的复杂度均为 O logN 跳表的具体定义 请参考参考维基百科点我 中文版 跳表是由 WilliamPugh 发明的 这位确实是个大牛 搞出一些很不错的东西 简单说来跳表也是链表的一种 只不过它在链表的基础上增加了跳跃功能 正是这个跳跃的功能 使得在查找元素时 跳表能

    2026年3月26日
    2
  • js的timeout_定时器有哪三种类型

    js的timeout_定时器有哪三种类型js中两种定时器setTimeout和setInterval开发工具与关键技术:DW、Js作者:李宥良撰写时间:2019年1月17日定时器的用法非常之普遍,一般动态变化的效果都会用到定时器;定时器分为setTimeout和setInterval下面是方法和描述计时器类型:一、setTimeout(对象)setTimeout()计时器:在载入后延迟指定时间后,去执行一次表达式,仅执…

    2022年10月4日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号