请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。& j( D- O4 A Z$ ~! x( v& x
MD5的用途主要有:* _( b6 q6 K# s, Q$ e0 w
一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出
. @' P$ O0 }" Q0 \' [/ ^7 R/ J: A新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。$ X# l1 h- V& Z5 V
数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。- V& P( g) @6 _" y4 Z
密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储) z' u# I" ~9 I. D+ O0 V) I. d
明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为:
1 }% I# v' r' g3 N[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e)
0 F" u) d3 h j8 W- i q& l$ k5 s {
; I* S2 Z+ T8 V5 `- C" I& V& p string plainPassword = "innovator";/ B8 q9 |, S8 [' X$ S- d9 ?/ y
/ ^9 ^7 d! J5 X
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
- F7 V/ D% s# i System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();
7 D- x$ O0 d7 ]1 h' P0 y$ R" A2 B byte[] data = ascii.GetBytes(plainPassword);; A+ o) r: B) @* a+ Q7 Q6 |" l
byte[] result = md5.ComputeHash(data);
' p) x( w u/ F. r // Convert the MD5 result to Hexadecimal string
, A3 K4 J1 n7 |( H% u2 v# \, D& u# e& h9 K& l
string MD5Password = BinaryToHex(result);6 S1 M! Q0 N* o/ Y8 z2 J: L/ F
string aa = "";3 t: a7 x6 F% w0 f0 H, Q# ]
}[/mw_shl_code]
! Q9 J {4 u% t/ B; s, n4 k[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray): N' Q4 b1 u; @! ^5 v$ s3 D# i; V" `6 o
{- k! S1 H+ V; y- `1 u
string result = "";
; T8 W$ [9 n1 N2 s4 [ long lowerByte;
* A5 y- x) A* Q/ E long upperByte;
4 y1 [+ j) k; [& D8 j) C& e7 M8 u
- a6 d) V1 r- o3 A" ~ foreach (Byte singleByte in BinaryArray)4 ?7 [4 ?1 x! P3 [- b
{ N3 n7 w1 Z5 I) i
lowerByte = singleByte & 15;& b1 {: ?, H. t
upperByte = singleByte >> 4;
# ?, u1 O! r( V6 D$ C4 k# W$ [) D6 e: F9 _1 s
result += NumberToHex(upperByte);
( O! @4 F( l7 Q, O. u9 @- F( f0 M result += NumberToHex(lowerByte);
( u# ^% w0 U( o+ ]2 A: k* s: k }) E! r1 @) W, {3 i
return result;
2 U3 b5 e" y' w) w3 a, g }[/mw_shl_code] 3 X9 W1 A( m7 P4 W0 i3 {! B, {
[mw_shl_code=csharp,true]private static char NumberToHex(long Number)( Y, y2 C$ R9 \7 l& |, u
{" x( V* Y9 T4 A! X
if (Number > 9)
8 H& S2 k0 P; d return Convert.ToChar(65 + (Number - 10));& I) q# T: d2 I
else
+ h: J D1 H H% u return Convert.ToChar(48 + Number);3 z/ \6 |3 r5 x+ g G% M% ]5 f! `
}[/mw_shl_code]
4 k. X4 ?; ?$ ^1 E) f/ X |