锐英源软件
第一信赖

精通

英语

开源

擅长

开发

培训

胸怀四海 

第一信赖

当前位置:锐英源 / 开源技术 / C++开源心得 / 通过InitializeSecurityContext实现TLS握手

联系方式

固话:0371-63888850
手机:138-0381-0136
Q Q:396806883
微信:ryysoft

服务方向

人工智能数据处理
人工智能培训
kaldi数据准备
小语种语音识别
语音识别标注
语音识别系统
语音识别转文字
kaldi开发技术服务
软件开发
运动控制卡上位机
机械加工软件
软件开发培训
Java 安卓移动开发
VC++
C#软件
汇编和破解
驱动开发

通过InitializeSecurityContext实现TLS握手


TLS握手使用InitializeSecurityContext的一些流程

1、首次调用InitializeSecurityContext来获取一个指向SecBufferDesc的指针。

2、提供output缓冲调用send(和Windows API功能一样)。

3、调用recv函数

4、用缓冲再次调用InitializeSecurityContext

MSDN介绍这些缓冲的说明如下:

二次调用必须包含2个缓冲,第一个缓冲类型为SECBUFFER_TOKEN,包含服务器接收的token。第二个缓冲类型为SECBUFFER_EMPTY。pvBuffer和cbBuffer和成员为0.

问题

1、更多补充信息,比如缓冲的意义,第二个缓冲包含何信息,缓冲的目的是?

2、MSDN里说TargetDataRep输入参数不适用于Schannel,但在很多例子里设置它为SECURITY_NATIVE_DREP,那么SECURITY_NATIVE_DREP是什么标志?为什么MSDN说要把它设置为0?

回答

InitializeSecurityContext不只适用于Schannel包,还适用于其它场景。在其它场景里用了这个参数,你看到的例子里可能是用于其它场景的。

2类缓冲,一个是负荷数据,一个是安全数据,不要假定API会能通过句柄找到安全数据。所以每次调用都要传入安全数据。

友情链接
版权所有 Copyright(c)2004-2021 锐英源软件
公司注册号:410105000449586 豫ICP备08007559号 最佳分辨率 1024*768
地址:A、郑州市芯互联大厦北楼1803A(文化路优胜北路西北角),B、郑州大学北校区院内