请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。; ?" ], A; Y5 d4 A
MD5的用途主要有:. m4 z( \ j" y1 B* y& _
一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出
* q9 K$ z7 L! \5 @% q. _1 M新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。
* a$ Y: o5 ?: h2 S数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。
" [0 p0 h% g; F, c7 _+ |密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储
$ R# C1 C: t/ n2 a明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为:
3 B2 P: t& T! x[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e): f! N( [7 N( c3 D' v
{3 j1 `* b+ ~6 ]
string plainPassword = "innovator";5 w2 C* G9 f: }$ h, q z7 t
: d, a& N* b8 L7 A System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
6 O3 l, E3 w- h3 c. K a+ }9 }4 F' D System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();/ o/ Z4 N/ H. Z6 [
byte[] data = ascii.GetBytes(plainPassword);+ E+ d- h! W) {4 L8 _. p8 _! v! q8 j
byte[] result = md5.ComputeHash(data);
6 c& t( O2 D- C. D' J6 H2 }: C# m // Convert the MD5 result to Hexadecimal string
( L6 w0 e1 T1 \3 {( L7 X
3 x& R K/ c# ]9 D. _ string MD5Password = BinaryToHex(result);- G/ K& E& z8 e# b \) ^
string aa = "";
9 U4 b& W& A" }. q1 a5 v, Z }[/mw_shl_code] " d5 G6 ~1 O6 r; [) Q& b) k" W
[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray)
: d+ K( f7 ~+ q2 p {
$ Y9 M4 m0 j( _, G% U: v3 Q string result = "";
: t7 H* F5 f- O; Z6 c/ v long lowerByte;" m( c! ~" e9 p& s. Q6 }% ]" r p
long upperByte;0 r$ X* R; D' Q4 C
4 C9 v& P' ?' R5 z0 _ foreach (Byte singleByte in BinaryArray)
. {3 i- u3 }' S8 j" \/ E9 V8 e {8 i- F1 M9 [7 m. L! e9 ^( _% K" H7 u
lowerByte = singleByte & 15;, b& a0 K6 p3 b1 j+ X, A3 t
upperByte = singleByte >> 4;
8 @/ y* c$ s6 ]5 y! `4 V
( M9 d) c& C1 Y3 h: v* J2 Q result += NumberToHex(upperByte);
; N2 a# @: c y' W, C result += NumberToHex(lowerByte);* V5 l7 B1 |, u+ J; q
}$ L* m5 Z5 `; C+ g7 L$ }
return result;! T! w7 n0 K ~( F
}[/mw_shl_code] * {" ?$ S8 g+ I6 |
[mw_shl_code=csharp,true]private static char NumberToHex(long Number)
/ Z4 E* n8 N( F* N) R {
. G2 L2 U; c+ W3 k! D7 u if (Number > 9)
# N ~, Z* R9 K return Convert.ToChar(65 + (Number - 10));
# u8 N! b9 U X else9 Y1 s; m8 k( U2 S
return Convert.ToChar(48 + Number);2 C) n2 {: s- U' |6 c" ?
}[/mw_shl_code]
m8 U1 |' E* N6 Z9 @% ^0 d |