mbedtls 入门第五课--编译mbedtls静态库到VS--VS SHA256移植

本文介绍了如何在Windows下,利用VS2012编译mbedtls生成静态库.lib,然后在新建项目中引入该库及头文件,进行SHA256算法的测试。主要步骤包括编译mbedtls,添加库和头文件路径,以及配置VS项目引用库文件。
摘要由CSDN通过智能技术生成

承接上两篇,我们将mbedtls的代码移植到了VS2012和ESP8266的两个平台。

博主这里继续介绍下使用windows静态库的方式实现SHA256算法。

1.打开mbedtls下建立的VC工程,如图所示:

博主推荐使用VS2010环境去编译,当然博主也不知道使用更高版本能否编译成功。

 2. 编译成功后可以在debug下看到编译成功的静态库.lib,如图所示:

3. 使用VS建立一个空白的工程,并且将mbedTLS.lib、mbedtls根目录下的头文件夹include、上次使用到的SHA256测试代码复制到工程下,如图所示:

 

 4. 添加库文件路径和头文件路径到VS的编译链中,如图所示:

 

5. 记住要告诉VS,你需要使用什么库,这里有两种方法,第一种是在工程 属性中配置库文件名,如下图一所示:

第二种方式是,直接使用 #pragma comment(lib, "mbedTLS.lib")的方式引用对应的库文件,如图所示:

6.测试代码如下所示:

 

#include <stdlib.h>
#include <stdio.h>
#include "mbedtls/config.h"
#include "mbedtls/sha256.h"
#include "mbedtls/config.h"
#pragma comment(lib, "mbedTLS.lib")
#define mbedtls_printf       printf
#define MBEDTLS_EXIT_SUCCESS EXIT_SUCCESS
#define MBEDTLS_EXIT_FAILURE EXIT_FAILURE
#if !defined(MBEDTLS_MD5_C)
int main( void )
{
    mbedtls_printf("MBEDTLS_MD5_C not defined.\n");
    return( 0 );
}
#else
int main( void )
{
    int i;
    mbedtls_sha256_context sha256_ctx;
    unsigned char hash[32];
    const unsigned char encrypt[] = "hello_worled1234";
    printf("SHA-256 encrypt\n");
    mbedtls_sha256_init(&sha256_ctx);
    mbedtls_sha256_starts(&sha256_ctx, 0); // 0表示传sha256 , 1 表示传SHA-244
    mbedtls_sha256_update(&sha256_ctx, encrypt, strlen((char *)encrypt));
    mbedtls_sha256_finish(&sha256_ctx, hash);

    printf("before SHA256 encrypt:[%s]\n", encrypt);
    printf("after SHA256 encrypt:");
    for( i = 0; i < 32; i++)
    {
        printf("%02x", hash[i]);
    }
    printf("\r\n");

    mbedtls_sha256_free(&sha256_ctx);
}
#endif /* MBEDTLS_MD5_C */
 

 

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在GD32F460系列单片机中移植mbedtls-v3.4.0库的AES和RSA加密算法,你需要按照以下步骤进行操作: 1. 下载mbedtls-v3.4.0库:从mbedtls官方网站(https://tls.mbed.org/)下载mbedtls-v3.4.0库的源代码。 2. 配置GD32F460开发环境:根据GD32F460系列单片机的开发环境,配置编译工具链(如GCC)和相应的开发环境。 3. 移植AES加密算法: - 将mbedtls/library/aes.c和mbedtls/include/mbedtls/aes.h两个文件复制到你的GD32F460项目中的对应目录下。 - 在你的项目中包含aes.c和aes.h文件,并进行编译和链接。 4. 移植RSA加密算法: - 将mbedtls/library/rsa.c、mbedtls/library/bignum.c和mbedtls/include/mbedtls/rsa.h、mbedtls/include/mbedtls/bignum.h四个文件复制到你的GD32F460项目中的对应目录下。 - 在你的项目中包含rsa.c、bignum.c、rsa.h和bignum.h文件,并进行编译和链接。 5. 配置编译选项:在你的GD32F460项目中,确保已经启用了适当的编译选项,例如启用了C标准库和适当的优化级别。 6. 修改配置文件:根据GD32F460系列单片机的内存和性能限制,适当调整mbedtls库的配置文件,例如`mbedtls/config.h`文件。你可以根据需要禁用不需要的功能或调整缓冲区大小等。 7. 编写测试代码:使用GD32F460的开发环境编写测试代码,调用mbedtls库中的AES和RSA函数进行加密和解密操作。 请注意,以上步骤提供了一个基本的指导,具体的移植过程可能因项目的具体要求和开发环境而有所不同。在移植过程中,你可能还需要处理其他依赖项、适配底层接口和处理与GD32F460硬件相关的特定细节。 建议参考mbedtls的官方文档和示例代码,以获取更详细的移植指南和使用说明。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值