深入密码加salt原理的分析


Posted in PHP onJune 06, 2013

我们知道,如果直接对密码进行散列,那么黑客可以对通过获得这个密码散列值,然后通过查散列值字典(例如MD5密码破解网站),得到某用户的密码。

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

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

下面以PHP示例,讲解md5($pass.$salt)加密函数。

<?php
function hash($a) {
    $salt=”Random_KUGBJVY”;  //定义一个salt值,程序员规定下来的随机字符串
    $b=$a.$salt;  //把密码和salt连接
    $b=md5($b);  //执行MD5散列
    return $b;  //返回散列    
}
?>

调用方式:$new_password=hash($_POST[password]);   //这里接受表单提交值,并进行加密
 
下面详细介绍一下加Salt散列的过程。介绍之前先强调一点,前面说过,验证密码时要使用和最初散列密码时使用“相同的”佐料。所以Salt值是要存放在数据库里的。

用户注册时,

用户输入【账号】和【密码】(以及其他用户信息);系统为用户生成【Salt值】;系统将【Salt值】和【用户密码】连接到一起;对连接后的值进行散列,得到【Hash值】;将【Hash值1】和【Salt值】分别放到数据库中。
用户登录时,

用户输入【账号】和【密码】;系统通过用户名找到与之对应的【Hash值】和【Salt值】;系统将【Salt值】和【用户输入的密码】连接到一起;对连接后的值进行散列,得到【Hash值2】(注意是即时运算出来的值);比较【Hash值1】和【Hash值2】是否相等,相等则表示密码正确,否则表示密码错误。
有时候,为了减轻开发压力,程序员会统一使用一个salt值(储存在某个地方),而不是每个用户都生成私有的salt值。

PHP 相关文章推荐
一个捕获函数输出的函数
Feb 14 PHP
在mysql数据库原有字段后增加新内容
Nov 26 PHP
php 函数使用方法与函数定义方法
May 09 PHP
PHP中根据IP地址判断城市实现城市切换或跳转代码
Sep 04 PHP
深入解析PHP中的(伪)多线程与多进程
Jul 01 PHP
ThinkPHP中pathinfo的访问模式、路径访问模式及URL重写总结
Aug 23 PHP
PHP中UNIX时间戳和日期间的转换与计算实例
Nov 19 PHP
php+jQuery递归调用POST循环请求示例
Oct 14 PHP
thinkPHP框架对接支付宝即时到账接口回调操作示例
Nov 14 PHP
ThinkPHP3.2.3框架实现的空模块、空控制器、空操作,跳转到错误404页面图文详解
Apr 03 PHP
Yii框架日志操作图文与实例详解
Sep 09 PHP
浅析PHP中的 inet_pton 网络函数
Dec 16 PHP
深入理解PHP几个算法:PHP冒泡、PHP二分法、PHP求素数、PHP乘法表
Jun 06 #PHP
php定时计划任务的实现方法详解
Jun 06 #PHP
PHP使用DES进行加密与解密的方法详解
Jun 06 #PHP
php xml常用函数的集合(比较详细)
Jun 06 #PHP
PHP5函数小全(分享)
Jun 06 #PHP
解析php时间戳与日期的转换
Jun 06 #PHP
基于header的一些常用指令详解
Jun 06 #PHP
You might like
thinkphp3查询mssql数据库乱码解决方法分享
2014/02/11 PHP
php实现用于验证所有类型的信用卡类
2015/03/24 PHP
如何在标题栏显示框架内页面的标题
2007/02/03 Javascript
扩展js对象数组的OrderByAsc和OrderByDesc方法实现思路
2013/05/17 Javascript
点击按钮自动加关注的代码(sina微博/QQ空间/人人网/腾讯微博)
2014/01/02 Javascript
js判断字符长度及中英文数字等
2014/03/19 Javascript
将HTML格式的String转化为HTMLElement的实现方法
2014/08/07 Javascript
Linux下编译安装php libevent扩展实例
2015/02/14 Javascript
jQuery实现按钮的点击 全选/反选 单选框/复选框 文本框 表单验证
2015/06/25 Javascript
javascript中的五种基本数据类型
2015/08/26 Javascript
深入浅析JavaScript函数前面的加号和叹号
2016/07/09 Javascript
Bootstrap 3 进度条的实现
2017/02/22 Javascript
JS 中document.write()的用法和清空的原因浅析
2017/12/04 Javascript
详解Angular-ui-BootStrap组件的解释以及使用
2018/07/13 Javascript
Angular angular-file-upload文件上传的示例代码
2018/08/23 Javascript
Vue中多个元素、组件的过渡及列表过渡的方法示例
2019/02/13 Javascript
[36:52]DOTA2真视界:基辅特锦赛总决赛
2017/05/21 DOTA
python刷投票的脚本实现代码
2014/11/08 Python
Windows下使Python2.x版本的解释器与3.x共存的方法
2015/10/25 Python
Django框架教程之正则表达式URL误区详解
2018/01/28 Python
Tensorflow 利用tf.contrib.learn建立输入函数的方法
2018/02/08 Python
python保存文件方法小结
2018/07/27 Python
在服务器上安装python3.8.2环境的教程详解
2020/04/26 Python
django的autoreload机制实现
2020/06/03 Python
keras使用Sequence类调用大规模数据集进行训练的实现
2020/06/22 Python
Html5 postMessage实现跨域消息传递
2016/03/11 HTML / CSS
我们是伦敦女孩:WalG
2018/01/08 全球购物
有原因的手表:Flex Watches
2019/03/23 全球购物
在C中是否有模拟继承等面向对象程序设计特性的好方法
2012/05/22 面试题
优秀党支部事迹材料
2014/01/14 职场文书
2014年教育工作总结
2014/11/26 职场文书
酒店辞职信怎么写
2015/02/27 职场文书
《生物入侵者》教学反思
2016/02/16 职场文书
python中的被动信息搜集
2021/04/29 Python
Redis调用Lua脚本及使用场景快速掌握
2022/03/16 Redis
Promise静态四兄弟实现示例详解
2022/07/07 Javascript