哈希算法,常称MD5是一种单向散列函数,单向散列函数的作用是将任何长度的一段数据散列成固定长度。常用于生成消息认证码等等,可以与非对称算法一起用于数字签名。
MD5据说已经被国内一名教授破解,不知真假,即便真的如此,但足以满足UBOOT的可靠性需求了。
UBOOT命令行加密是比较简单的问题(main_loop()),但是如何确保看到的代码的人及LINUX系统管理员无法通过环境变量获取密码呢,加入哈希加密算法,也叫MD5算法,大大提高了UBOOT命令行的可靠性:
头文件md5.h
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
#ifndef MD5_H
#define MD5_H
typedef
struct
{
unsigned
int
count[2];
unsigned
int
state[4];
unsigned
char
buffer[64];
}MD5_CTX;
#define F(x,y,z) ((x & y) | (~x & z))
#define G(x,y,z) ((x & z) | (y & ~z))
#define H(x,y,z) (x^y^z)
#define I(x,y,z) (y ^ (x | ~z))
#define ROTATE_LEFT(x,n) ((x << n) | (x >> (32-n)))
#define FF(a,b,c,d,x,s,ac) \
{ \
a += F(b,c,d) + x + ac; \
a = ROTATE_LEFT(a,s); \
a += b; \
}
#define GG(a,b,c,d,x,s,ac) \
{ \
a += G(b,c,d) + x + ac; \
a = ROTATE_LEFT(a,s); \
a += b; \
}
#define HH(a,b,c,d,x,s,ac) \
{ \
a += H(b,c,d) + x + ac; \
a = ROTATE_LEFT(a,s); \
a += b; \
}
#define II(a,b,c,d,x,s,ac) \
{ \
a += I(b,c,d) + x + ac; \
a = ROTATE_LEFT(a,s); \
a += b; \
}
void
MD5Init(MD5_CTX *context);
void
MD5Update(MD5_CTX *context,unsigned
char
*input,unsigned
int
inputlen);
void
MD5Final(MD5_CTX *context,unsigned
char
digest[16]);
void
MD5Transform(unsigned
int
state[4],unsigned
char
block[64]);
void
MD5Encode(unsigned
char
*output,unsigned
int
*input,unsigned
int
len);
void
MD5Decode(unsigned
int
*output,unsigned
char
*input,unsigned
int
len);
#endif
|