请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。
- I, _$ x6 E5 j% U' NMD5的用途主要有:1 J3 Z, C4 }. ^4 s' I h u6 h, o
一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出
, _; ^3 g4 ~- u3 N新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。( d- g( \( P+ }' U, B6 {
数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。" C; @! s+ Z0 G/ G
密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储- j# e4 [3 |& x( s
明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为: ! [7 f& i8 K# G; V! ?9 N* L$ G
[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e)% j# h$ M2 D( {1 ^$ {$ B8 {
{, J2 D' Y- Z+ q
string plainPassword = "innovator";8 {/ E7 `7 T* Q
/ M y: S" C* Y: ~6 |) | System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
0 z" g4 @/ x- W6 N2 }1 q System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();
. A4 Q) @# v0 s. a3 \ byte[] data = ascii.GetBytes(plainPassword);) {# s9 [' U9 Q, h" X/ |0 x
byte[] result = md5.ComputeHash(data);, j, ^/ Y0 Y% E7 ^9 l
// Convert the MD5 result to Hexadecimal string' i. R! F! B% z H/ b
+ H4 L+ w" V9 g Z: s4 l
string MD5Password = BinaryToHex(result);% H' {: J9 s+ J2 f5 D- L! z7 B
string aa = "";
! o* ~+ |! S- _# W }[/mw_shl_code] 5 g+ K% A$ @- [* s
[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray)
5 s8 U+ Q( S. D- _3 y2 x/ |1 K }( G {+ N$ V* U) {; L, i: n6 x) g
string result = "";( X1 w3 w7 J! E# `5 A0 k
long lowerByte;
6 J9 u( ~6 ]6 g' W5 w long upperByte;
+ i8 e' i1 I5 f
& j4 l2 e# n# Y( M2 u* j4 K foreach (Byte singleByte in BinaryArray)* s# \6 ~& O5 j( {
{8 u. E" w4 ]* M. v h q0 Q* c
lowerByte = singleByte & 15;
& }& |" a8 L% } upperByte = singleByte >> 4; C- T) j1 J, ]$ M. c1 B
6 [+ y: p& ?! u( i, M9 Y result += NumberToHex(upperByte);. b; t" u: i6 L/ T8 M3 t6 a7 s- y
result += NumberToHex(lowerByte);8 |7 [- \; j+ G$ d4 }, ~ t9 z
}
% J( m+ S: h: M& i( L- a return result;6 G7 \0 B! `) i6 W! _' h; _: d; ~$ h
}[/mw_shl_code]
! Y. A1 v$ A# e ~' O, F+ }[mw_shl_code=csharp,true]private static char NumberToHex(long Number). ]$ G1 a2 L/ x: }: d, b/ o
{
! E6 w5 \) n8 _- W% N" E if (Number > 9)9 y6 X' n& b1 U' g, v" [/ a: y
return Convert.ToChar(65 + (Number - 10));
% A; I# o% c- C( k5 P8 p/ N else; ]. \3 a1 {- U$ r7 Z+ j
return Convert.ToChar(48 + Number);) X* w% {' r- h/ p3 u( j
}[/mw_shl_code]
6 n ~' U5 x2 _2 F% C |