作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在研究在 PHP.NET 上对数据库进行哈希处理和存储密码。这个网站说:
例如,如果您将数据存储在 MySQL 数据库中,请记住 varchar 字段在插入过程中会自动删除尾随空格。由于加密数据可以以空格 (ASCII 32) 结尾,因此删除会损坏数据。而是将数据存储在 tinyblob/tinytext(或更大)字段中。
哪个建议更好?或者我可能不得不问:其中一个更好吗?如果答案是肯定的,哪个?最后我应该如何使用 PDO 将密码存储到数据库。我以为我可以像文件一样将信息写入 blob 行,但是如果我从输入中获取值,必须使用哪个方法或函数?请解释一下好吗?
最佳答案
存储散列密码时,删除空格不是问题:
密码应使用经过验证的现代 key-stretching 进行哈希处理算法,但不适用于 SHA-256 或 MD5 等加密哈希函数。合适的算法包括 PBKDF2 , bcrypt , 或 scrypt .
例如,使用 bcrypt 和新盐对字符串“pass phrase”进行散列处理可能会产生
$2a$12$PuYHvYwgKeD.hQ1Dv6nLQuxUkv5zP3lYLPHqdMOzgwPVaGGSAs07u
`-----'`-----------······· ·········-------'
algorithm random salt password hash
parameters
整个字符串都可以用作盐,因为实际的密码哈希将被截断而不用作盐。
验证登录尝试的推荐工作流程:
设置新密码的推荐工作流程:
进一步评论:
[1] 此处,“明文”表示可打印的 ASCII 字符。它不是指密码的明文。
关于php - 将散列密码存储到 Mysql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20462411/
我是一名优秀的程序员,十分优秀!