深入密码加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 25 PHP
php中时间轴开发(刚刚、5分钟前、昨天10:23等)
Oct 03 PHP
php判断用户是否手机访问代码
Jun 08 PHP
分享php代码将360浏览器导出的favdb的sqlite数据库文件转换为html
Dec 09 PHP
基于PHP的加载类操作以及其他两种魔术方法的应用实例
Aug 28 PHP
PHP使用Nginx实现反向代理
Sep 20 PHP
PHP时间戳和日期相互转换操作实例小结
Dec 18 PHP
在PHP中输出JS语句以及乱码问题的解决方案
Feb 13 PHP
使用Zookeeper分布式部署PHP应用程序
Mar 15 PHP
tp5(thinkPHP5框架)使用DB实现批量删除功能示例
May 28 PHP
聊聊 PHP 8 新特性 Attributes
Aug 19 PHP
PHP数组实际占用内存大小原理解析
Dec 11 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中spl_autoload详解
2014/10/17 PHP
PHP5.4起内置web服务器使用方法
2016/08/09 PHP
php使用变量动态创建类的对象用法示例
2017/02/06 PHP
详解PHP多个进程配合redis的有序集合实现大文件去重
2019/03/06 PHP
Nodejs学习笔记之Stream模块
2015/01/13 NodeJs
JavaScript子窗口调用父窗口变量和函数的方法
2015/10/09 Javascript
JS从一组数据中找到指定的单条数据的方法
2016/06/02 Javascript
详解angular中通过$location获取路径(参数)的写法
2017/03/21 Javascript
微信小程序实现根据字母选择城市功能
2017/08/16 Javascript
使用puppeteer破解极验的滑动验证码
2018/02/24 Javascript
jQuery+ajax读取json数据并按照价格排序示例
2018/03/28 jQuery
Nodejs把接收图片base64格式保存为文件存储到服务器上
2018/09/26 NodeJs
vue实现可视化可拖放的自定义表单的示例代码
2019/03/20 Javascript
JavaScript实现多张图片放大镜效果示例【不限定图片尺寸,rem单位】
2019/05/14 Javascript
Vue实现渲染数据后控制滚动条位置(推荐)
2019/12/09 Javascript
JavaScript onclick事件使用方法详解
2020/05/15 Javascript
[14:51]DOTA2 HEROS教学视频教你分分钟做大人-卓尔游侠
2014/06/13 DOTA
[56:35]DOTA2上海特级锦标赛C组小组赛#1 OG VS Archon第二局
2016/02/27 DOTA
[38:38]完美世界DOTA2联赛PWL S3 access vs Rebirth 第二场 12.17
2020/12/18 DOTA
K-近邻算法的python实现代码分享
2017/12/09 Python
人脸识别经典算法一 特征脸方法(Eigenface)
2018/03/13 Python
Pycharm+Python+PyQt5使用详解
2019/09/25 Python
Python发送邮件的实例代码讲解
2019/10/16 Python
Python使用jpype模块调用jar包过程解析
2020/07/29 Python
python实现梯度下降算法的实例详解
2020/08/17 Python
使用CSS3编写类似iOS中的复选框及带开关的按钮
2016/04/11 HTML / CSS
HTML5 Canvas标签使用收录
2009/07/07 HTML / CSS
Stuarts London美国/加拿大:世界领先的独立男装零售商之一
2019/03/18 全球购物
家佳咖啡店创业计划书
2013/12/27 职场文书
八一建军节部队活动方案
2014/02/04 职场文书
求职信格式要求
2014/05/23 职场文书
营销与策划专业求职信
2014/06/20 职场文书
2014乡镇班子个人对照检查材料思想汇报
2014/09/26 职场文书
学生喝酒检讨书500字
2014/11/02 职场文书
2015年度班主任自我评价
2015/03/11 职场文书
领导干部失职检讨书
2015/05/05 职场文书