MessageDigest
MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,输出固定长度的哈希值。
MessageDigest 对象开始被初始化。该对象通过使用 update 方法处理数据。任何时候都可以调用 reset 方法重置摘要。一旦所有需要更新的数据都已经被更新了,应该调用 digest 方法之一完成哈希计算。
对于给定数量的更新数据,digest 方法只能被调用一次。digest 被调用后,MessageDigest 对象被重新设置成其初始状态。
举个简单的md5加密的例子:
package com.company; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MessageDigestTest { public static void main(String[] args) throws NoSuchAlgorithmException { String source = "123123"; String md5Str = getMd5(source); System.out.println(md5Str); } /** * 通过md5进行加密 * @param source 要加密的数据 * @return * @throws NoSuchAlgorithmException */ private static String getMd5(String source) throws NoSuchAlgorithmException { //1.获取MessageDigest对象 MessageDigest digest = MessageDigest.getInstance("md5"); //2.执行加密操作 byte[] bytes = source.getBytes(); //在MD5算法这,得到的目标字节数组的特点:长度固定为16 byte[] targetBytes = digest.digest(bytes); //3.声明字符数组 char [] characters = new char[]{'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'}; //4.遍历targetBytes StringBuilder builder = new StringBuilder(); for (byte b : targetBytes) { //5.取出b的高四位的值 //先把高四位通过右移操作拽到低四位 int high = (b >> 4) & 15; //6.取出b的低四位的值 int low = b & 15; //7.以high为下标从characters中取出对应的十六进制字符 char highChar = characters[high]; //8.以low为下标从characters中取出对应的十六进制字符 char lowChar = characters[low]; builder.append(highChar).append(lowChar); } return builder.toString(); } }
测试结果:
4297F44B13955235245B2497399D7A93
封装成工具类:
package com.company; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MD5Tool { private static ThreadLocal<MD5Tool> md5ToolThreadLocal = new ThreadLocal<>(); private MD5Tool() { } /** * 获取一个MD5工具实例 */ public static MD5Tool getInstance() { if (md5ToolThreadLocal.get() == null) { md5ToolThreadLocal.set(new MD5Tool()); } return md5ToolThreadLocal.get(); } /** * 通过md5进行加密 * * @param source 要加密的数据 * @return * @throws NoSuchAlgorithmException */ public String getMd5(String source) throws NoSuchAlgorithmException { //1.获取MessageDigest对象 MessageDigest digest = MessageDigest.getInstance("md5"); //2.执行加密操作 byte[] bytes = source.getBytes(); //在MD5算法这,得到的目标字节数组的特点:长度固定为16 byte[] targetBytes = digest.digest(bytes); //3.声明字符数组 char[] characters = new char[]{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'}; //4.遍历targetBytes StringBuilder builder = new StringBuilder(); for (byte b : targetBytes) { //5.取出b的高四位的值 //先把高四位通过右移操作拽到低四位 int high = (b >> 4) & 15; //6.取出b的低四位的值 int low = b & 15; //7.以high为下标从characters中取出对应的十六进制字符 char highChar = characters[high]; //8.以low为下标从characters中取出对应的十六进制字符 char lowChar = characters[low]; builder.append(highChar).append(lowChar); } return builder.toString(); } }
到此这篇关于Java中MessageDigest来实现数据加密的方法的文章就介绍到这了,更多相关MessageDigest 数据加密内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
本文向大家介绍java使用RSA加密方式实现数据加密解密的代码,包括了java使用RSA加密方式实现数据加密解密的代码的使用技巧和注意事项,需要的朋友参考一下 RSA的应用 RSA是一种非对称加密算法。现在,很多登陆表单的密码的都采用RSA加密,例如京东中的登陆使用公钥对密码进行加密 java使用RSA加密方式实现数据加密解密,需要首先产生私钥和公钥 测试代码 RSA工具类的实现 总结 以上所述是
本文向大家介绍java中加密的实现方法(MD5,MD2,SHA),包括了java中加密的实现方法(MD5,MD2,SHA)的使用技巧和注意事项,需要的朋友参考一下 java中加密的实现方法(MD5,MD2,SHA) 实例代码:注释都很清楚, 输出结果: 以上就是java 加密的实例,如疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
本文向大家介绍PHP对称加密函数实现数据的加密解密,包括了PHP对称加密函数实现数据的加密解密的使用技巧和注意事项,需要的朋友参考一下 项目中有一个地方用到了将用户ID加密、传至下个接点进行反解的需求。(原谅我不能透漏太多-_-!),第一个想到的就是康盛Ucenter中的一个函数,后来搜了下,在简明魔法中也找到了个简单的方法,遂整合了下,形成了自己使用的函数。 一、对称加密 发送方将明文使用密钥和
本文向大家介绍Java AES加密解密的简单实现方法,包括了Java AES加密解密的简单实现方法的使用技巧和注意事项,需要的朋友参考一下 废话不多说,直接上代码 以上这篇Java AES加密解密的简单实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
本文向大家介绍java实现MD5加密的方法小结,包括了java实现MD5加密的方法小结的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了java实现MD5加密的方法。分享给大家供大家参考,具体如下: 方法二 PS:关于加密解密感兴趣的朋友还可以参考本站在线工具: 文字在线加密解密工具(包含AES、DES、RC4等): http://tools.jb51.net/password/txt_en
本文向大家介绍php实现cookie加密的方法,包括了php实现cookie加密的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php实现cookie加密的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的php程序设计有所帮助。