深入密码加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 相关文章推荐
用PHP实现多服务器共享SESSION数据的方法
Mar 16 PHP
Php Cookie的一个使用注意点
Nov 08 PHP
PHP中=赋值操作符对不同数据类型的不同行为
Jan 02 PHP
php图片的裁剪与缩放生成符合需求的缩略图
Jan 11 PHP
解析dedeCMS验证码的实现代码
Jun 07 PHP
PHP迭代器实现斐波纳契数列的函数
Nov 12 PHP
php建立Ftp连接的方法
Mar 07 PHP
PHP常见漏洞攻击分析
Feb 21 PHP
ThinkPHP中session函数详解
Sep 14 PHP
PHP实现动态创建XML文档的方法
Mar 30 PHP
基于Laravel 多个中间件的执行顺序详解
Oct 21 PHP
PHP安装扩展mcrypt以及相关依赖项深入讲解
Mar 04 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
在PHP中执行系统外部命令
2006/10/09 PHP
phpmyadmin 访问被拒绝的真实原因
2009/06/15 PHP
php判断当前用户已在别处登录的方法
2015/01/06 PHP
Yii2框架使用计划任务的方法
2016/05/25 PHP
监控 url fragment变化的js代码
2010/04/19 Javascript
JavaScript类和继承 this属性使用说明
2010/09/03 Javascript
js中split和replace的用法实例
2015/02/28 Javascript
实现placeholder效果的方案汇总
2015/06/11 Javascript
深入浅析JavaScript中的arguments对象(强力推荐)
2016/06/03 Javascript
jQuery UI结合Ajax创建可定制的Web界面
2016/06/22 Javascript
纯JS实现表单验证实例
2016/12/24 Javascript
Google 爬虫如何抓取 JavaScript 的内容
2017/04/07 Javascript
JS判断非空至少输入两个字符的简单实现方法
2017/06/23 Javascript
基于JS代码实现简单易用的倒计时 x 天 x 时 x 分 x 秒效果
2017/07/13 Javascript
详解各版本React路由的跳转的方法
2018/05/10 Javascript
JS异步处理的进化史深入讲解
2019/08/25 Javascript
JavaScript 斐波那契数列 倒序输出 输出100以内的质数代码实例
2019/09/11 Javascript
0基础学习前端开发的一些建议
2020/07/14 Javascript
关于vue 结合原生js 解决echarts resize问题
2020/07/26 Javascript
JS实现悬浮球只在一侧滑动并且是横屏状态下
2020/08/19 Javascript
vue实现单一筛选、删除筛选条件
2020/10/26 Javascript
python 多线程应用介绍
2012/12/19 Python
Python3使用requests登录人人影视网站的方法
2016/05/11 Python
python的staticmethod与classmethod实现实例代码
2018/02/11 Python
Python查找两个有序列表中位数的方法【基于归并算法】
2018/04/20 Python
Python使用pandas处理CSV文件的实例讲解
2018/06/22 Python
django项目搭建与Session使用详解
2018/10/10 Python
Python使用pyshp库读取shapefile信息的方法
2018/12/29 Python
python 实现手机自动拨打电话的方法(通话压力测试)
2019/08/08 Python
详解python opencv、scikit-image和PIL图像处理库比较
2019/12/26 Python
新加坡网上花店:FlowerAdvisor新加坡
2018/10/05 全球购物
一道SQL面试题
2012/12/31 面试题
文员岗位职责
2013/11/09 职场文书
市场安全管理制度
2014/01/26 职场文书
政协工作总结2015
2015/05/20 职场文书
使用react-virtualized实现图片动态高度长列表的问题
2021/05/28 Javascript