QNetworkRequest和默认SSL配置

时间:2010-09-10 10:20:10

标签: qt ssl qnetworkaccessmanager qnetworkrequest

我正在使用以下代码与服务器发出HTTPS请求。

QNetworkRequest request;

//request.setSslConfiguration(QSslConfiguration::defaultConfiguration());
request.setUrl(QUrl("https://www.someurl.com/"));

QNetworkReply *reply = manager->get(request);

似乎一切都在使用我的测试服务器,但我想知道是否建议设置defaultConfiguration(取消注释第二行),或者在使用SSL时网络API是否会自动检查所有defaultConfiguration?如果它检查,如果我添加一个自定义配置,它也会这样做吗?我的意思是,是否需要将自定义配置附加到默认配置列表中?例如:

QSslConfiguration SslConfiguration(QSslConfiguration::defaultConfiguration());

QList<QSslCertificate> certificates = SslConfiguration.caCertificates();
certificates.append(QSslCertificate::fromData(certificate.toAscii(), QSsl::Pem));
SslConfiguration.setCaCertificates(certificates);

request.setSslConfiguration(SslConfiguration);

编辑:我想补充一点,我正在使用Symbian平台。

1 个答案:

答案 0 :(得分:6)

来自文件 void QNetworkRequest::setSslConfiguration ( const QSslConfiguration & config )

  

默认情况下,没有SSL配置   设置,允许后端   自由选择配置是什么   最适合他们。

您可以使用以下代码验证此声明:

#include <QtGui/QApplication>
#include <QtCore/QDebug>
#include <QtNetwork/QNetworkAccessManager>
#include <QtNetwork/QNetworkRequest>
#include <QtNetwork/QNetworkReply>
#include <QtNetwork/QSslConfiguration>

int main(int argc, char *argv[])
{
    QApplication app(argc, argv);

    QNetworkAccessManager qnam;
    QNetworkRequest request;
    QNetworkReply* reply = qnam.get(request);

    qDebug() << "Default SSL configuration isNull: "
             << QSslConfiguration::defaultConfiguration().isNull();

    qDebug() << "SSL configuration used by QNAM isNull: "
             << reply->sslConfiguration().isNull();

    return app.exec();
}

但是,您似乎将根CA证书存储与SSL配置混淆。前者只是后者的一部分(见QList<QSslCertificate> QSslConfiguration::caCertificates () const)。如果您想确保QNAM将使用您的根CA证书,您可以利用QNAM使用QSslSocket建立SSL连接并使用以下任何静态方法的事实

void addDefaultCaCertificate ( const QSslCertificate & certificate )
bool addDefaultCaCertificates ( const QString & path, QSsl::EncodingFormat encoding = QSsl::Pem, QRegExp::PatternSyntax syntax = QRegExp::FixedString )
void addDefaultCaCertificates ( const QList<QSslCertificate> & certificates )
void setDefaultCaCertificates ( const QList<QSslCertificate> & certificates )

设置要使用QSslSocket进行的所有 SSL连接使用的根CA证书。请记住,这是全局设置,并且影响使用QSslSocket 进行的所有SSL连接,而不仅仅是使用QNAM进行的连接。没有API可以仅为特定的QNAM或所有QNAM设置此项。