乐鑫Esp32学习之旅 22 讨论下程序员 “青春饭” 那些事,分享在esp32实现多种加密算法md5 |AES CBC-ECB| Sha1 | Sha256 等,附带Demo;


  • 本系列博客学习由非官方人员 半颗心脏 潜心所力所写,仅仅做个人技术交流分享,不做任何商业用途。如有不对之处,请留言,本人及时更改。

1、 爬坑学习新旅程,虚拟机搭建esp32开发环境,打印 “Hellow World”。
2、 巧用eclipes编辑器,官方教程在在Windows下搭建esp32开发环境,打印 “Hellow World”。
3、 认识基本esp32的GPIO接口,开始点亮您的第一盏 LED和中断回调实现按键功能 。
4、体会esp32的强大的定时器功能, 实现定时2s闪烁一盏LED灯。
5、接触实践esp32的pwm宽度脉冲功能, 实现呼吸效果闪烁一盏LED灯。
6、smartConfig和微信airKiss在esp32的实现,一键配网轻松快捷连接路由器。
7、利用GPIO中断做一个按键的短按和长按的回调事件,再也无须担心触发源。
8、esp32上实现本地 UDP 客户端和服务端角色,在局域网内实现通讯。
9、esp32上实现本地 TCP 客户端和服务端角色,可断线重连原路返回数据。
10、乐鑫esp32 SDK编程利用rmt驱动ws2812七彩灯,实现彩虹渐变效果。
11、入门 乐鑫esp-adf 音频框架开发,esp32造一个蓝牙耳机,实现切换歌曲,获取歌曲信息等功能。
12、开源一个微信公众号airkiss配网esp32以及局域网发现功能的工程,分享一个airkiss配网小工具。
13、esp32 内置 dns 服务器,无需外网访问域名返回指定网页。
14、esp32 sdk编程实现门户强制认证,连接esp32热点之后,自动强制弹出指定的登录界面。
15、认识本地离线语音唤醒识别框架 esp-skainet ,实现较低成本的硬件语音本地识别控制。
16、学习本地语音唤醒离线识别框架 esp-skainet ,如何修改唤醒词? 如何自定义命令词?如何做意图动作?
17、全网首发,乐鑫esp32 sdk直连京东微联·小京鱼 · IoT开放平台,实现叮咚音响语音智能控制。
18、入门京东微联·小京鱼的控制面板H5开发,读懂vue语法,做自己的控制页面。
19、重磅开源,如何在微信小程序上ble蓝牙配网esp32,blufi的那些事!
20、一篇好文,开发过程中编译esp32固件太大,无法正常启动?教你如何自定义分区表partitions.csv。
21、 esp32蓝牙配网blufi的高度封装,集成简单、使用简单、容易上手,提高开发效率!
22、讨论下程序员 “青春饭” 那些事,分享在esp32实现多种加密算法md5 |AES CBC-ECB| Sha1 | Sha256 等!

在这里插入图片描述

一、前言

在这里插入图片描述
    很庆幸能生活在如今的中国,物质条件和以前相比直线提高,没有任何能够理由抱怨社会、抱怨身边的是非!

    此生无悔入华夏,来生愿在种花家。

    近些年是互联网的寒冬,很大的大型公司都在大规模裁员,滴滴、360、乐视、蘑菇街、暴风魔镜等巨头公司都在其列!说到底,还是中国互联网行业对程序员门槛在提高!

    这些年一直有个说法,“程序员青春饭”,这是一个很现实的问题,不能回避!其然,很多行业都有这样的说法,比如说酒店里面的前台,服务员,酒吧里面的前台,服务员等等,很多服务行业基本上都是如此,他们需要年轻的人,一群有活力,有颜值的人,毕竟这也是个看脸的世界。只是在IT行业,这个说法被提到的更加突出!

    因为计算机,特别是算法,需要很长时间的沉淀,需要踩很多坑,做很多总结,看大量别人的成果,才能有所突破。

    因为这个行业与其他行业不同,其他行业你可以靠一个经验二十年,但计算机行业需要的是不停的学习,有着极高的复杂度,很多在一线编写的程序员无法跟上节奏会逐渐离开换管理或者转行。计算机行业基本上每3-5年,你所学过的知识就需要重新更新一遍。

    说白了水平层次没达到,35岁的技术水平跟20刚出头的没什么差别,公司凭啥不要招聘年轻的!

    最后,希望大家一起学习,关注我公众号,一起奋斗!

    因乐鑫esp-idf框架集成开源的 mbedtls 加密库,所以很大程度上,下面分享的代码,不仅仅适用esp32或esp8266,也适合像 stm32 这样流行的arm芯片!

