请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。
0 o* d( k; D7 YMD5的用途主要有:
8 e; {3 \# L7 ]/ H" f2 o/ v6 A8 Y2 F一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出! L2 \ i4 x- U! v
新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。0 T- B3 _5 A' k3 h
数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。( G* N+ g$ @2 ^$ C8 W2 [+ ]
密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储$ Q: R; Z- h7 N$ Z
明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为: & f+ M1 s+ K$ x/ V/ M
[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e); P- g. C m8 Z! m" _; Z
{
8 L6 J' ~$ [, E+ Q2 H- B string plainPassword = "innovator";
* t* A1 t. M' M# T
; e. e- b3 m# U6 A7 S6 ] System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
7 v. |* y5 Q4 V2 x System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();! [1 d/ E8 b) i% p# b$ Q
byte[] data = ascii.GetBytes(plainPassword);
% k5 o& g* \' C0 Z9 ` byte[] result = md5.ComputeHash(data);
) X' |2 q. q7 ]7 J. Q5 U // Convert the MD5 result to Hexadecimal string
2 @4 m7 G9 A6 @- ^
; N/ b0 b1 L! X( E. i6 b$ K string MD5Password = BinaryToHex(result);+ ?) O- {7 H. T" L/ U5 C
string aa = "";" G4 B% z- H, C/ a- w# h3 {8 l2 j- A
}[/mw_shl_code] . T8 v: }# d* U, ]* F
[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray)
6 x; Z+ P2 n( O+ Z. @' R {
5 f `! q. Q. H" C; j string result = "";
2 `# F% Y4 y. t) F/ v( v: N long lowerByte;5 p3 [( k2 _* C6 u# i V1 M
long upperByte;
& H* M/ ?: q$ u1 E9 g. K( L }2 w
|$ D- K0 \; E Y1 V% F& p foreach (Byte singleByte in BinaryArray)
4 _2 {- Q9 [; Q M6 y3 s {* B! o2 s2 X: P
lowerByte = singleByte & 15;( J, X3 G& y7 h
upperByte = singleByte >> 4;6 t& s# |2 I$ I
; M$ ^! a( y: K$ X# R# e* W6 D+ O& p result += NumberToHex(upperByte);
$ x5 {' u* ]: Z. v$ ^, z3 z result += NumberToHex(lowerByte);' L2 {3 d7 w; X- |
}; c& v/ y& e) q. |
return result;
3 ^# q: M+ }6 H/ x! b }[/mw_shl_code]
" i1 ?8 B5 N p8 A5 u* c" J) K[mw_shl_code=csharp,true]private static char NumberToHex(long Number)
2 j( q9 Z/ a) | {1 n- V+ Z `+ W6 h8 Y ~
if (Number > 9)
& n7 ?! K7 @4 k' R return Convert.ToChar(65 + (Number - 10));6 V* \. g' B8 }' k8 z4 O8 R
else# {( Z, e( w! ^: o5 B
return Convert.ToChar(48 + Number);
0 q# y) ~+ S5 f% n6 k# x& k, h6 n }[/mw_shl_code]
* F7 X/ m. n p$ ` |