mbedtls mbedtls_ssl_handshake失败

在学习mbedtls中,尝试使用PSK加密套件来进行通信,于是写了一个简单的sever和client。

client程序运行到mbedtls_ssl_handshake出现失败,返回-6C00,错误原因:Internal error (eg, unexpected failure in lower-level module)。

运行环境是wsl2下的ubuntu20.04

在网上找了很多资料也没有解决。请问有人遇到过这种情况吗,怎么处理?

以下是服务端代码

#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdarg.h>

#include "mbedtls/net_sockets.h"
#include "mbedtls/ssl.h"
#include "mbedtls/entropy.h"
#include "mbedtls/ctr_drbg.h"


#define SERVER_IP "172.19.25.42"
#define SERVER_PORT "4433"


// 预共享密钥
static const unsigned char psk_key[] = {
    0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
    0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11
};


// 预共享密钥标识
static const char psk_identity[] = "Client_Identity";


int main() {
    mbedtls_net_context server_fd;
    mbedtls_ssl_context ssl;
    mbedtls_ssl_config conf;
    mbedtls_ctr_drbg_context ctr_drbg;
    mbedtls_entropy_context entropy;
    int ret;


    // 初始化网络、SSL、SSL 配置、熵源和 CTR_DRBG 上下文
    mbedtls_net_init(&server_fd);
    mbedtls_ssl_init(&ssl);
    mbedtls_ssl_config_init(&conf);
    mbedtls_entropy_init(&entropy);
    mbedtls_ctr_drbg_init(&ctr_drbg);


    // 初始化熵源和 CTR_DRBG
    ret = mbedtls_ctr_drbg_seed(&ctr_drbg, mbedtls_entropy_func, &entropy, NULL, 0);
    if (ret!= 0) {
        printf("Failed to seed the random number generator!\n");
        goto exit_cleanup;
    }


    // 设置 SSL 配置默认值
    mbedtls_ssl_config_defaults(&conf,MBEDTLS_SSL_IS_SERVER,MBEDTLS_SSL_TRANSPORT_STREAM,MBEDTLS_SSL_PRESET_DEFAULT);
    mbedtls_ssl_conf_rng(&conf, mbedtls_ctr_drbg_random, &ctr_drbg);


    // 配置 PSK 信息
    mbedtls_ssl_conf_psk(&conf, psk_key, sizeof(psk_key), (const unsigned char *)psk_identity, strlen(psk_identity));


    // 仅使用 MBEDTLS_TLS_PSK_WITH_AES_128_CBC_SHA256 密码套件
    const int ciphersuites = MBEDTLS_TLS_PSK_WITH_AES_128_CBC_SHA256;
    mbedtls_ssl_conf_ciphersuites(&conf, &ciphersuites);


    // 绑定和监听端口
    ret = mbedtls_net_bind(&server_fd, SERVER_IP, SERVER_PORT, MBEDTLS_NET_PROTO_TCP);
    if (ret!= 0) {
        printf("Failed to bind to port %s\n", SERVER_PORT);
        goto exit_cleanup;
    }


    printf("Listening on port %s...\n", SERVER_PORT);


    // 接受客户端连接
    mbedtls_net_context client_fd;
    mbedtls_net_init(&client_fd);
    ret = mbedtls_net_accept(&server_fd, &client_fd, NULL,0,NULL);
    if (ret!= 0) {
        printf("Failed to accept client connection\n");
        goto exit_cleanup;
    }

    // char buf[256];
    // while(1)
    // {
    //     memset(buf,0,256);
    //     read(client_fd.fd,buf,256);
    //     printf("buf = %s\n",buf);
    //     sleep(2);
    // }

    printf("Client connected\n");


    // 初始化 SSL 上下文
    mbedtls_ssl_setup(&ssl, &conf);
    mbedtls_ssl_set_bio(&ssl, &client_fd, mbedtls_net_send, mbedtls_net_recv, NULL);


    // 进行 SSL/TLS 握手
    // ret = mbedtls_ssl_handshake(&ssl);
    // if (ret!= 0) {
    //     printf("SSL/TLS handshake failed! ret = %d\n",ret);
    //     goto exit_cleanup;
    // }

    while( ( ret = mbedtls_ssl_handshake( &ssl ) ) != 0 )
    {
        if( ret != MBEDTLS_ERR_SSL_WANT_READ && ret != MBEDTLS_ERR_SSL_WANT_WRITE )
        {
            printf( " failed\n  ! mbedtls_ssl_handshake returned -0x%x\n\n", -ret );
            goto exit_cleanup;
        }
    }


    printf("SSL/TLS handshake successful!\n");


    // 发送和接收数据
    char send_buffer[] = "Hello, client!";
    ret = mbedtls_ssl_write(&ssl, (const unsigned char *)send_buffer, strlen(send_buffer));
    if (ret < 0) {
        printf("Failed to send data!\n");
        goto exit_cleanup;
    } else {
        printf("Sent %d bytes: %s\n", ret, send_buffer);
    }


    unsigned char recv_buffer[1024];
    ret = mbedtls_ssl_read(&ssl, recv_buffer, sizeof(recv_buffer) - 1);
    if (ret < 0) {
        printf("Failed to receive data!\n");
        goto exit_cleanup;
    } else {
        recv_buffer[ret] = '\0';
        printf("Received %d bytes: %s\n", ret, recv_buffer);
    }


exit_cleanup:
    // 释放资源
    mbedtls_net_free(&server_fd);
    mbedtls_net_free(&client_fd);
    mbedtls_ssl_free(&ssl);
    mbedtls_ssl_config_free(&conf);
    mbedtls_ctr_drbg_free(&ctr_drbg);
    mbedtls_entropy_free(&entropy);


    return ret;
}

