请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。
# B- G2 Y( _* B( w7 z3 b8 u! JMD5的用途主要有:
) j8 @! M$ M/ q( j* v# [一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出
; G# }1 U7 o! G6 n3 A3 C新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。( ?" }. X! u% t% G- p
数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。% \& y$ ~5 v8 J) ?, K4 q" b; s/ ?1 T
密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储' N+ o. ?( n; M# v. S$ u
明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为:
% m5 P& O- m3 J. k% [* n[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e)
~- D1 ~1 h3 M5 y2 i6 o+ ~1 S4 ^* r {
) S) v3 ~$ {* B# ?# O9 y: O string plainPassword = "innovator";
; X; {- R0 [. F, B" S* J: u- ~1 l
7 I! ^+ m, D% a/ m! W' o) t% a3 i$ e System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
6 @% `8 F+ {; U; r" B; v! j$ X System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();
3 n! S4 a: ^) a, Y* T! H byte[] data = ascii.GetBytes(plainPassword);. T8 C a! d8 X) c+ ~
byte[] result = md5.ComputeHash(data);) V2 U8 ?/ h" V! c: G, ~+ y
// Convert the MD5 result to Hexadecimal string* C2 f/ o% b6 [1 i
5 x+ o' o: K: e( q, h string MD5Password = BinaryToHex(result);
! v9 m; w4 v" F2 T string aa = "";' e6 W4 B3 s- F
}[/mw_shl_code] + \! b' C$ ]/ C" x7 t, M$ b
[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray)
) v+ ~# v6 B; Y: ]5 l3 G5 i( N {
6 c5 ^- G9 s8 \% u/ t' K5 W string result = "";
9 h. }* ]# b* P7 a# _/ A6 z long lowerByte;
- v. v- \- `8 ]3 F, z long upperByte;8 \/ U/ ~4 V! x- Z) Q( g- v: R ~
7 y' \+ g' J! d' f foreach (Byte singleByte in BinaryArray)
& ?1 H) E8 T5 |) l1 ] {" A. ]6 h$ b- N1 o9 O
lowerByte = singleByte & 15;
0 ]+ [- Q$ A- q& n2 } upperByte = singleByte >> 4;
2 i* s2 n' r6 b/ N8 N
G1 n5 K8 K: o. p7 h# b2 j& L: X result += NumberToHex(upperByte);5 M; r1 t6 k/ ^5 |7 U
result += NumberToHex(lowerByte);9 |+ u% a# X! G5 M. r& n
}8 X, C# \' l$ D7 V: I, {* S T
return result;8 b( D5 m: V" P3 t. n9 U
}[/mw_shl_code] ; x& z4 G1 x/ D! h- n" H8 C
[mw_shl_code=csharp,true]private static char NumberToHex(long Number)
8 r+ ^1 a, k7 | {, h- s( t3 i: K4 R7 B% p2 E d
if (Number > 9)
! Z- E% ?* h2 ^8 @+ D" n4 z return Convert.ToChar(65 + (Number - 10));0 ^1 B0 S+ d' _% U. [& _
else
! Z" @0 l5 N4 L! A return Convert.ToChar(48 + Number);
$ V: q+ G5 b: A) h% I4 `- \ }[/mw_shl_code] 6 P8 S8 s* n$ b0 z. Q2 G- h
|