标签:tps trick 兴趣 char dig 十六 输入 href code
这篇文章将向你解释如何使用
Node.js
的Crypto模块对你的密码进行加盐hash
。在这里,我们将不会对不懂的密码存储方式进行详细的比较。我们将要做的是知道在Node.js
中使用加盐hash
在进行密码存储的机制。放心,这是最好的存储密码的方式,在没有出现其他更好的方法之前。
加盐是这样一直技术:将用户输入的密码和一个随机的字符串(这个字符串就是盐)通过hash结合,通过hash算法生成一个hash值,然后将结果存储在数据库中。
因为相同密码的hash值是相同的,所以那时很容易通过lookup tables和rainbow tables来破解密码(lookup tables 和rainbow talbes是一些人预先破解了一些常见的密码然后存储起来以供其他人使用的表格)。如果有两个或者更多的用户拥有相同的密码hash值,将会让攻击者更加容易预测密码。加盐是为了让有相同密码hash值得这种情况减少。 如果你的盐(随机字符串)够长,那么这种几率将会几乎为零。
在实践中你将会进行以下这些操作
首先需要引入crypto
这个模块。你不需要单独去下载它,因为他是Node.js的内置模块,只需引入即可。
‘use strict‘
var crypto = require(‘crypto‘)
/**
* generates random string of characters i.e salt
* @function
* @param {number} length - Length of the random string.
*/
var genRandomString = function(length){
return crypto.randomBtytes(Math.ceil(length/2))
.toString(‘hex‘) /**转成十六进制*/
.slice(0,length);/**返回指定长度字符串*/
}
使用一种你在读这篇文章时代的一种合适的加密hash算法,因为伴随着计算能力的发展,加密hash技术也会发展。所以如果你使用就得hash加密算法是存在很大风险的。这里我们使用sha512
/**
* hash password with sha512.
* @function
* @param {string} password - List of required fields.
* @param {string} salt - Data to be validated.
*/
var sha512 = function(password, salt){
var hash = crypto.createHamc(‘sha512‘, salt); /**使用sha512算法进行hash*/
hash.update(password)
var value = hash.digest(‘hex‘)
return {
salt:salt,
passwordHash:value
}
}
下面我们将创建一个函数使用让面的的函数生成一个hash值,作为用户密码存储在数据库中。
function saltHashPassword(userpassword){
var salt = genRandowString(16) /**生成一个长度为16个字符的盐*/
var passwordData = sha512(userpassword, salt);
console.log( console.log(‘UserPassword = ‘+userpassword);
console.log(‘Passwordhash = ‘+passwordData.passwordHash);
console.log(‘nSalt = ‘+passwordData.salt);)
}
saltHashPassword(‘MYPASSWORD‘);
saltHashPassword(‘MYPASSWORD‘);
注意,我们当用saltHashPassword
两次使用相同的参数,只是想要展示使用相同密码的两次hash加密的结果是不同的。
下面让我们来看看完整的代码展示
‘use strict‘;
var crypto = require(‘crypto‘);
/**
* generates random string of characters i.e salt
* @function
* @param {number} length - Length of the random string.
*/
var genRandomString = function(length){
return crypto.randomBytes(Math.ceil(length/2))
.toString(‘hex‘) /** convert to hexadecimal format */
.slice(0,length); /** return required number of characters */
};
/**
* hash password with sha512.
* @function
* @param {string} password - List of required fields.
* @param {string} salt - Data to be validated.
*/
var sha512 = function(password, salt){
var hash = crypto.createHmac(‘sha512‘, salt); /** Hashing algorithm sha512 */
hash.update(password);
var value = hash.digest(‘hex‘);
return {
salt:salt,
passwordHash:value
};
};
function saltHashPassword(userpassword) {
var salt = genRandomString(16); /** Gives us salt of length 16 */
var passwordData = sha512(userpassword, salt);
console.log(‘UserPassword = ‘+userpassword);
console.log(‘Passwordhash = ‘+passwordData.passwordHash);
console.log(‘nSalt = ‘+passwordData.salt);
}
saltHashPassword(‘MYPASSWORD‘);
saltHashPassword(‘MYPASSWORD‘);
在运行这段代码,你将会的得到两个不同的hash值(这里就不做展示了,有兴趣的可以自己运行看看)
无论你做任何需要存储用户密码的web应用,它都非常容易出现问题,所以这里我们强烈推荐你使用加盐hash来对用户密码进行处理,这将有效的提高密码存储的安全性。
使用nodeJS的 crypto模块来为你的密码hash加盐
标签:tps trick 兴趣 char dig 十六 输入 href code
原文地址:https://www.cnblogs.com/tianjinblog/p/8781188.html