使用c ++ QNetworkRequest获取HTTPS站点内容

时间:2015-12-21 11:35:05

标签: c++ qt ssl https qnetworkrequest

我试图在VS2010 c ++环境中使用Qt框架(QNetworkRequest)获取站点(json字符串)的内容。我从HTTP站点读取数据没有问题,但是当我尝试读取HTTPS站点的内容时,我没有运气。另一方面,浏览器可以看到"网站内容。我认为这是证书问题,但我不完全确定。我只能从firefox访问ca.pem(我导出)。我为cert.pem和key.pem使用了伪pem文件,这样我就不会留空。不幸的是,我不能以另一种方式获得这些文件。

我收到错误99代码,其中包含描述"私钥不认证公钥,错误:140A80B1:SSL例程:SSL_CTX_check_private_key:未分配证书"。所以它应该是虚拟密钥证书的错误。

然而,我不禁想知道浏览器怎么可能"看到"内容和通过代码,我不能?是否有可能找到一个解决方法?

我的代码如下:

{
    QNetworkAccessManager *manager = new QNetworkAccessManager();
    QNetworkRequest request;
    QNetworkReply *reply = NULL;

    QSslConfiguration config = QSslConfiguration::defaultConfiguration();   
    config.setProtocol(QSsl::AnyProtocol);  
    request.setSslConfiguration(config);
    request.setUrl(QUrl("https://...."));
    addSSl(&request);
    request.setHeader(QNetworkRequest::ServerHeader, "application/json");

    reply = manager->get(request);  

    QObject::connect(manager, SIGNAL(finished(QNetworkReply*)), this,   SLOT(replyFinished(QNetworkReply*)));
}

void addSSL(QNetworkRequest *request)
{   
    QString cacert_path="../certificates/cacert.pem";
    QString cert_path="../certificates/cert.pem";
    QString key_path="../certificates/key.pem";

    QFile cacert_file(cacert_path); 

    QSslConfiguration SslConfiguration(QSslConfiguration::defaultConfiguration());

    QList<QSslCertificate> caList = SslConfiguration.caCertificates();
    QSslCertificate cacert_cert=QSslCertificate::fromPath(cacert_path,QSsl::Pem)[0];

    QSslCertificate cert_cert=QSslCertificate::fromPath(cert_path,QSsl::Pem)[0];

    caList.append(cacert_cert);
    SslConfiguration.setCaCertificates(caList);
    SslConfiguration.setLocalCertificate(cert_cert);
    SslConfiguration.setProtocol(QSsl::AnyProtocol);

    QFile key_file(key_path);
    bool exists=key_file.exists();
    QDir d = QFileInfo(key_file).absoluteDir();    
    QString absolutepath=d.absolutePath();

    QDir myDir("certificates");
    QStringList filesList = myDir.entryList(QDir::Files);

    key_file.open(QIODevice::ReadOnly); 
    QSslKey sslkey(&key_file,QSsl::Rsa, QSsl::Pem, QSsl::PrivateKey);   
    key_file.close();

    SslConfiguration.setPrivateKey(sslkey);
    request->setSslConfiguration(SslConfiguration);
}

1 个答案:

答案 0 :(得分:-2)

请将这些.DLL复制到您的应用程序文件夹:

libeay32.dll ssleay32.dll

QT需要这些才能使用SSL。