请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。; l3 T, k! K9 z, i" d
MD5的用途主要有:
; M, D$ X! o7 t; Q% I: P一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出: \* Z0 a6 R' Y
新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。6 N \+ f1 N* W' x, }. z+ k
数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。
, _ s4 R9 ?; c/ n6 t; A密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储
; n% b0 S! R; b4 ?6 H0 g9 }明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为:
4 ^$ [! G4 x& k5 D5 o2 K( p2 d; Y[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e)- V" J& L. }# K$ M! F
{
; B! h! H' m8 x1 F/ S7 q string plainPassword = "innovator";
5 n0 v0 i! s% ?& W# b; [* L
$ \8 f( D8 Y# I1 j9 D+ b( F) J; ` System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
7 Y# @# ]2 ^5 H- d( z: O% F System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();
P% D- f$ q# H8 ?1 |$ d% L byte[] data = ascii.GetBytes(plainPassword); n. w) l) W9 C# o& h* l
byte[] result = md5.ComputeHash(data);
: c. U8 z5 v) V) l" Y: [2 { // Convert the MD5 result to Hexadecimal string
, @) {* h& O9 C: o. H& |" N+ u5 o9 Q0 u2 ~; }7 _
string MD5Password = BinaryToHex(result);3 q2 e$ T% O! b# U/ E
string aa = "";
3 e/ @* {" x6 f6 J" d }[/mw_shl_code]
& ^/ l& h4 W% F3 P/ h& Q[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray)$ t: p x0 L, u6 _( F( s) ~
{
5 Z' }8 V7 O6 @! a3 g! v( S string result = "";
- x1 q( ?& v5 f0 j4 K$ d) v long lowerByte;
$ m+ ~" Y4 d, k8 Q long upperByte;
0 _% v' g e8 G$ P0 @: Z4 C6 ^
6 E+ v* s: O7 X* W5 P5 ] foreach (Byte singleByte in BinaryArray)$ ^: \( Z& b# Y' J- h' V
{* a* s* z6 s6 q; N
lowerByte = singleByte & 15;
( p4 Q5 ^ C$ B% x: E" J upperByte = singleByte >> 4;3 c0 f, P4 u( H: F, r8 h5 e; X
/ h$ O# v: f/ g9 w, _' n result += NumberToHex(upperByte);4 o7 C* @5 L0 J% K4 [6 k
result += NumberToHex(lowerByte);; N# M8 ~$ Z, H- Y$ p2 \1 t7 Y
}- l5 C) x' T% A+ m
return result;9 }* f2 ~% y7 d* M x3 v9 r. g5 z
}[/mw_shl_code]
1 ?' q4 ]0 O# n t$ w[mw_shl_code=csharp,true]private static char NumberToHex(long Number)
7 b' M$ Z: ~2 d J8 K4 l { [+ f' u9 p. u7 c4 O* O [' A1 ?
if (Number > 9)
2 d2 e5 m4 U$ E' T. n return Convert.ToChar(65 + (Number - 10));+ a M n3 m8 U) s. g
else
" v2 f k) d* w: z( {6 S return Convert.ToChar(48 + Number);
" S5 g$ c0 Q& M' a, v }[/mw_shl_code] ! i0 c) Z* t9 i+ A+ e# \3 W
|