请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。
* i. h3 q p% N1 GMD5的用途主要有:! |5 T/ j4 _/ x6 c" G
一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出
) w4 y9 I- O9 ] l8 H新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。
' g4 u/ }8 a3 N( c2 z+ ]+ R3 y数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。
' s/ }' v7 O; G. X' O( ]0 B" j密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储
6 q" m: D. w$ y0 `; c: m明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为:
( f* ?1 ]- a0 x. z+ Y' }[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e)
4 U' J8 X4 V7 I, I O- k {
8 ]( N/ j+ Z6 Y5 [0 E: u string plainPassword = "innovator";
- S! Z ]3 G. D" J/ J7 N1 c( Y- H# L. I9 a. D9 O7 ]5 M0 s
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
" X8 z# c) f, p" t3 p System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();( S* i$ I( }8 d$ F$ ^
byte[] data = ascii.GetBytes(plainPassword); ], }6 D$ ^% Y) o
byte[] result = md5.ComputeHash(data);' r- q$ V1 l- Q7 X5 C
// Convert the MD5 result to Hexadecimal string( \" z1 ^# T; C6 ?& |# V2 f
; o% }/ `* B( R+ j! {: y& t string MD5Password = BinaryToHex(result);0 \, K( O+ z/ Y$ y _
string aa = "";
- R+ e3 R' \; M- ]% N }[/mw_shl_code]
- r8 g% r; D' |5 y0 A[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray). P' q; P! ^/ G8 b4 I
{
9 Y. `* A. R0 j/ [2 H; t string result = "";" t% \/ n6 K8 o% u
long lowerByte;
( _5 c# Y! G) L$ T2 m8 p3 p long upperByte;( m7 v7 o2 D7 N& p7 ?
4 `) ]$ j; |# e) i/ w: A foreach (Byte singleByte in BinaryArray); } T5 }1 i5 ^5 A( s+ ]: U
{4 ~: v% i" }+ T- F# ]7 h' T
lowerByte = singleByte & 15;
2 u' r$ A2 t p4 u: r upperByte = singleByte >> 4;& D1 {/ ]4 c/ E# n1 g5 C" I
- W4 @' ~- I% O2 V result += NumberToHex(upperByte);
% k/ _ ?6 o8 D. \, i8 U2 l result += NumberToHex(lowerByte);
" m+ V8 k6 F- ]3 ^: J- }# C+ b }
$ G/ K5 N; A4 ^" K' U% { return result;
. j9 M* D. X, ?% W4 S* V9 B I }[/mw_shl_code] ! Q8 N3 J4 i, g/ Y
[mw_shl_code=csharp,true]private static char NumberToHex(long Number)! V& t' n6 n1 h/ J% h- E
{
' o9 Q3 o8 r: [& b" P3 V if (Number > 9): D; Y# A9 N4 F
return Convert.ToChar(65 + (Number - 10));9 a( s" {/ s0 \' t5 q- \
else
9 L6 q; O: O1 [ return Convert.ToChar(48 + Number);
5 y! p3 F" X. F' s; V' k }[/mw_shl_code]
: a: h8 u8 c9 I |