当前位置: 代码网 > 服务器>网络安全>加密解密 > ASP.NET中MD5和SHA1加密的几种方法

ASP.NET中MD5和SHA1加密的几种方法

2008年10月08日 加密解密 我要评论
ASP.NET中MD5和SHA1加密的几种方法 MD5的全称是Message-Digest Algorithm 5(信息-摘要算法),在90年代初由Mit Laboratory for Computer Science和Rsa data security inc的Ronald l. rivest开发出来,经md2、md3和md4发... 08-10-08
md5的全称是message-digest algorithm 5(信息-摘要算法),在90年代初由mit laboratory for computer science和rsa data security inc的ronald l. rivest开发出来,经md2、md3和md4发展而来。它的作用是让大容量信息在用数字签名软件签署私人密匙前被“压缩”成一种保密的格式(就是把一个任意长度的字节串变换成一定长的大整数)。不管是md2、md4还是md5,它们都需要获得一个随机长度的信息并产生一个128位的信息摘要。

加密哈希函数将任意长度的二进制字符串映射为固定长度的小型二进制字符串。加密哈希函数有这样一个属性:在计算上不大可能找到散列为相同的值的两个不同的输入;也就是说,两组数据的哈希值仅在对应的数据也匹配时才会匹配。数据的少量更改会在哈希值中产生不可预知的大量更改。所以你很难从加密后的文字中找到蛛丝马迹。

sha1的全称是secure hash algorithm(安全哈希算法)

md5算法的哈希值大小为128位。而sha1算法的哈希值大小为160位。两种算法都是不可逆。

虽说2004年8月17日的美国加州圣巴巴拉的国际密码学会议(crypto’2004)上,来自中国山东大学的王小云教授做了破译md5、haval-128、md4和ripemd算法的报告,公布了md系列算法的破解结果。宣告了固若金汤的世界通行密码标准md5的堡垒轰然倒塌,引发了密码学界的轩然大波。但是我觉得对于我们做普通的软件来说,这个加密安全程度已经足够使用了。

我们平常用的最多的无非就是加密用户密码,把加密好的密码存储到数据库中,进行密码比较的时候,把用户输入的密码再进行加密,然后与数据库中的密文进行比较。至于asp.net类中是如何实现加密算法的,这个我们不需要关心,会用就行了。

下面就是asp.net中几种加密方法。加密算法有两种,也就是上面提到的md5和sha1,这里我举的例子是以md5为例,sha1大致相同,只是使用的类不一样。

md5相关类:

system.security.cryptography.md5
system.security.cryptography.md5cryptoserviceprovider()
system.web.security.formsauthentication.hashpasswordforstoringinconfigfile(strsource, "md5")

sha1相关类:

system.security.cryptography.sha1
system.security.cryptography.sha1cryptoserviceprovider()
system.web.security.formsauthentication.hashpasswordforstoringinconfigfile(strsource, "sha1")

方法如下:(用的vs 2005)

1/**//// <summary>
2 /// 方法一:通过使用 new 运算符创建对象
3 /// </summary>
4 /// <param name="strsource">需要加密的明文</param>
5 /// <returns>返回16位加密结果,该结果取32位加密结果的第9位到25位</returns>
6 public string get_md5_method1(string strsource)
7 {
8  //new
9  system.security.cryptography.md5 md5 = new system.security.cryptography.md5cryptoserviceprovider();
10
11  //获取密文字节数组
12  byte[] bytresult = md5.computehash(system.text.encoding.default.getbytes(strsource));
13
14  //转换成字符串,并取9到25位
15  string strresult = bitconverter.tostring(bytresult, 4, 8);
16  //转换成字符串,32位
17  //string strresult = bitconverter.tostring(bytresult);
18
19  //bitconverter转换出来的字符串会在每个字符中间产生一个分隔符,需要去除掉
20  strresult = strresult.replace("-", "");
21  return strresult;
22 }
23
24 /**//// <summary>
25 /// 方法二:通过调用特定加密算法的抽象类上的 create 方法,创建实现特定加密算法的对象。
26 /// </summary>
27 /// <param name="strsource">需要加密的明文</param>
28 /// <returns>返回32位加密结果</returns>
29 public string get_md5_method2(string strsource)
30 {
31  string strresult = "";
32
33  //create
34  system.security.cryptography.md5 md5 = system.security.cryptography.md5.create();
35
36  //注意编码utf8、utf7、unicode等的选择 
37  byte[] bytresult = md5.computehash(system.text.encoding.utf8.getbytes(strsource));
38
39  //字节类型的数组转换为字符串
40  for (int i = 0; i < bytresult.length; i )
41  {
42 //16进制转换
43 strresult = strresult bytresult[i].tostring("x");
44   }
45  return strresult;
46 }
47
48 /**//// <summary>
49 /// 方法三:直接使用hashpasswordforstoringinconfigfile生成
50 /// </summary>
51 /// <param name="strsource">需要加密的明文</param>
52 /// <returns>返回32位加密结果</returns>
53 public string get_md5_method3(string strsource)
54 {
55  return system.web.security.formsauthentication.hashpasswordforstoringinconfigfile(strsource, "md5");
56 }


这些加密函数都是在服务器端执行,也就是说,当用户输入密码后,从客户端到服务器端传输时,用户的密码没有任何保护,很危险。银行的做法是在客户端安装activex控件,在客户端就把一些重要信息进行加密,再发送。

(0)

相关文章:

  • 密钥或对称密钥加密术

    密钥或对称密钥加密术

    密钥或对称密钥加密术 密钥或对称密钥加密术 (Secret-Key or Symmetric-Key Cryptography) 密钥加密术是确保具有报文解密... [阅读全文]
  • DB2中的数据值加密

    DB2中的数据值加密

    DB2中的数据值加密 多年来,数据库已经能够阻止未经授权的人看到其中的数据,这通常是通过数据库管理器中的特权和权限来实现的。在当前的环境下,对存储数据的保密的... [阅读全文]
  • PECompact.v1.80.b2解密详解

    PECompact.v1.80.b2解密详解

    PECompact.v1.80.b2解密详解 ////////////////////////////////////////////////////////... [阅读全文]
  • 加密解密有高招

    加密解密有高招

    加密解密有高招 加密和解密是一个永久的热点话题,什么样的加密才是安全的?怎样才能解开常用的密码?你是否已经意识到,在你每日朝夕相处的密码和保护中,已经有太多的... [阅读全文]
  • 取密钥生成算法(图)

    取密钥生成算法(图) 从拷贝保护产品中剥取(ripping)算法通常是创建密钥生成程序的一种简单而行之有效的方法。其思路非常简单:定位受保护程序内计算合法序列号的函数(可能不止一…

    2008年10月08日 网络安全
  • 高级破解Defender教程(图)

    高级破解Defender教程(图) Defender与底层操作系统紧密集成在一起,且它是专为在基于NT的Windows系统中运行设计的。它可以在当前所有基于NT的系统中运行,包括…

    2008年10月08日 网络安全

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com