C++ boost::asio https 通过代理

C++ boost::asio https through proxy

所以我有这段代码可以很好地使用 boost::asio 与 ssl 连接:

打开了 Fiddler,但我根本看不到这些连接。 从我读到的内容来看,我收集到我必须通过代理传递请求。 所以我尝试了所有我能找到的例子和答案,但我无法让它发挥作用。

我得到的最好的结果是握手从未触发回调。

我错过了什么?

void performHTTPRequest(std::string host, std::string path) {
    std::ostream request_stream(&mRequest);
    request_stream << "GET " << path << " HTTP/1.1\r\n";
    request_stream << "Host: " << host << "\r\n";
    request_stream << "Accept: */*\r\n";
    request_stream << "Connection: close\r\n\r\n";
    tcp::resolver::query query(host, "https");
    mResolver.async_resolve(query,
        boost::bind(handle_resolve,
        this,
        boost::asio::placeholders::error,
        boost::asio::placeholders::iterator));
}

void handle_resolve(const boost::system::error_code& err,
        tcp::resolver::iterator endpoint_iterator)
{
    if (!err)
    {
        boost::asio::async_connect(mSocket.lowest_layer(), 
            endpoint_iterator,
            boost::bind(&handle_connect, this,
            boost::asio::placeholders::error));
    }
    else
    {
        delete this;
    }
}

void handle_connect(const boost::system::error_code& err)
{
    if (!err)
    {
        mSocket.async_handshake(
            boost::asio::ssl::stream_base::handshake_type::client,
            boost::bind(&handle_handshake, this,
            boost::asio::placeholders::error));
    }
    else
    {
        delete this;
    }
}


void handle_handshake(const boost::system::error_code& err)
{
    if (!err)
    {
        boost::asio::async_write(mSocket, mRequest,
            boost::bind(&handle_write_request, this,
            boost::asio::placeholders::error));
    }
    else
    {
        delete this;
    }
}

void handle_write_request(const boost::system::error_code& err)
{
    if (!err)
    {
        boost::asio::async_read_until(mSocket, mResponse, "\r\n",
            boost::bind(&handle_read_status_line, this,
            boost::asio::placeholders::error));
    }
    else
    {
        delete this;
    }
}

void handle_read_status_line(const boost::system::error_code& err)
{
    if (!err)
    {
        std::istream response_stream(&mResponse);
        std::string http_version;
        response_stream >> http_version;
        unsigned int status_code;
        response_stream >> status_code;
        std::string status_message;
        std::getline(response_stream, status_message);
        if (!response_stream || http_version.substr(0, 5) != "HTTP/")
        {
            return;
        }
        if (status_code != 200)
        {
            return;
        }
    }
    else
    {
        delete this;
    }
}

看来只需更改此行:

tcp::resolver::query query(host, "https");

有了这个:

tcp::resolver::query query(proxyUrl, proxyPort);

成功了。

问题出在不允许 HTTPS 通信的代理配置上。