首页 > 解决方案 > nghttp2 api.binance.com ssl 错误

问题描述

我想使用 http/2 为 binance.com 的 api 编写一个客户端。为此,我正在尝试库 nghttp2,我在他们的示例代码中对 api 进行了测试调用:

int main(int argc, char *argv[]) {
  boost::system::error_code ec;
  boost::asio::io_service io_service;

  boost::asio::ssl::context tls(boost::asio::ssl::context::sslv23);
  tls.set_default_verify_paths();
  // disabled to make development easier...
  // tls.set_verify_mode(boost::asio::ssl::verify_peer);
  configure_tls_context(ec, tls);

  session sess(io_service, tls, "api.binance.com", "443");

[...]

    auto req = sess.submit(ec, "GET", "https://api.binance.com/api/v1/ping");

[...]

然而,它总是在错误处理程序中告诉我

sslv3 警报握手失败

我不知道如何调试这个。我什至可以做些什么来理解为什么这不起作用?我试图将 tls 上下文创建的打开更改为其他内容,例如 tlsv12,但没有任何效果。如果它真的在尝试使用 sslv3,那么它不起作用也就不足为奇了,因为 api.binance.com 的 ssl 测试报告不支持 sslv3。对 nghttp2.org 本身进行测试我没有收到此错误。SSL 协商的某些地方出了问题。但我怎么能看到在哪里?

标签: ssltls1.2http2nghttp2

解决方案


此问题已修复:https ://github.com/nghttp2/nghttp2/pull/1173 。

所以如果你赶时间不想等待 nghttp2 1.32 发布,你可以查看 master 分支。我确实从源代码构建了 nghttp,所以我可以说这需要时间,但构建起来很简单。


推荐阅读