以下是客户端代码

#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdarg.h>

#include "mbedtls/net_sockets.h"
#include "mbedtls/ssl.h"
#include "mbedtls/entropy.h"
#include "mbedtls/ctr_drbg.h"


#define SERVER_IP "172.19.25.42"
#define SERVER_PORT "4433"


// 预共享密钥,需与服务端匹配
static const unsigned char psk_key[] = {
    0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
    0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11
};


// 预共享密钥标识,需与服务端匹配
static const char psk_identity[] = "Client_Identity";


int main() {
    mbedtls_net_context server_fd;
    mbedtls_ssl_context ssl;
    mbedtls_ssl_config conf;
    mbedtls_ctr_drbg_context ctr_drbg;
    mbedtls_entropy_context entropy;
    int ret;


    // 初始化网络、SSL、SSL 配置、熵源和 CTR_DRBG 上下文
    mbedtls_net_init(&server_fd);
    mbedtls_ssl_init(&ssl);
    mbedtls_ssl_config_init(&conf);
    mbedtls_entropy_init(&entropy);
    mbedtls_ctr_drbg_init(&ctr_drbg);


    // 初始化熵源和 CTR_DRBG
    ret = mbedtls_ctr_drbg_seed(&ctr_drbg, mbedtls_entropy_func, &entropy, NULL, 0);
    if (ret!= 0) {
        printf("Failed to seed the random number generator!\n");
        goto exit_cleanup;
    }


    // 设置 SSL 配置默认值
    mbedtls_ssl_config_defaults(&conf, MBEDTLS_SSL_IS_CLIENT, MBEDTLS_SSL_TRANSPORT_STREAM, MBEDTLS_SSL_PRESET_DEFAULT);
    mbedtls_ssl_conf_rng(&conf, mbedtls_ctr_drbg_random, &ctr_drbg);


    // 配置 PSK 信息
    mbedtls_ssl_conf_psk(&conf, psk_key, sizeof(psk_key), (const unsigned char *)psk_identity, strlen(psk_identity));


    // 仅使用 MBEDTLS_TLS_PSK_WITH_AES_128_CBC_SHA256 密码套件
    const int ciphersuites = MBEDTLS_TLS_PSK_WITH_AES_128_CBC_SHA256;
    mbedtls_ssl_conf_ciphersuites(&conf, &ciphersuites);


    // 建立与服务器的网络连接
    ret = mbedtls_net_connect(&server_fd, SERVER_IP, SERVER_PORT, MBEDTLS_NET_PROTO_TCP);
    if (ret!= 0) {
        printf("Failed to connect to server at %s:%s\n", SERVER_IP, SERVER_PORT);
        goto exit_cleanup;
    }

    // while(1)
    // {
    //     write(server_fd.fd,"hello",6);
    //     sleep(2);
    // }

    // 初始化 SSL 上下文
    mbedtls_ssl_setup(&ssl, &conf);
    mbedtls_ssl_set_bio(&ssl, &server_fd, mbedtls_net_send, mbedtls_net_recv, NULL);


    //进行 SSL/TLS 握手
    ret = mbedtls_ssl_handshake(&ssl);
    if (ret!= 0) {
        printf("SSL/TLS handshake failed! ret = %d\n",ret);
        goto exit_cleanup;
    }

    printf("SSL/TLS handshake successful!\n");

    // 发送和接收数据
    char send_buffer[] = "Hello, server!";
    ret = mbedtls_ssl_write(&ssl, (const unsigned char *)send_buffer, strlen(send_buffer));
    if (ret < 0) {
        printf("Failed to send data!\n");
        goto exit_cleanup;
    } else {
        printf("Sent %d bytes: %s\n", ret, send_buffer);
    }


    unsigned char recv_buffer[1024];
    ret = mbedtls_ssl_read(&ssl, recv_buffer, sizeof(recv_buffer) - 1);
    if (ret < 0) {
        printf("Failed to receive data!\n");
        goto exit_cleanup;
    } else {
        recv_buffer[ret] = '\0';
        printf("Received %d bytes: %s\n", ret, recv_buffer);
    }


exit_cleanup:
    // 释放资源
    mbedtls_net_free(&server_fd);
    mbedtls_ssl_free(&ssl);
    mbedtls_ssl_config_free(&conf);
    mbedtls_ctr_drbg_free(&ctr_drbg);
    mbedtls_entropy_free(&entropy);


    return ret;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值