1.1 Md5加密

    下面是对字符串变量encrypt加密,参考网址对比如下:
    在线MD5加密:https://www.cmd5.com

/**
 * @description: md5加密  32位输出
 * @param {type} 
 * @return: 
 */
static void TaskMd5(void *parm)
{

    unsigned char encrypt[] = "https://blog.csdn.net/xh870189248";
    unsigned char decrypt[16];
    mbedtls_md5_context md5_ctx;
    mbedtls_md5_init(&md5_ctx);
    mbedtls_md5_starts(&md5_ctx);
    mbedtls_md5_update(&md5_ctx, encrypt, strlen((char *)encrypt));
    mbedtls_md5_finish(&md5_ctx, decrypt);
    ESP_LOGI(LOG_TAG, "Md5加密前:[%s] \n md5加密后(32位):", encrypt);

    for (int i = 0; i < 16; i++)
    {
        printf("%02x", decrypt[i]);
    }
    mbedtls_md5_free(&md5_ctx);

    printf("\n");
    vTaskDelete(NULL);
}

1.2 Sha1加密

    下面是对字符串变量encrypt加密,参考网址对比如下:
    在线Sha1加密:http://www.3464.com/tools/sha1


/**
 * @description: sha1加密
 * @param {type} 
 * @return:     
 */
static void TaskSha1(void *parm)
{
    int i;

    unsigned char decrypt[32];
    const unsigned char encrypt[] = "https://github.com/xuhongv";
    ESP_LOGI(LOG_TAG, "Sha1 要加密数据: %s", encrypt);

    mbedtls_sha1_context sha1_ctx;
    mbedtls_sha1_init(&sha1_ctx);
    mbedtls_sha1_starts(&sha1_ctx);
    mbedtls_sha1_update(&sha1_ctx, encrypt, strlen((char *)encrypt));
    mbedtls_sha1_finish(&sha1_ctx, decrypt);
    mbedtls_sha1_free(&sha1_ctx);

    ESP_LOGI(LOG_TAG, "Sha1 加密后数据:");
    for (i = 0; i < 20; i++)
    {
        printf("%02x", decrypt[i]);
    }
    vTaskDelete(NULL);
}

1.3 AES - ECB加密、解密

    下面是对字符串变量 plain加密,注意参考网址对比:
    在线ECB加密:http://tool.chacuo.net/cryptaes

     !!! ECB模式只能实现16字节的明文加解密。 !!!

/**
 * @description: ECB加密解密:数据块128位 偏移量为0,没填充
 * @param {type} !!!! ECB模式只能实现16字节的明文加解密。 !!!
 * @return: 
 */
static void TaskECB(void *parm)
{

    ESP_LOGI(LOG_TAG, "AES-ECB 加密-数据块(128位),偏移量为0");

    mbedtls_aes_context aes_ctx;
    //密钥数值
    unsigned char key[16] = {'e', 'c', 'b', 'p', 'a', 's', 's', 'w', 'o', 'r', 'd', '1', '2', '3', '4'};
    //明文空间
    unsigned char plain[16] = "csdn-xuhong";
    //解密后明文的空间
    unsigned char dec_plain[16] = {0};
    //密文空间
    unsigned char cipher[16] = {0};

    mbedtls_aes_init(&aes_ctx);
    //设置加密密钥
    mbedtls_aes_setkey_enc(&aes_ctx, key, 128);
    ESP_LOGI(LOG_TAG, "要加密的数据: %s", plain);
    ESP_LOGI(LOG_TAG, "加密的密码: %s", key);
    mbedtls_aes_crypt_ecb(&aes_ctx, MBEDTLS_AES_ENCRYPT, plain, cipher);
    ESP_LOGI(LOG_TAG, "加密结果,二进制表示: ");
    for (int loop = 0; loop < 16; loop++)
        printf("%02x", cipher[loop]);
    printf("\r\n");

    //设置解密密钥
    mbedtls_aes_setkey_dec(&aes_ctx, key, 128);
    mbedtls_aes_crypt_ecb(&aes_ctx, MBEDTLS_AES_DECRYPT, cipher, dec_plain);
    ESP_LOGI(LOG_TAG, "解密后的数据: %s", dec_plain);
    mbedtls_aes_free(&aes_ctx);
    vTaskDelete(NULL);
}
  • 操作截图:
    在这里插入图片描述

1.4 AES - ECB加密、解密

    下面是对字符串变量encrypt加密,参考网址对比如下:
    在线Sha256加密:http://convertstring.com/zh_CN/Hash/SHA256

