这是代码:
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。
我做错了什么?
答案 0 :(得分:0)
检查SSL_write()
返回的内容。也许它是SSL_ERROR_WANT_READ
,在这种情况下,您必须先从SSL连接中读取并将读取的数据提供给SSL
对象。如果您在第二个SSL_read()
之前调用它,SSL_set_bio()
会为您执行此操作。
但是当你成功使用SSL_write()
时 - 请注意,它不会只是你的生物BIO中的加密数据。与协议有关的数据也将存在。