密码在数据库当中是如何存储的?明文还是密文? 很显然做为一家负责人的公司密码应该采用密文在数据库中存储 这样做即使数据库被攻破密码采用了加密也不会得到泄露
MD5是一种哈希算法,用来保证信息的完整性。 一段信息对应一个哈希值,且不能通过哈希值推出这段信息,而且还需要保证不存在任意两段不相同的信息对应同一个哈希值。
所需要的依赖:commons-codec
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
</dependency>
实现:
String str = "admin";
//使用DigestUtils工具类
String s = DigestUtils.md5Hex(str+salter);
System.out.println("MD5加密结果:"+s);
虽然md5算法加密不可以解密,但是一些简单的,出现频率高的密码还是极有可能被破解记录下来的 如:123456,admin,root等 那么何为加盐? 就是在原要加密的字符串中按照自己的想法把一些规律的不规律的字符串添加进来
例如:加密字符串:123456 加盐:加密字符串变为:123456abcd
String salter = "加盐字符串";
String str = "admin";
//使用DigestUtils工具类
String s = DigestUtils.md5Hex(str+salter);
System.out.println("MD5加密结果:"+s);
npm 下载crypto npm install crypto 代码:
var crypto = require('crypto')
//加盐
let str = "admin"
let salt = 'Node'
str = str + salt
let obj = crypto.createHash('md5')
obj.update(str)
let strHex = obj.digest('hex')
console.log(strHex)