深入密码加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传输数据的代码
Nov 13 PHP
浅析php中jsonp的跨域实例
Jun 21 PHP
解析php通过cookies获取远程网页的指定代码
Jun 25 PHP
php输入流php://input使用示例(php发送图片流到服务器)
Dec 25 PHP
PHP防盗链代码实例
Aug 27 PHP
Yii框架关联查询with用法分析
Dec 02 PHP
Apache无法自动跳转却显示目录的解决方法
Nov 30 PHP
Ajax实现对静态页面的文章访问统计功能示例
Oct 10 PHP
PHP应用跨时区功能的实现方法
Mar 21 PHP
yii框架数据库关联查询操作示例
Oct 14 PHP
PHP命名空间(namespace)原理与用法详解
Dec 11 PHP
PHP对接阿里云虚拟号的实现(号码隐私保护)
Apr 06 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中通过ADODB库实现调用Access数据库之修正版本
2006/12/31 PHP
laravel实现于语言包的完美切换方法
2019/09/29 PHP
TP3.2.3框架文件上传操作实例详解
2020/01/23 PHP
用Laravel轻松处理千万级数据的方法实现
2020/12/25 PHP
IE和Firefox在JavaScript应用中的兼容性探讨
2008/04/01 Javascript
JS正则中的RegExp对象对象
2012/11/07 Javascript
js数组的操作详解
2013/03/27 Javascript
js从Cookies里面取值的简单实现
2014/06/30 Javascript
AngularJs Modules详解及示例代码
2016/09/01 Javascript
本地Bootstrap文件字体图标引入却无法显示问题的解决方法
2020/04/18 Javascript
vue 中自定义指令改变data中的值
2017/06/02 Javascript
在vue中实现简单页面逆传值的方法
2017/11/27 Javascript
分析JS中this引发的bug
2017/12/12 Javascript
微信小程序自定义轮播图
2018/11/04 Javascript
vue使用vuex实现首页导航切换不同路由的方法
2019/05/08 Javascript
js获取浏览器地址(获取第1个斜杠后的内容)
2019/09/03 Javascript
node.js使用http模块创建服务器和客户端完整示例
2020/02/10 Javascript
JQuery获得内容和属性方法解析
2020/05/30 jQuery
python中循环语句while用法实例
2015/05/16 Python
Python实现的txt文件去重功能示例
2018/07/07 Python
python实现linux下抓包并存库功能
2018/07/18 Python
基于python3实现socket文件传输和校验
2018/07/28 Python
解决PyCharm同目录下导入模块会报错的问题
2018/10/13 Python
简单了解Python读取大文件代码实例
2019/12/18 Python
Django重设Admin密码过程解析
2020/02/10 Python
Windows下Anaconda和PyCharm的安装与使用详解
2020/04/23 Python
python对execl 处理操作代码
2020/06/22 Python
Python特殊属性property原理及使用方法解析
2020/10/09 Python
HTML5 script元素async、defer异步加载使用介绍
2013/08/23 HTML / CSS
The Hut德国站点:时装、家居用品、美容等
2016/09/23 全球购物
娱乐地球:Entertainment Earth
2020/01/08 全球购物
幼儿园大班毕业教师寄语
2014/04/03 职场文书
教师求职信范文
2014/05/24 职场文书
团队合作精神学习心得体会
2016/01/19 职场文书
go语言中fallthrough的用法说明
2021/05/06 Golang
Python实现单例模式的5种方法
2021/06/15 Python