Shiro-散列算法
来源:互联网 发布:重庆知行科技学校 编辑:程序博客网 时间:2024/05/26 02:20
5.2 散列算法
散列算法一般用于生成数据的摘要信息,是一种不可逆的算法,一般适合存储密码之类的数据,常见的散列算法如MD5、SHA等。一般进行散列时最好提供一个salt(盐),比如加密密码“admin”,产生的散列值是“21232f297a57a5a743894a0e4a801fc3”,可以到一些md5解密网站很容易的通过散列值得到密码“admin”,即如果直接对密码进行散列相对来说破解更容易,此时我们可以加一些只有系统知道的干扰数据,如用户名和ID(即盐);这样散列的对象是“密码+用户名+ID”,这样生成的散列值相对来说更难破解。
Java代码
- String str = "hello";
- String salt = "123";
- String md5 = new Md5Hash(str, salt).toString();//还可以转换为 toBase64()/toHex()
如上代码通过盐“123”MD5散列“hello”。另外散列时还可以指定散列次数,如2次表示:md5(md5(str)):“new Md5Hash(str, salt, 2).toString()”。
Java代码
- String str = "hello";
- String salt = "123";
- String sha1 = new Sha256Hash(str, salt).toString();
使用SHA256算法生成相应的散列数据,另外还有如SHA1、SHA512算法。
Shiro还提供了通用的散列支持:
Java代码
- String str = "hello";
- String salt = "123";
- //内部使用MessageDigest
- String simpleHash = new SimpleHash("SHA-1", str, salt).toString();
通过调用SimpleHash时指定散列算法,其内部使用了Java的MessageDigest实现。
0 0
- Shiro-散列算法
- shiro简介,认证,认证流程,自定义realm,散列算法
- shiro中自定义realm实现md5散列算法加密的模拟(二)
- 【shiro】shiro学习笔记3-散列功能
- java鬼混笔记:shiro 3、shiro下的散列操作(MD5,SHA-1)
- 散列算法--介绍
- 散列算法
- MD5散列算法
- sha1散列算法
- 散列算法
- 算法之双重散列
- SHA安全散列算法
- 散列算法与散列码
- SHA:安全散列算法
- Hash散列算法解析
- 开放定址散列算法
- SHA:安全散列算法 .
- SHA散列算法心得
- tomcat安装APR本地库不兼容问题的解决 APR based Apache Tomcat Native library is installed
- 反向代理
- Python_urllib模块
- [leetcode] 98. Validate Binary Search Tree
- 使用ajaxForm提交表单获取CKEditor值的问题
- Shiro-散列算法
- *** WARNING L2: REFERENCE MADE TO UNRESOLVED EXTERNAL
- 编译安装php扩展fileinfo
- js 里 escape,encodeURI,encodeURIComponent编码方法之我见
- Hibernate事务与并发问题处理(悲观锁与乐观锁)
- 谷歌开源项目风格指南笔记(上)
- AndroidManifest.xml文件详解
- 【6】旋转数组 的最小数字
- js同源策略