请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。
: }1 q Q2 g6 y8 TMD5的用途主要有:* @! i. e6 O% N( h6 u4 ~
一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出- p% U4 G/ t9 J0 Z* j7 z5 M4 r! @" T( j
新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。
' E+ I* m3 a1 U& q% ]数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。# o) ^* K( }; D! J' ^ ]
密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储: T. J" _3 E3 ]8 G3 ^; o
明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为:
7 s* G: j* r& S7 j[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e)$ L# B& B! h. [9 V# D
{1 n' r4 S+ V* s& }9 T
string plainPassword = "innovator";- E* C& |1 K7 i- D, d6 X6 v) O
5 w/ A! O' x# T1 Z System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
; s7 y% e) _7 v G9 x* Y1 ?1 h* c, W System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding(); @1 D& i/ z$ P$ q6 Q8 w, `
byte[] data = ascii.GetBytes(plainPassword);
) }' X: p& O' b2 b; ] byte[] result = md5.ComputeHash(data);
. o7 z* T) }0 @4 r% Y9 n // Convert the MD5 result to Hexadecimal string
0 {7 P5 ~/ `. |$ ~0 G8 f; c v+ ?+ [6 Y* L! O; z! B
string MD5Password = BinaryToHex(result);
& \& g# q# b2 K" x" l; J3 u string aa = "";5 o6 ^% h" |/ T7 ~
}[/mw_shl_code] & w! w) ?4 S( J3 M$ d7 {' q; H) H' K
[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray)
* t/ G( L+ L; T1 e {
: t+ k) p }, A string result = "";9 i D) V! u4 Y" {2 D
long lowerByte;
! m3 ~2 {' Z- Z long upperByte;2 s- H! D, h% }/ @7 i. L: a. T7 P
% c/ A! P/ j. m" G3 P( h9 {
foreach (Byte singleByte in BinaryArray)
8 L, B, O2 ?. y4 t8 t# i: S {
5 Q6 X3 w7 L3 Q- D+ e lowerByte = singleByte & 15;
" `) t9 I# e$ j8 }7 [+ N6 {. [3 @/ G upperByte = singleByte >> 4;
" e" G; s" \! o& a( I0 P6 [" F+ T
result += NumberToHex(upperByte);5 t7 f S! V; {6 D* E
result += NumberToHex(lowerByte);
! ]( u: i; ^, v }5 M8 w9 X, N- ?) \& D
return result;- [( B3 o5 H' ^9 o0 M& [6 _7 J
}[/mw_shl_code] ! k1 ~* @1 h$ H; U* y1 D( [
[mw_shl_code=csharp,true]private static char NumberToHex(long Number)$ m/ r! o! l3 I& f
{6 e2 q) M. Z# o; {% [( a) W# u- p7 N/ q
if (Number > 9)
: Y. M2 m) a( b4 d- N: s) B6 ]1 w return Convert.ToChar(65 + (Number - 10));
% P# B# c0 q) \; W else6 V' Y' _( l5 u- D. N* x6 e
return Convert.ToChar(48 + Number);
1 y! E! j1 o, M+ Q U9 E }[/mw_shl_code]
+ X6 P; Q: [2 O- o |