博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用户密码传输和存储的保护
阅读量:4627 次
发布时间:2019-06-09

本文共 577 字,大约阅读时间需要 1 分钟。

软件设计的过程中,用户的密码信息最为敏感,在进行用户登录验证时,除了将密码在传输的过程中,进行md5加密,避免密码明文传输过程中被截获外,还有一个就是密码在数据库中的存储安全问题。

常用的方案是对密码进行“加盐”处理。

用户注册。

1.      得到用户传过来的密码后,首先在计算机中获取一个随机数,

2.      获取到随机数后,设计一个任意算法,对随机数与用户密码进行拼接处理,比如最简单的(用户密码+随机数),者将得到一个全新的字符串

3.      我们再对这个新的字符串进行哈希算法处理,得到一个新的密码,由于哈希算法的特殊性,该算法是不可逆的。

4.      将用户id,新密码和随机数保存到数据库中。用户注册成功。

用户登录。

1.      服务端获取到用户的id和密码后,根据用户id从数据库中取出该用户的新密码和随机数。

2.      把用户传过来的旧密码和随机数交给用户注册第2步中的随机数和密码拼接算法,拼接后,得到一个新的字符串(和用户注册第2步得到的全新字符串是一模一样的)。

3.      将新字符串交给哈希算法处理将得到一个处理结果。

4.      如果处理后的结果和数据库中存储的新密码相同,那么,该用户传过来的密码是正确的,登录成功,否则,登录失败。

 

这就是常用的用户密码“加盐“!

 

 

转载于:https://www.cnblogs.com/CoderAyu/p/8490103.html

你可能感兴趣的文章
jdk和jre的区别
查看>>
快速开发一个PHP扩展
查看>>
主攻ASP.NET.4.5 MVC4.0之重生:Entity Framework生成实体类步骤(十三)
查看>>
PHP-密码学算法及其应用-对称密码算法
查看>>
Linux-TCP/IP TIME_WAIT状态原理
查看>>
ScaleYViewPager
查看>>
Codeforces 504 A (Round #285 div.1 A) Misha and Forest
查看>>
适用于SharePoint 2013 的 CAML Desinger
查看>>
动态规划——洛谷_P1057传球游戏
查看>>
vi_7
查看>>
Android调用远程Service的参数和返回值都需要实现Parcelable接口
查看>>
ORACLE 用户权限管理
查看>>
Ubuntu 初学
查看>>
网页分享插件 share.js 国外常用
查看>>
javascript学习笔记1
查看>>
atitit.跨架构 bs cs解决方案. 自定义web服务器的实现方案 java .net jetty HttpListener...
查看>>
编码规范
查看>>
shell代码模板
查看>>
C语言:1孩半问题
查看>>
分治——最近点对问题 hdu1007
查看>>