OpenSSL:尝试使用通过握手获取的密钥材料来本地加密数据

时间:2011-09-06 15:56:28

标签: c++ ssl openssl

这是代码:

bool EncoderTLS::handshake()
{
    int sock = getSocket();
    SSL *ssl = SSL_new(ctx);
    BIO *sbio = BIO_new_socket(sock, BIO_NOCLOSE);
    SSL_set_bio(ssl, sbio, sbio);
    int r;
    int i = 0;
    while(i < ATTEMPTS)
    {
        int s;
        if((r = ((isServer) ? SSL_accept(ssl) :SSL_connect(ssl)) )<=0)
        {
            s = SSL_get_error(ssl,r);
            if (SSL_get_error(ssl,r) == SSL_ERROR_SYSCALL)
            {
                if (errno == 0) break;
                printf("errno = %d\n",errno);
                perror("Syscall error");
            }
        }
        if (s == SSL_ERROR_WANT_READ || s == SSL_ERROR_WANT_WRITE) usleep(10);
        else 
        {
            logger->log(Level::WARNING, "SSL handshake failed");
            return false;
        }
        i++;
    }
    if (!isServer && SSL_get_verify_result(ssl) != X509_V_OK) //Server authentication
    {
        logger->log(Level::WARNING, "couldn't verify certificate");
        printf("Error: %s\n", ERR_reason_error_string(ERR_get_error()));
        return false;
    }
    BIO *test = BIO_new(BIO_s_mem());
    SSL_set_bio(ssl, test, test);
    SSL_write(ssl, "blablablablabla", 10);
    char **p;
    int length = BIO_get_mem_data(test,p);
    printf("Printing encoding of 'blablablab', of length %d:\n", length);
    for(int j=0; j<length; j++)
        printf("%c", p[j]);
    printf("\n");
    return true;
}

我希望SSL_write写到最后的数据会进入BIO和内存。但是,当我尝试从BIO获取数据时,它告诉我它的长度为0。

我做错了什么?

1 个答案:

答案 0 :(得分:0)

检查SSL_write()返回的内容。也许它是SSL_ERROR_WANT_READ,在这种情况下,您必须先从SSL连接中读取并将读取的数据提供给SSL对象。如果您在第二个SSL_read()之前调用它,SSL_set_bio()会为您执行此操作。

但是当你成功使用SSL_write()时 - 请注意,它不会只是你的生物BIO中的加密数据。与协议有关的数据也将存在。