Qt服务器和android ssl客户端证书

时间:2013-09-18 15:49:19

标签: java android qt

我使用Qt作为服务器端,android作为客户端。 我设置了SSLSocketFactory认证

    private ConnectionManager(MBoxConfiguration config) {
    try {
        this.config = config;


         try {
                trusted.load(in, "password".toCharArray());
        } finally {
            in.close();
        }

          SSLSocketFactory sf = new SSLSocketFactory(trusted);
          Socket socket;
          socket = ssf.createSocket();
      socket.connect(new InetSocketAddress(config.ip, config.port));
           KeyStore trusted = KeyStore.getInstance("BKS");

        InputStream in = MainActivity.context.getResources().openRawResource(R.raw.truststore);
        try {

            trusted.load(in, "password".toCharArray());
        } finally {
            in.close();
        }

        ssf = new SSLSocketFactory(trusted);
             ssf.setHostnameVerifier(SSLSocketFactory.STRICT_HOSTNAME_VERIFIER);                                                                                                                   


    } catch (Exception e) {

        e.printStackTrace();

    }

}

当我想要连接到服务器时,在QT中给出了我的错误

Thread Address in peerVerifyError "The peer did not present any certificate" Thread Address in sslErrors ("The peer did not present any certificate") Thread Address in error QAbstractSocket::SocketError( 13 ) Thread Address in destroyThreadfirst: QThread(0x12ec9448) Thread Address in destroyThread: QThread(0x12ec9238)

1 个答案:

答案 0 :(得分:0)

http://qt-project.org/doc/qt-5.1/qtnetwork/qsslsocket.html

查看QSslSocket :: sslErrors的描述

尝试连接sslErrors信号,然后从那里调用插槽ignoreSslErrors()以忽略错误,这应该会有所帮助。