だから私は QTCreator で非常に基本的なサーバー/クライアントに取り組んでいます。クライアントが接続しようとしたときに、サーバーがクライアントに証明書を送信することになっています。サーバーに次のコードがあります。
void Dialog::createSocket()
{
tcpSocket = (QSslSocket*)tcpServer->nextPendingConnection();
QByteArray key;
QByteArray cert;
QByteArray block;
QFile fileKey("C:/Users/siu850967358.AD.002/Desktop/ECE424_Lab2/server.key");
if(fileKey.open(QIODevice ::ReadOnly))
{
key = fileKey.readAll();
fileKey.close();
}
else
{
qDebug() << fileKey.errorString();
}
QFile fileCert("C:/Users/siu850967358.AD.002/Desktop/ECE424_Lab2/server.crt");
if(fileCert.open(QIODevice ::ReadOnly))
{
cert = fileCert.readAll();
fileCert.close();
}
else
{
qDebug() << fileCert.errorString();
}
qDebug() << key + "\n" + cert;
QString mykey(cert);
QSslKey ssl_Key(key, QSsl::Rsa);
QSslKey* sslKey = &ssl_Key;
QSslCertificate ssl_Cert(cert);
QSslCertificate* sslCert = &ssl_Cert;
//CRASH HAPPENS HERE
qDebug() << "ok";
tcpSocket->setPrivateKey(ssl_Key);
qDebug() << "ok2";
tcpSocket->setLocalCertificate(ssl_Cert);
qDebug() << "Key and certificate set";
//CRASH HAPPENS HERE
QDataStream out(&block, QIODevice::WriteOnly);
out.setVersion(QDataStream::Qt_4_0);
out << (quint16)0;
out << mykey;
out.device()->seek(0);
out << (quint16)(block.size() - sizeof(quint16));
qDebug() << "write the certificate to the socket so that client may get the pubkey";
tcpSocket->write(block);
//connect(tcpSocket, SIGNAL(encrypted()), this, SLOT(readSocket()));
connect(tcpSocket, SIGNAL(readyRead()), this, SLOT(readSocket()));
tcpSocket->startServerEncryption();
}
tcpSocket->setPrivateKey(ssl_Key); クラッシュを引き起こします。tcpSocket->setPrivateKey(キー); クラッシュは発生しませんが、それは正しくないと思います.... tcpSocket->setLocalCertificate(); と同じ扱いです。
何か案は??ところで、この場所 tcpSocket->flush() もクラッシュします...ありがとうございます