Java中MessageDigest来实现数据加密的方法

网友投稿 390 2022-12-06


Java中MessageDigest来实现数据加密的方法

MessageDigest

MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,输出固定长度的哈希值。

MessageDigest 对象开始被初始化。该对象通过使用 update 方法处理数据。任何时候都可以调用 reset 方法重置摘要。一旦所有需要更新的数据都已经被更新了,应该调用 digest 方法之一完成哈希计算。

对于给定数量的更新数据,digest 方法只能被调用一次。digest 被调用后,MessageDigest 对象被重新设置成其初始状态。

举个简单的md5加密的例子:

package com.company;

impohttp://rt 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 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();

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:spring 注解验证@NotNull等使用方法
下一篇:JAVA参数传递方式实例浅析【按值传递与引用传递区别】
相关文章

 发表评论

暂时没有评论,来抢沙发吧~