0

だから私は 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() もクラッシュします...ありがとうございます

4

1 に答える 1

0

QTcpSocket を QSslSocket に単純にキャストして、動作することを期待することはできません。Qt で SSL サーバーを作成する方法の例については、https://gitorious.org/qt-examples/qt-examples/source/7fdab8bcca3b1083cd07670131c75874300ad2d3:sslserverを参照してください。

于 2014-05-24T16:48:44.020 に答える