QWebSocket SSL客户端

1、SSL配置

QSslConfiguration conf = webclient.sslConfiguration();
conf.setPeerVerifyMode(QSslSocket::VerifyNone);
//conf.setPeerVerifyMode(QSslSocket::VerifyPeer);
conf.setProtocol(QSsl::TlsV1SslV3);
webclient.setSslConfiguration(conf);

如果setPeerVerifyMode设置为VerifyPeer,配置信赖服务器证书,我这里使用的是自签名证书,做如下配置

QList<QSslCertificate> certlist = QSslCertificate::fromPath(":/localhost.cert");
QSslError error(QSslError::SelfSignedCertificate, certlist.at(0));
QList<QSslError> expectedErrors;
expectedErrors.append(error);
webclient.ignoreSslErrors(expectedErrors);

2、完整构造函数实现

//配置SSL
QSslConfiguration conf = webclient.sslConfiguration();
//conf.setPeerVerifyMode(QSslSocket::VerifyNone);
conf.setPeerVerifyMode(QSslSocket::VerifyPeer);
conf.setProtocol(QSsl::TlsV1SslV3);
webclient.setSslConfiguration(conf);

//解决自签名证书不受信赖问题,VerifyNone不需添加以下代码
QList<QSslCertificate> certlist = QSslCertificate::fromPath(":/localhost.cert");
QSslError error(QSslError::SelfSignedCertificate, certlist.at(0));
QList<QSslError> expectedErrors;
expectedErrors.append(error);
webclient.ignoreSslErrors(expectedErrors);

connect(&webclient, SIGNAL(textMessageReceived(QString)), this, SLOT(recvData(QString)));
connect(&webclient, SIGNAL(connected()), this, SLOT(connected()));
connect(&webclient, SIGNAL(error(QAbstractSocket::SocketError)),
        this, SLOT(readError(QAbstractSocket::SocketError)));

源代码下载:https://download.csdn.net/download/cqchengdan/11439289

 

 
 
Netty是一个基于Java NIO的网络通信框架,可以用于快速开发高性能的网络应用程序。WebSocket是一种在单个持久连接上进行全双工通信的协议,可以在客户端和服务器之间进行实时数据传输。而SSL(Secure Socket Layer)则是一种加密通信协议,用于确保网络通信的安全性。 在Netty中使用WebSocket进行通信时,可以通过SSL来加密通信,从而提高通信的安全性。在客户端中使用Netty WebSocket SSL,需要首先创建一个客户端SSLContext,并加载对应的证书和密钥,然后将SSLContext集成到Netty的ChannelPipeline中。 在创建Netty的客户端时,首先需要创建一个Bootstrap实例,并配置相关的参数。然后,创建一个处理器(Handler),用于处理客户端WebSocket请求和SSL加密。在处理器中,需要添加来自Netty的WebSocketClientProtocolHandler和SslHandler,用于处理WebSocketSSL的握手和通信过程。 在向服务器发送WebSocket请求时,客户端需要构建一个WebSocket的握手请求,并将请求发送给服务器。在握手成功后,客户端就可以与服务器进行双向通信,通过WebSocket协议进行数据的传输。 总的来说,Netty WebSocket SSL客户端的实现需要首先创建SSLContext和配置客户端的Bootstrap实例,在处理器中将WebSocketSSL的握手和通信进行集成,然后构建WebSocket的握手请求并与服务器进行通信,从而实现基于Netty的WebSocket SSL客户端的开发。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值