深入密码加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 相关文章推荐
服务器端解压缩zip的脚本
Dec 22 PHP
PHP数据库调用类调用实例(详细注释)
Jul 12 PHP
将时间以距今多久的形式表示,PHP,js双版本
Sep 25 PHP
浅析关于PHP位运算的简单权限设计
Jun 30 PHP
分享最受欢迎的5款PHP框架
Nov 27 PHP
PHP Warning: Module 'modulename' already loaded in问题解决办法
Mar 16 PHP
PHP实现生成带背景的图形验证码功能
Oct 03 PHP
php foreach如何跳出两层循环(详解)
Nov 05 PHP
Yii2.0多文件上传实例说明
Jul 24 PHP
php 中htmlentities导致中文无法查询问题
Sep 10 PHP
Laravel框架文件上传功能实现方法示例
Apr 16 PHP
WordPress伪静态规则设置代码实例
Dec 10 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中的Swoole
2016/04/05 PHP
thinkPHP模板算术运算相关函数用法分析
2016/07/12 PHP
PHPCMS手机站伪静态设置详细教程
2017/02/06 PHP
PHP实现电商订单自动确认收货redis队列
2017/05/17 PHP
JS 创建对象(常见的几种方法)
2008/11/03 Javascript
js 单引号 传递方法
2009/06/22 Javascript
基于jQuery的简单的列表导航菜单
2011/03/02 Javascript
JS中typeof与instanceof之间的区别总结
2013/11/14 Javascript
Node.js实现简单聊天服务器
2014/06/20 Javascript
laytpl 精致巧妙的JavaScript模板引擎
2014/08/29 Javascript
javaScript中slice函数用法实例分析
2015/06/08 Javascript
简述AngularJS相关的一些编程思想
2015/06/23 Javascript
JavaScript程序开发之JS代码放置的位置
2016/01/15 Javascript
JS中取二维数组中最大值的方法汇总
2016/04/17 Javascript
Vue.js常用指令汇总(v-if、v-for等)
2016/11/03 Javascript
jQuery实现鼠标经过显示动画边框特效
2017/03/24 jQuery
Bootstrap进度条与AJAX后端数据传递结合使用实例详解
2017/04/23 Javascript
微信小程序中实现手指缩放图片的示例代码
2018/03/13 Javascript
Vue组件全局注册实现警告框的实例详解
2018/06/11 Javascript
JavaScript生成一个不重复的ID的方法示例
2019/09/16 Javascript
在js文件中引入(调用)另一个js文件的三种方法
2020/09/11 Javascript
vue中axios封装使用的完整教程
2021/03/03 Vue.js
Python读写Json涉及到中文的处理方法
2016/09/12 Python
使用PyInstaller将python转成可执行文件exe笔记
2018/05/26 Python
python遍历文件夹,指定遍历深度与忽略目录的方法
2018/07/11 Python
python批量生成条形码的示例
2020/10/10 Python
vivo智能手机官方商城:vivo
2016/09/22 全球购物
Eagle Eyes Optics鹰眼光学:高性能太阳镜
2018/12/07 全球购物
德国购买门票网站:ADticket.de
2019/10/31 全球购物
大一学生的职业生涯规划书范文
2014/01/19 职场文书
共产党员公开承诺书
2014/03/25 职场文书
镇班子对照检查材料思想汇报
2014/09/24 职场文书
盘点2020年适合农村地区创业的项目
2019/10/16 职场文书
JVM钩子函数的使用场景详解
2021/08/23 Java/Android
html5调用摄像头截图功能
2022/01/18 Javascript
MySQL新手入门进阶语句汇总
2022/09/23 MySQL