`
xp9802
  • 浏览: 1205179 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

“md5+随机”方式加密

阅读更多
摘要:

1 加Salt散列
2 ASP.NET 2.0 Membership中与密码散列有关的代码

声明:本文所罗列之源代码均通过Reflector取自.NET Framework类库,引用这些代码仅出于学习和研究的目的。

其实,对密码进行散列存储不是一个新鲜话题了,解决起来也不是很难,但很多人还是不大了解。这个小文只是强调一下“加Salt散列”这个简单的技术,并给出ASP.NET Membership所使用的代码。

本来打算写一篇介绍如何实现用户登录功能的文章的,但因为时间有限,所以先介绍一下密码的散列,下一篇再介绍用户登录。

----

1 密码必须散列存储

(内容略)

2 加Salt散列

我们知道,如果直接对密码进行散列,那么黑客(统称那些有能力窃取用户数据并企图得到用户密码的人)可以对一个已知密码进行散列,然后通过对比散列值得到某用户的密码。换句话说,虽然黑客不能取得某特定用户的密码,但他可以知道使用特定密码的用户有哪些。

加Salt可以一定程度上解决这一问题。所谓加Salt,就是加点“佐料”。其基本想法是这样的——当用户首次提供密码时(通常是注册时),由系统自动往这个密码里撒一些“佐料”,然后再散列。而当用户登录时,系统为用户提供的代码撒上同样的“佐料”,然后散列,再比较散列值,已确定密码是否正确。

这里的“佐料”被称作“Salt值”,这个值是由系统随机生成的,并且只有系统知道。这样,即便两个用户使用了同一个密码,由于系统为它们生成的salt值不同,他们的散列值也是不同的。即便黑客可以通过自己的密码和自己生成的散列值来找具有特定密码的用户,但这个几率太小了(密码和salt值都得和黑客使用的一样才行)。

下面详细介绍一下加Salt散列的过程。介绍之前先强调一点,前面说过,验证密码时要使用和最初散列密码时使用“相同的”佐料。所以Salt值是要存放在数据库里的。


用户注册时:

1)用户提供密码(以及其他用户信息);
2)系统为用户生成Salt值;
3)系统将Salt值和用户密码连接到一起;
4)对连接后的值进行散列,得到Hash值;
5)将Hash值和Salt值分别放到数据库中。


登录时:
1)用户提供用户名和密码;
2)系统通过用户名找到与之对应的Hash值和Salt值;
3)系统将Salt值和用户提供的密码连接到一起;
4)对连接后的值进行散列,得到Hash'(注意有个“撇”);
5)比较Hash和Hash'是否相等,相等则表示密码正确,否则表示密码错误。

3 ASP.NET 2.0 Membership中的相关代码
(省略关于Membership的介绍若干字)
本文Anders Liu仅研究了SqlMembershipProvider,该类位于System.Web.dll,System.Web.Security命名空间中。
首先,要使用Membership,必须先用aspnet_regsql.exe命令来配置数据库,该工具会向现有数据库中添加一系列表和存储过程等,配置好的数据库中有一个表aspnet_Membership,就是用于存放用户帐户信息的。其中我们所关注的列有三个——Password、PasswordFormat和PasswordSalt。

Password存放的是密码的散列值,PasswordFormat存放用于散列密码所使用的算法,PasswordSalt就是系统生成的Salt值了。

网站安全了,程序自然也就复杂了...
     discuz的加密方式:md5(md5($password).$salt),$salt是一个6位随机数。
     注册的时候,把用户的密码用md5(md5($password).$salt)加密,$salt是一个6位随机数字,下面是我的一个获取6位随机数的一个方法:
     function randstr($len=6) {
     $chars='abcdefghijklmnopqrstuvwxyz0123456789';
// characters to build the password from
     mt_srand((double)microtime()*1000000*getmypid());
// seed the random number generater (must be done)
     $password='';
     while(strlen($password)<$len)
         $password.=substr($chars,(mt_rand()%strlen($chars)),1);
     return $password;
}
     $salt=randstr();把randstr()赋值给$salt,然后用md5(md5(会员提交的密码).$salt)加密就可以了,但是千万不要忘了把$salt入库哦(uc_members表)。
     登陆的时候根据用户名把$salt取出来,用md5(md5(会员提交的密码).$salt)匹配密码,如果一样就登陆成功了
2
1
分享到:
评论
4 楼 xp9802 2011-11-03  
有没有哪些老前辈说下,您们在以往的系统中,用到什么加密技术呢?
3 楼 xp9802 2011-11-03  
zc0604 写道
其实腾讯和新浪都是这么干的。。。

呵,可能他们的随机数不会那么简单
2 楼 zc0604 2011-11-03  
其实腾讯和新浪都是这么干的。。。
1 楼 xp9802 2011-11-03  
附上:
MD5不再安全?
    MD5不叫“加密”,叫“摘要”。别把MD5不安全跟可以解密混在一起。MD5在数学上就是不可解密的。md5单向加密,MD5是不可逆的。
    有些破解MD5的网站,原来他们的原理是,字典破解。因为他们有很多的值--密钥数据。所以,如果是公开的算法的话,怎么都是不安全的。无论是md5 还是 sha ,或者是 md5 + sha 。都会被收入字典,反向破解。
    最有有效的办法是,必须在md5或者sha基础上,再自行设置的一中算法,比如,加salt(一个随机串)。

相关推荐

    MD5加密实例(加盐)

    "加盐"是在MD5加密中增加额外安全性的技术。在密码存储中,"盐"是一段随机数据,与原始密码一起输入到MD5算法中,生成的哈希值包含了盐的信息,使得即使两个用户有相同的密码,其哈希值也会因为盐的不同而不同。这种...

    用户登陆(md5+验证码).rar

    综上所述,这个“用户登录(md5+验证码)”程序体现了在Web开发中保障用户账户安全的基本原则和常见实践,结合MD5加密和验证码技术,提供了相对基础但有效的安全防护。然而,随着技术的发展,开发者需要持续关注新的...

    密码学:MD5+Mysql

    在这个主题中,我们将重点关注MD5(Message-Digest Algorithm 5)哈希函数以及MySQL数据库系统在用户登录注册过程中的应用。 MD5是一种广泛使用的哈希函数,由Ronald Rivest在1991年设计。它将任意长度的输入(也...

    .Net几种加密方法(固定key 随机key 对称加密 MD5等)

    本文将详细介绍.NET中常见的几种加密方法,包括固定Key、随机Key、对称加密以及MD5加密。这些技术在保护敏感信息、验证数据完整性和防止数据篡改方面起着至关重要的作用。 1. 固定Key加密: 固定Key加密是指使用一...

    随机生成36位MD5加密字符

    在给定的`GUID.java`文件中,可能实现了类似的MD5生成逻辑,但是具体的实现方式需要查看源码才能得知。通常,全局唯一标识符(GUID)与MD5不直接相关,因为GUID是基于时间戳、机器标识和其他因素生成的128位值,而MD...

    Md5加密jar包

    "Md5加密jar包"可能包含了两种不同的MD5加密实现,这可能是因为每个jar包提供了不同的功能或者优化方式。一种可能的情况是,一个jar包提供了基础的MD5加密功能,而另一个则可能包含了一些额外的功能,比如加盐(salt...

    MD5 加密解密例子

    MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希函数,主要应用于数据的校验和加密场景。在IT行业中,MD5常被用来确保数据的完整性和安全性,尤其是在存储密码时,通常会将原始密码转化为MD5哈希值进行存储...

    MD5加密_c#加密_C#_

    C#语言提供了System.Security.Cryptography命名空间,其中包含MD5类,用于实现MD5加密算法。以下是一个简单的C# MD5加密的示例: ```csharp using System; using System.Text; using System.Security.Cryptography;...

    md5散列加密算法 强大的工具

    MD5散列加密算法是一种广泛应用于信息安全领域的强效工具,主要功能是将任意长度的数据转化为固定长度的摘要信息。这个算法由Ronald L. Rivest在1991年提出,是早期的MD4算法的加强版。MD5全称为Message-Digest ...

    php MD5 base64 crypt等加密函数用法集.rar

    //Sha1这种加密方式跟MD5相差不是很大都有一个$raw_output的可选参数,使用方法也是一样的,$raw_output参数为true返回以20字符长度的格式,否则返回40字符长度的16进制的数字  $str=urlencode('陈和群'); //...

    delphi中用MD5进行密码加密

    - 加密过程中不应直接使用原始密码,而是应先对其进行加盐处理(添加随机数据)后再进行MD5运算,这样可以增加破解的难度。 - 为了增强密码安全性,通常会结合使用其他安全策略,如最小密码长度、复杂度要求以及多...

    MD5加密(有盐+无盐).zip

    在Java中实现MD5加密,可以使用`java.security.MessageDigest`类。以下是一个简单的MD5无盐加密示例: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public ...

    android MD5加密

    2. **盐值的使用**:为了提高安全性,可以在进行MD5加密前添加随机的“盐值”(salt),这样即使两个用户的密码相同,其哈希值也会不同。 3. **性能优化**:对于大数据量的加密,可以考虑使用分块处理等方式来提高...

    C# MD5加密实例

    在C#中,我们可以使用System.Security.Cryptography命名空间中的MD5类来实现MD5加密。下面是一个具体的C# MD5加密的实例: ```csharp using System; using System.Text; using System.Security.Cryptography; ...

    asp.net MD5加密

    除了基本的MD5加密,ASP.NET还提供了多种加密和解密方式,例如SHA系列、AES、DES等。这些算法各有特点,适用于不同的安全需求。例如,如果需要更高级的安全性,可以考虑使用RSA或AES等对称/非对称加密算法。 在实际...

    C# MD5 加密.rar

    MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希函数,主要应用于数据的校验和加密场景。在C#编程环境中,MD5加密通常用于生成一个特定输入数据的固定长度、不可逆的数字指纹,这有助于验证数据的完整性和...

    springboot+shiro+md5

    总的来说,这个项目展示了如何使用SpringBoot作为基础框架,结合Shiro进行用户身份验证和授权,并利用MD5加密技术来增强密码的安全性。这是一个典型的Web应用安全实践,对于学习和理解SpringBoot、Shiro以及密码学的...

    C#实现MD5加密

    根据提供的文件信息,我们可以深入探讨如何使用C#来实现MD5加密,并且了解其背后的原理以及实际应用。MD5(Message-Digest Algorithm 5)是一种广泛使用的散列函数,能够将任意长度的数据转换为固定长度的摘要。由于...

    servlet+jsp实现的有验证码和MD5加密的登陆

    本项目"Servlet+jsp实现的有验证码和MD5加密的登陆"是一个典型的Web登录系统,它结合了数据库操作、前端展示和安全机制,具体涉及以下几个关键知识点: 1. **Servlet**:Servlet是Java编写服务器端应用程序的接口,...

Global site tag (gtag.js) - Google Analytics