深入密码加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 相关文章推荐
一个用mysql_odbc和php写的serach数据库程序
Oct 09 PHP
apache+php+mysql安装配置方法小结
Aug 01 PHP
PHP中运用jQuery的Ajax跨域调用实现代码
Feb 21 PHP
ThinkPHP模板引擎之导入资源文件方法详解
Jun 18 PHP
PHP实现利用MySQL保存session的方法
Aug 23 PHP
PHPExcel读取EXCEL中的图片并保存到本地的方法
Feb 14 PHP
PHP往XML中添加节点的方法
Mar 12 PHP
PHP性能分析工具XHProf安装使用教程
May 13 PHP
Laravel使用RabbitMQ的方法示例
Jun 18 PHP
对laravel的session获取与存取方法详解
Oct 08 PHP
基于PHP实现用户在线状态检测
Nov 10 PHP
PHP网站常见安全漏洞,及相应防范措施总结
Mar 01 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生成静态页面分析 模板+缓存+写文件
2009/08/17 PHP
关于Iframe如何跨域访问Cookie和Session的解决方法
2013/04/15 PHP
PHP设计模式之迭代器模式的深入解析
2013/06/13 PHP
php数组中包含中文的排序方法
2014/06/03 PHP
yii2分页之实现跳转到具体某页的实例代码
2016/06/02 PHP
PHP simplexml_load_file()函数讲解
2019/02/03 PHP
学习YUI.Ext 第六天--关于树TreePanel(Part 1)
2007/03/10 Javascript
Javascript在IE和FireFox中的不同表现简析
2012/12/03 Javascript
cookie.js 加载顺序问题怎么才有效
2013/07/31 Javascript
Javascript 鼠标移动上去 滑块跟随效果代码分享
2013/11/23 Javascript
jQuery中prev()方法用法实例
2015/01/08 Javascript
jquery实现全选、不选、反选的两种方法
2016/09/06 Javascript
浅谈js在html中的加载执行顺序,多个jquery ready执行顺序
2016/11/26 Javascript
Angular指令封装jQuery日期时间插件datetimepicker实现双向绑定示例
2017/01/22 Javascript
使用get方式提交表单在地址栏里面不显示提交信息
2017/02/21 Javascript
简单实现js点击展开二级菜单功能
2017/05/16 Javascript
vue组件父与子通信详解(一)
2017/11/07 Javascript
你了解vue3.0响应式数据怎么实现吗
2019/06/07 Javascript
Node对CommonJS的模块规范
2019/11/06 Javascript
react-native聊天室|RN版聊天App仿微信实例|RN仿微信界面
2019/11/12 Javascript
python 循环while和for in简单实例
2016/08/16 Python
离线安装Pyecharts的步骤以及依赖包流程
2020/04/23 Python
Python实现基于C/S架构的聊天室功能详解
2018/07/07 Python
python2.7和NLTK安装详细教程
2018/09/19 Python
PyQt5+python3+pycharm开发环境配置教程
2020/03/24 Python
用 Python 制作地球仪的方法
2020/04/24 Python
浏览器实现移动端高性能css3动画(开启gpu加速)
2013/12/23 HTML / CSS
荷兰最大的多品牌男装连锁店:Adam Brandstore
2019/12/31 全球购物
软件缺陷的分类都有哪些
2014/08/22 面试题
人事行政经理岗位职责
2014/06/18 职场文书
运动员获奖感言
2014/08/15 职场文书
2015新年联欢晚会开场白
2014/12/14 职场文书
AJAX实现省市县三级联动效果
2021/10/16 Javascript
python opencv将多个图放在一个窗口的实例详解
2022/02/28 Python
idea下配置tomcat避坑详解
2022/04/12 Servers
Win10加载疑难解答时出错发生意外错误的解决方法
2022/07/07 数码科技