请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。
0 m: w8 }% k& ?* {& P, gMD5的用途主要有:
/ i4 E' i4 i9 B7 Q" D0 K C( ?一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出 z: R% a$ h# Q6 Q& ^
新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。
- S f% W1 r8 m- |' v. o9 N数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。
: \7 V# f7 {0 J* P* U; s$ \0 @密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储$ p9 z" {, E" y1 t" g4 j% b% y8 }
明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为: / m+ H6 w! {/ e
[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e)
7 E. Y* ^) A, Y {( b+ k: K8 C9 C8 j( }4 Y
string plainPassword = "innovator";4 L. [$ p4 V% @1 A* C s/ F
8 X* R3 V1 Z+ g( [0 z0 p j System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
$ r. i+ g! c [# Y" D& J System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();5 T4 t2 |# a" W# M
byte[] data = ascii.GetBytes(plainPassword);
+ @+ |. c) }( z5 p byte[] result = md5.ComputeHash(data);# x, B3 }/ y: G6 m, f: }5 B6 U
// Convert the MD5 result to Hexadecimal string! W2 g) A/ l4 B( \9 Z
3 `" T% D3 r% V# r$ Y
string MD5Password = BinaryToHex(result);4 \0 f0 M) y, N+ |4 j4 S* A$ M+ N
string aa = "";% m" m1 }, A7 p) N* `7 _3 p
}[/mw_shl_code] 5 `1 Y% n1 |, x. t* l) K0 g8 N
[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray)
) t! R$ l# Q: b' }8 E8 s z5 a {
& x, }, `9 w5 y8 \0 E9 S9 U: u string result = "";: O8 C& J& Q2 k% K) a) r
long lowerByte; g: o; y" S! z% h
long upperByte;. k1 a& K6 @9 Q* A% q- a- ?- F% O: @; x
7 w: g( g+ {3 z
foreach (Byte singleByte in BinaryArray)
% M, @8 b/ k1 k, O% I( Y {5 b+ I. L" {/ l* I- I2 v) m8 D; x
lowerByte = singleByte & 15;, w4 I; B8 `" y: B/ M
upperByte = singleByte >> 4;4 i9 t" K5 n' ?! Y$ l; d
+ ~" S* E: b' E
result += NumberToHex(upperByte);6 \, |; i3 D0 B' I/ h! r; j
result += NumberToHex(lowerByte);" E/ o4 n, S# x$ b- b
}- Y5 f+ ~; r( s
return result;
* `- _( ~1 c1 Z: H, C$ q; o }[/mw_shl_code]
. Z+ A/ E# [& O% u[mw_shl_code=csharp,true]private static char NumberToHex(long Number)( |& p) R7 q( G! i
{
* R% M$ l8 B* U3 a8 i! z5 q if (Number > 9)" R( X8 c# w5 D+ U
return Convert.ToChar(65 + (Number - 10));3 a/ R* [$ N* c
else0 Q' ^9 O: D1 [/ I
return Convert.ToChar(48 + Number);
5 ^' U( z/ i) X4 O+ O r }[/mw_shl_code] 0 i1 C4 N) E& r2 Y5 O
|