/**
 * @description: SHA-256 或 SHA-244
 * @param {type} 
 * @return: 
 */
static void TaskSha256(void *parm)
{
    int i;

    unsigned char decrypt[32];
    const unsigned char encrypt[] = "https://github.com/xuhongv";
    // sha256/224
    ESP_LOGI(LOG_TAG, "Sha256 要加密数据: %s", encrypt);
    mbedtls_sha256_context sha256_ctx;
    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, decrypt);
    ESP_LOGI(LOG_TAG, "Sha256 加密后数据: ");
    for (i = 0; i < 32; i++)
    {
        printf("%02x", decrypt[i]);
    }
    mbedtls_sha256_free(&sha256_ctx);
    vTaskDelete(NULL);
}

1.5 AES-CBC 加密解密

    下面是对字符串变量encrypt加密,参考网址对比如下:
    在线CBC加密:http://tool.chacuo.net/cryptaes

/**
 * @description: 
 * @param {type} 
 * @return: 
 */
static void TaskAESCBC(void *parm)
{
    int i;

    mbedtls_aes_context aes_ctx;

    //密钥数值
    unsigned char key[16] = {'c', 'b', 'c', 'p', 'a', 's', 's', 'w', 'o', 'r', 'd', '1', '2', '3', '4'};
    //iv
    unsigned char iv[16];

    //明文空间
    unsigned char plain[64] = "https://github.com/xuhongv";
    //解密后明文的空间
    unsigned char dec_plain[64] = {0};
    //密文空间
    unsigned char cipher[64] = {0};

    mbedtls_aes_init(&aes_ctx);

    //设置加密密钥
    printf("plain:%s\r\n", plain);
    mbedtls_aes_setkey_enc(&aes_ctx, key, 128);
    for (i = 0; i < 16; i++)
    {
        iv[i] = 0x01;
    }
    mbedtls_aes_crypt_cbc(&aes_ctx, MBEDTLS_AES_ENCRYPT, 64, iv, plain, cipher);
    printf("cipher:\r\n");

    for (i = 0; i < 64; i++)
    {
        printf("%02x", cipher[i]);
    }
    printf("\r\n");
    //设置解密密钥
    mbedtls_aes_setkey_dec(&aes_ctx, key, 128);
    for (i = 0; i < 16; i++)
    {
        iv[i] = 0x01;
    }
    mbedtls_aes_crypt_cbc(&aes_ctx, MBEDTLS_AES_DECRYPT, 64, iv, cipher, dec_plain);
    printf("dec_plain:%s\r\n", dec_plain);
    printf("\r\n");
    mbedtls_aes_free(&aes_ctx);

    vTaskDelete(NULL);
}
  • 注意偏移量为十六进制,操作截图:
    在这里插入图片描述

二、其他

  • 下面记下AES加密类型一览表:
算法/模式/填充 字节加密后数据长度 不满16字节加密后长度
AES/CBC/NoPadding 16 不支持
AES/CBC/PKCS5Padding 32 16
AES/CBC/ISO10126Padding 32 16
AES/CFB/NoPadding 16 原始数据长度
AES/CFB/PKCS5Padding 32 16
AES/CFB/ISO10126Padding 32 16
AES/ECB/NoPadding 16 不支持
AES/ECB/PKCS5Padding 32 16
AES/ECB/ISO10126Padding 32 16
AES/OFB/NoPadding 16 原始数据长度
AES/OFB/PKCS5Padding 32 16
AES/OFB/ISO10126Padding 32 16
AES/PCBC/NoPadding 16 不支持
AES/PCBC/PKCS5Padding 32 16
AES/PCBC/ISO10126Padding 32 16

       有任何疑问联系本人下方邮箱或加qq群或文章留言,不要私信我,我已经屏蔽私信!多多支持!

       本博文对应的源码获取 请关注本人的微信公众号回复 191214 获取,谢谢!


另外,不要把我的博客作为学习标准,我的只是笔记,难有疏忽之处,如果有,请指出来,也欢迎留言哈!

  • 玩转esp8266带你飞、加群付费QQ群,不喜的朋友勿喷勿加:434878850
  • 个人邮箱:[email protected] 24小时在线,有回必回复!
  • esp8266源代码学习汇总(持续更新,欢迎star):https://github.com/xuhongv/StudyInEsp8266
  • esp32源代码学习汇总(持续更新,欢迎star):https://github.com/xuhongv/StudyInEsp32
  • 关注下面微信公众号二维码,干货多多,第一时间推送!
发布了152 篇原创文章 · 获赞 785 · 访问量 79万+

猜你喜欢

转载自blog.csdn.net/xh870189248/article/details/103539421
今日推荐