配置QSslConfiguration让客户端程序跳过本地SSL验证

来源:互联网 发布:js 数字比大小 编辑:程序博客网 时间:2024/06/17 06:28

大家下午好哦。今天我们在重新制作我们萌梦聊天室的时候,出现了这样的问题。那就是我们的客户端能够对qtdream.com服务器进行登录,但是不能对localhost服务器(也就是本机啦)进行登录。这究竟是什么原因呢?

因为这个问题是在我们引入了https的时候出现的,所以我们把原因定位到为什么会导致https出现问题。后面我看到了QNetworkRequest这个类,看到了里面有这样一个函数:

QNetworkRequest::setSslConfiguration(const QSslConfiguration &configuration);

这个函数呢,可以设置SSL的配置,包括OpenSSL以及其它的SSL,都是这样的配置。然后我又看QSslConfiguration这个类,并且看到了这样的函数:

QSslSocket::setPeerVerifyMode(QSslSocket::PeerVerifyMode mode);

我在仔细研读文档后,发现其中的端倪。原来默认设置是对服务器的安全证书进行验证的。我们本地的网站由于证书有问题,从而无法导入证书,这个时候呢,无法通过验证。这个时候,默认的验证模式无法通过,从而服务端无法获得到客户端传入的数据,因此我们需要进行这样的操作:

    // 设置SSL配置    QSslConfiguration sslConf;    sslConf.setPeerVerifyMode( QSslSocket::VerifyNone );    r.setSslConfiguration( sslConf );

这样操作的话,我们就可以不再检测SSL了。这样我们就可以顺利地通过我们的客户端连接到我们的服务器了。怎样?很简单吧。


原文链接:点击打开链接

原创粉丝点击