请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。
; n, N, X) ^* ?' D- OMD5的用途主要有:, c- W7 t# [& A$ L4 v
一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出
6 I4 S- T. E: @' }新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。
: z7 o& v6 P* @: R, ?3 J" l数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。" {; S+ F6 V6 I# i2 s
密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储
; B4 o; r. t& D4 y0 p! z: n8 C, C明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。 对于密码存储,Asp.net的实现方法为:
7 U8 V c/ T- S W4 f D[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e)
$ a* p0 I8 ~" E, F+ Q { q Q: H' ~$ a+ E* r# K$ `
string plainPassword = "innovator";
8 ?% d$ `. V- P7 {' z$ Y N( @- E* e& Q4 Z
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
5 g- v4 s3 P6 n/ `. w V k- U System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();' h, P. r) q: t( Z3 a5 o
byte[] data = ascii.GetBytes(plainPassword);
$ j! W+ o: F) i byte[] result = md5.ComputeHash(data);
) O: p; Q5 a! h+ y; ~; X. L; Y& T0 M // Convert the MD5 result to Hexadecimal string
# r$ L/ {' s4 m6 x. Z$ {0 `2 Q$ b' W3 k- C9 Z E, G. o: `
string MD5Password = BinaryToHex(result);( X/ H9 E7 b3 m6 L; W7 g0 D. A! K
string aa = "";. b0 Z- t3 V' C6 Z
}[/mw_shl_code] ! d/ S) G9 c6 u/ t1 q- K
[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray)6 a% U& y' J. p4 {7 Q
{
# o% H1 A' H$ J0 |# v string result = "";
. ^& f& S# k# ~4 |0 d long lowerByte;
0 V. l! o# @+ m long upperByte;
& c8 S ?* D) F8 l/ D; y2 _: ]
5 {+ B" m$ q4 J$ o/ j1 O foreach (Byte singleByte in BinaryArray)
. l* E& c- u1 M9 p6 `8 o {
! P% A% h, w( B8 u8 B; {3 N# [+ C lowerByte = singleByte & 15;6 ?3 Q5 o2 C u0 m! h5 ~8 M+ U# \
upperByte = singleByte >> 4;0 L7 g1 N$ t4 Y# z1 B# L
( t# `8 X& A8 L* S
result += NumberToHex(upperByte);
8 w4 [3 D ~5 U6 j4 Y1 u. f result += NumberToHex(lowerByte);. P& ]: E4 {$ w% H$ w. x
}( F* u' g7 ~, v
return result;
. l0 z( D0 @* v, J6 P/ z' g }[/mw_shl_code] # i2 A# }% S# n2 F. l
[mw_shl_code=csharp,true]private static char NumberToHex(long Number)+ Q) [4 @' V, F: R# M3 d* {: R
{
+ ?7 t! M; p8 g* J* r if (Number > 9)) s' |5 v9 W: E- F& X8 k
return Convert.ToChar(65 + (Number - 10));
) p" J+ |' b" A6 K$ l else$ X3 S+ o* y4 z
return Convert.ToChar(48 + Number);/ R7 k& L( x. v) a/ n7 w
}[/mw_shl_code]
- R. t" \" j6 ^2 b: J( z |