我想在VS2010 C++环境中使用Qt框架(QNetworkRequest)获取网站(json字符串)的内容。我从HTTP网站读取数据没有问题,但是当我尝试阅读HTTPS网站的内容时,我没有运气。另一方面,浏览器可以“查看”网站内容。我认为这是一个证书问题,但我不完全确定。我只能从firefox访问ca.pem(我输出)。我用cert.pem和key.pem的虚拟pem文件,以便我不留空。不幸的是,我无法以其他方式获取这些文件。使用C++获取HTTPS网站内容QNetworkRequest
我得到一个带有描述“私钥不能证明公钥,错误: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);
}
replyFinished()中没有报告错误? (检查回复 - >错误()和回复 - > errorString()) –
我得到一个错误99代码与描述“私钥不认证公钥,错误:140A80B1:SSL例程:SSL_CTX_check_private_key:没有分配证书”。所以它应该是伪密钥证书的错误。 – roni