openssl源码分析(二)

本文深入解析OpenSSL源码,详细介绍构造Server Hello和Server Key Exchange过程。内容涵盖版本信息、随机数、Session ID、加密套件、压缩方法的选择以及Server Key Exchange中的DH和EC算法。通过分析源码,揭示了握手过程中安全性保障的关键步骤,如哈希运算和密钥协商,为理解SSL/TLS协议提供了深入见解。
摘要由CSDN通过智能技术生成

构造Server Hello消息

int tls_construct_server_hello(SSL *s)

{

unsigned char *buf;

unsigned char *p, *d;

int i, sl;

int al = 0;

unsigned long l;

/*我们知道数据包包含了头部和数据两个部分,在构造的时候是分别构造的,一般的头部部分构造比较复杂,数据部分通常就是一个拷贝操作。这里的 ssl_handshake_start就是一个区分头部和数据部分的指针。# define ssl_handshake_start(s) (((unsigned char *)s->init_buf->data) + s->method->ssl3_enc->hhlen)*/

buf = (unsigned char *)s->init_buf->data;

d = p = ssl_handshake_start(s);

//拿到了头部的指针之后,就可以开始往里顺序的填充头部了。首先填充的是版本号

*(p++) = s->version >> 8;

*(p++) = s->version & 0xff;

/*

* 填充服务端产生的随机数

*/

memcpy(p, s

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HeathXian

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值