ESP8266之MD5加密

MD5算法原理:

MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。
1.填充(使其位长对512求余的结果等于448,并且填充必须进行,即使其位长对512求余的结果等于448。因此,信息的位长(Bits Length)将被扩展至N*512+448,N为一个非负整数,N可以是零。)

填充的方法如下:

  1. 在信息的后面填充一个1和无数个0,直到满足上面的条件时才停止用0对信息的填充。
  2. 在这个结果后面附加一个以64位二进制表示的填充前信息长度(单位为Bit),如果二进制表示的填充前信息长度超过64位,则取低64位。
    经过这两步的处理,信息的位长=N*512+448+64=(N+1)*512,即长度恰好是512的整数倍。这样做的原因是为满足后面处理中对信息长度的要求。
  • MD5加密后有16位和 32位,没有加密密钥
  • HmacMD5加密后仅仅有 32位,但是有加密密钥

折叠MD5加密字符串实例


现以字符串"jklmn"为例。

该字符串在内存中表示为:6A 6B 6C 6D 6E(从左到右为低地址到高地址,后同),信息长度为40 bits, 即0x28。

对其填充,填充至448位,即56字节。结果为:

6A 6B 6C 6D 6E 80 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00

剩下64位,即8字节填充填充前信息位长,按小端字节序填充剩下的8字节,结果为。

6A 6B 6C 6D 6E 80 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 28 00 00 00 00 00 00 00

(64字节,512 bits)

初始化A、B、C、D四个变量。

将这64字节填充后数据分成16个小组(程序中对应为16个数组),即:

M0:6A 6B 6C 6D (这是内存中的顺序,按照小端字节序原则,对应数组M(0)的值为0x6D6C6B6A,下同)

M1:6E 80 00 00

M2:00 00 00 00

.....

M14:28 00 00 00

M15:00 00 00 00

经过"3. 分组数据处理"后,a、b、c、d值分别为0xD8523F60、0x837E0144、0x517726CA、0x1BB6E5FE

在内存中为a:60 3F 52 D8

b:44 01 7E 83

c:CA 26 77 51

d:FE E5 B6 1B

a、b、c、d按内存顺序输出即为最终结果:603F52D844017E83CA267751FEE5B61B。这就是字符串"jklmn"的MD5值。

参考链接:
MD5:https://baike.so.com/doc/7185663-7409786.html?from=208667&sid=7409786&redirect=search#7185663-7409786-3_2
MD5在线加密:https://md5jiami.51240.com
HMACMD5 :https://baike.so.com/doc/4404442-4611453.html
HmacMD5在线加密:http://tools.jb51.net/password/hash_encrypt

XH_MD5.c

开始加密

  • strContent:要加密的数据
  • iLength:要加密的数据的长度
  • typeMd5:16表示生成16位32表示生成32位
  • outBuffer:要接收的字符串
/*
 - filename: XH_MD5.c
 */

#include "user_config.h"

#include "XH_Md5.h"

#define STRLEN	strlen
#define STRNCMP strncmp
#define MEMSET	memset
#define STRNCPY	strncpy
#define MALLOC	malloc
#define FREE	free

unsigned char PADDING[] = { 0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
		0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
		0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };

void XH_MD5Init(XH_MD5_CTX *context) {  
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的 ESP8266 开发百度翻译 API 的示例代码: ```c++ #include <ESP8266WiFi.h> #include <WiFiClientSecure.h> #include <ArduinoJson.h> // 请将下面的 APP_ID 和 SECURITY_KEY 替换为你自己的 const char* APP_ID = "YOUR_APP_ID"; const char* SECURITY_KEY = "YOUR_SECURITY_KEY"; const char* WIFI_SSID = "YOUR_WIFI_SSID"; const char* WIFI_PASSWORD = "YOUR_WIFI_PASSWORD"; const char* TRANSLATE_API_HOST = "fanyi-api.baidu.com"; const int TRANSLATE_API_PORT = 443; const char* TRANSLATE_API_URL = "/api/trans/vip/translate"; WiFiClientSecure client; void setup() { Serial.begin(115200); WiFi.begin(WIFI_SSID, WIFI_PASSWORD); while (WiFi.status() != WL_CONNECTED) { delay(1000); Serial.println("Connecting to WiFi..."); } Serial.println("Connected to WiFi"); client.setInsecure(); } void loop() { String input = "hello world"; String output = translate(input, "en", "zh"); Serial.println(output); delay(1000); } String translate(String q, String from, String to) { String url = String(TRANSLATE_API_URL) + "?q=" + q + "&from=" + from + "&to=" + to + "&appid=" + APP_ID + "&salt=" + String(random(1000000)) + "&sign=" + getSign(q); Serial.println("Sending request to " + String(TRANSLATE_API_HOST) + ":" + String(TRANSLATE_API_PORT) + url); if (!client.connect(TRANSLATE_API_HOST, TRANSLATE_API_PORT)) { Serial.println("Connection failed"); return ""; } client.print(String("GET ") + url + " HTTP/1.1\r\n" + "Host: " + TRANSLATE_API_HOST + "\r\n" + "User-Agent: ESP8266\r\n" + "Connection: close\r\n\r\n"); String response = ""; while (client.connected()) { String line = client.readStringUntil('\n'); if (line == "\r") { break; } } while (client.available()) { response += (char) client.read(); } Serial.println("Response:"); Serial.println(response); DynamicJsonDocument json(1024); deserializeJson(json, response); String dst = json["trans_result"][0]["dst"].as<String>(); return dst; } String getSign(String q) { String str = String(APP_ID) + q + String(random(1000000)) + SECURITY_KEY; char buf[33]; char *hash = buf; byte i; // 计算 MD5 散列值 MD5Builder md5; md5.begin(); md5.add(str); md5.calculate(); md5.getBytes(hash); // 将散列值转换为十六进制字符串 String sign = ""; for (i = 0; i < 16; i++) { sign += String(hash[i], HEX); } return sign; } ``` 在这个示例代码中,我们使用了 ESP8266 的 WiFiClientSecure 库来建立一个加密连接。我们还使用了 ArduinoJson 库来解析 JSON 格式的响应。 首先,我们需要将 APP_ID 和 SECURITY_KEY 替换为自己的百度翻译 API 应用 ID 和密钥。然后,我们需要将 WIFI_SSID 和 WIFI_PASSWORD 替换为自己的 WiFi SSID 和密码。 在 loop() 函数中,我们调用 translate() 函数来进行翻译。这个函数接受三个参数:待翻译的字符串 q、原语种 from 和目标语种 to。它会发送一个 HTTP GET 请求到百度翻译 API,然后返回翻译结果。 在 translate() 函数中,我们首先构建了一个 API 请求 URL,并使用 getSign() 函数计算签名。然后,我们使用 client.connect() 函数建立一个加密连接,并使用 client.print() 函数发送 HTTP GET 请求。最后,我们使用 client.readStringUntil() 和 client.read() 函数读取响应,并使用 deserializeJson() 函数解析 JSON 格式的响应。 getSign() 函数用于计算签名。它接受一个待翻译的字符串 q,并使用 APP_ID、q、随机数和 SECURITY_KEY 计算 MD5 散列值,并将散列值转换为十六进制字符串作为签名。 这是一个简单的 ESP8266 开发百度翻译 API 的示例代码。你可以根据自己的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值