【发布时间】:2019-08-15 14:46:04
【问题描述】:
我目前正在尝试在 Windows 下用 C++ 实现一个肥皂客户端。由于一些技术要求,http和通信层已经使用Winhttp API实现。一切似乎都正常,但是一旦启用 TLS 1.1 或 1.2,软件就无法执行 SSL 握手。它只是不断地向服务器发送 TCP 连接数据包。
我进行了几次测试以了解发生了什么,到目前为止,这是我已经知道的:
该软件在 Windows 10 Pro 中按预期工作(无论选择哪个 TLS 版本)。当软件部署在 Windows 10 ltsb 2016 (1607) 中时,就不能这么说了。
按照here 的建议启用 TLS 支持不起作用。
winhttp代码可以在here找到。我只在第 351-352 行添加了这个修改:
DWORD dwOpt = WINHTTP_FLAG_SECURE_PROTOCOL_ALL | WINHTTP_FLAG_SECURE_PROTOCOL_TLS1_1 |WINHTTP_FLAG_SECURE_PROTOCOL_TLS1_2;
int res = WinHttpSetOption(pData->hInternet, WINHTTP_OPTION_SECURE_PROTOCOLS, &dwOpt, sizeof(dwOpt));
谢谢
【问题讨论】: