请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。
5 z6 l7 _. r2 d8 a5 @0 z& D( gMD5的用途主要有:
i, ~" Z4 c' D7 a一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出
/ E: b% {9 C! T5 N$ d新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。8 ^. i; x: L* p, L# M& s
数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。* j/ Y9 k1 ]+ m1 F f& L
密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储
3 } d' ]8 M, I" t& V2 ^明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为: / R+ r! w# G8 k+ v$ K
[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e): a2 ~( d" s4 j8 H) l, {
{
/ [) O/ S1 U6 d$ L string plainPassword = "innovator";' f* ]6 ^( h5 Q
+ X( {3 D7 \4 l W
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();, v4 ~# P! Q4 \; F3 O9 v: Z# i' ?
System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();
1 z, s" ]6 q- K) m) P8 T0 u byte[] data = ascii.GetBytes(plainPassword);
/ W3 y" _2 Y% R( }+ S6 S! L byte[] result = md5.ComputeHash(data);
a8 \: f8 p' _3 Y3 E) m5 S9 y+ } // Convert the MD5 result to Hexadecimal string$ i: j) J. X l8 L) k: D! |
2 {# L# L8 P+ {( ?% x string MD5Password = BinaryToHex(result);: a/ T( f- c% k8 e5 S4 v
string aa = "";5 N+ E' O) ?+ O( @1 I) s) F5 t+ H2 s
}[/mw_shl_code]
# t h4 T5 k1 J6 w" V6 d[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray): G) K4 c5 T$ O0 k7 o" Z
{" Q, X w9 Y4 _; ]% x9 e+ W1 Z) L
string result = "";# F' C( A6 P' ]1 d. D1 Y' x. F
long lowerByte;% z3 P3 \) y/ a
long upperByte;
7 T' T3 r4 ~8 ^/ Z" w# g) H$ `4 S& T, S# E; V5 K' \
foreach (Byte singleByte in BinaryArray)$ ~2 s1 o' f5 `, Z5 r# j
{2 l n, Y5 @2 O* A% c6 ?
lowerByte = singleByte & 15;5 |$ r6 C# F0 h5 ]( E
upperByte = singleByte >> 4;' h( R" e+ u% w& {
9 F% {$ m% r& q+ \- n
result += NumberToHex(upperByte);
5 j- A3 O* }2 P$ a result += NumberToHex(lowerByte);
) I7 h$ y0 i7 N9 W8 `0 p9 X8 M }
) F, G1 u0 h2 L return result;" T9 H: P8 e3 p1 d9 p
}[/mw_shl_code] 8 i6 f7 ~3 D4 k% ~
[mw_shl_code=csharp,true]private static char NumberToHex(long Number): e6 }+ U% [# S1 x B
{
, I2 g* R' t, \# Q8 O8 z7 G+ k if (Number > 9)
1 K4 u D8 i, y+ | return Convert.ToChar(65 + (Number - 10));$ f& h' `) o! y* R5 k) v$ ^
else
. g' s4 w( |8 s/ i return Convert.ToChar(48 + Number);
f y5 _4 w2 | }[/mw_shl_code] % ^* G& i. `) j6 R8 c
|