- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
需要创建一个使用 SSL 连接到客户端的小型服务器应用程序。一次只能连接一个客户端。
每次客户端尝试建立新连接时,都会调用以下函数:
void Control::on_newConnection() {
if (socket != nullptr) return;
logger.appendStandard("New connection received 0");
// New connection is available.
socket = (QSslSocket*)(listener->nextPendingConnection());
logger.appendStandard("New connection received 1");
if (!socket->isValid()) {
logger.appendError("ERROR: Could not cast incoming socket connection");
return;
}
logger.appendStandard("New connection received 2");
// Doing the connections.
connect(socket,SIGNAL(encrypted()),this,SLOT(on_encryptedSuccess()));
connect(socket,SIGNAL(sslErrors(QList<QSslError>)),this,SLOT(on_sslErrors(QList<QSslError>)));
connect(socket,SIGNAL(stateChanged(QAbstractSocket::SocketState)),this,SLOT(on_socketStateChanged(QAbstractSocket::SocketState)));
connect(socket,SIGNAL(error(QAbstractSocket::SocketError)),this,SLOT(on_socketError(QAbstractSocket::SocketError)));
connect(socket,&QSslSocket::readyRead,this,&Control::on_readyRead);
connect(socket,&QSslSocket::disconnected,this,&Control::on_disconnected);
logger.appendStandard("New connection received 3");
// The SSL procedure.
socket->setPrivateKey(":/certificates/server.key");
logger.appendStandard("New connection received 3.1");
socket->setLocalCertificate(":/certificates/server.csr");
logger.appendStandard("New connection received 3.2");
socket->setPeerVerifyMode(QSslSocket::VerifyNone);
logger.appendStandard("New connection received 3.2");
socket->startServerEncryption();
logger.appendStandard("New connection received 4");
}
服务器是一个保持运行、监听连接的应用程序。建立连接后,我会根据客户端的要求做一些事情,然后使用此功能删除连接。
void Control::clearSocket(const QString &fromWhere){
if (socket != nullptr){
logger.appendStandard(fromWhere + ": About to delete socket");
delete socket;
socket = nullptr;
logger.appendStandard(fromWhere + ": Socket deleted!");
}
}
这在客户端第一次发出请求时就完美无缺。建立连接,服务器收到请求,客户端收到应答,然后在客户端关闭时删除服务器中的连接。
然而,当我想第二次执行完全相同的事务时,服务器程序在这一行崩溃了:
socket->setLocalCertificate(":/certificates/server.csr");
由于日志消息,我知道这一点。
有谁知道为什么会发生这种情况?
最佳答案
可能是事件队列中与已删除的基于 QObject 的套接字对象相关的某些内容导致了崩溃。
要安全删除,请使用 socket->deleteLater()而不是直接调用删除。它通过事件循环安排删除对象,并且该对象的任何未决事件将从事件队列中删除。
关于由于 QSslSocket 的 setLocalCertificate,Qt 控制台应用程序崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55634421/
在 Windows 7 Ultimate x64 上的 Qt 4.8 中,当我尝试使用 QNetworkAccessManager 通过网络进行 post() 操作时: _net_acc_mgr.po
我正在使用 Qt Creator 4.2.0 运行 Qt 5.7.1(MSVC 2015,32 位)。 QSslSocket 有问题。我收到以下错误: qt.network.ssl: QSslSock
我在 debian wheezy 中使用 Qt 5.4.1 中的 QSslSocket 创建了一个 sslclient 和 sslserver。当我运行程序时,它们根本不工作。调试我的代码后,我看到它
在我的项目中,我需要使用特定版本的 OpenSSL。我同时使用 Qt 4.8.6 和 Qt 5.4.0。我想创建一个自定义 QSslSocket 以传递给 QNetworkAccessManager,
我正在尝试用 Qt 编写一个简单的客户端-服务器应用程序,该应用程序将通过 SSL 进行通信。我尝试使用 QSslSockets,但我一直遇到各种问题。 看看这个: 客户: #define dumpv
我有一个客户端程序和一个服务器程序,它们使用 QSslSockets 进行通信。在服务器程序中,如果客户端成功连接,我将发送一个字符串 "Snameadded",我还想向它发送服务器上的用户列表,但作
这是我编写的同步 TCP 客户端中 read() 语句上方的一小段代码。 std::cout bytesAvailable() waitForReadyRead(); std::cou
我有一个使用QTcpSocket 的客户端-服务器应用程序。现在我想改用加密的 SSL 连接,因此我尝试切换到 QSslSocket。但是我无法与服务器建立连接。这是客户端的代码: Connectio
我正在尝试使用 Qt 文档中的示例代码实现 SSL 服务器。 但是在 serverSocket->startServerEncryption(); 被调用之后,什么也没有发生——无论是 encrypt
是否可以创建一个新的 QSslSocket 并让它获得现有 TCP 连接的所有权,并丢弃旧的 QTcpSocket,而不中断或关闭 TCP 连接? 我需要它在我的 FTP 服务器中实现显式 FTPS,
我使用此代码通过套接字传输大文件内存使用量没有峰值: connect(socket, SIGNAL(bytesWritten(qint64)), this, SLOT(refillSocket
我真的很困惑,希望有人知道我的问题。 我有一个非常简单的 SSL 客户端和服务器。连接很好。沟通很好。当客户端与服务器断开连接时,就会出现问题。这会在服务器上触发一个信号,该信号在 SLOT erro
我对 wkhtmltopdf 有疑问。我在我的 docker 中使用了这样的 wkhtmltopdf。 wkhtmltopdf https://www.google.com google.pdf 然后
我正在编写代理服务器,http 部分已准备就绪,但 https 有问题。我以这种方式创建了一个证书和私钥(据我所知,没有它是行不通的): OpenSSL> req-x509-newkey rsa: 2
我正在尝试通过 SSL 连接到 Twitch 聊天服务器,我基本上复制并粘贴了 QT 中安全 SSL 连接示例中的一些代码。当我可以 connectToHostEncrypted 时,一切都崩溃了。非
我们的业务应用程序基于 Qt 的生产服务器出现问题。当 SSL 连接总数随时间增加时,一些客户端根本无法连接。 QSslSocket::waitForEncrypted() 开始失败,没有 QSslE
需要创建一个使用 SSL 连接到客户端的小型服务器应用程序。一次只能连接一个客户端。 每次客户端尝试建立新连接时,都会调用以下函数: void Control::on_newConnection()
我有一个应用程序作为代理使用 QTcpSocket 拦截 HTTP 请求。我正在尝试将其扩展为也适用于 HTTPS,但它似乎并没有像我预期的那样工作。由于应用程序的独特性,我无法使用 QHttp。 目
我正在 Windows 上开发一个应连接到服务器的应用程序。因此我实现了一个 QSslSocket。 执行连接方法后,sslSocket errorString 发送 The issuer certi
有一个定义 QT_NO_SSL ,如果没有找到 Ssl 库,则定义。还有方法 QSslSocket::supportsSsl() . 但这两者有什么关系,它们是等价的吗?是否QT_NO_SSL QS
我是一名优秀的程序员,十分优秀!