承接上两篇,我们将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 */