springBoot中使用MD5加密

第一步引入相关的依赖

<dependency>
           <groupId>commons-codec</groupId>
           <artifactId>commons-codec</artifactId>
           <version>1.9</version>
        </dependency>

第二步,写加密文件

package com.ysd.dto;

import java.io.FileInputStream;
import java.security.DigestInputStream;
import java.security.MessageDigest;

public class MD5Util
{

private static MessageDigest md5 = null;
static
{
try
{
md5 = MessageDigest.getInstance("MD5");
}
catch (Exception e)
{
System.out.println(e.getMessage());
}
}

/**
* 用于获取一个String的md5值
* 
* @param string
* @return
*/
public static String getMd5(String str)
{
byte[] bs = md5.digest(str.getBytes());
StringBuilder sb = new StringBuilder(40);
for (byte x : bs)
{
if ((x & 0xff) >> 4 == 0)
{
sb.append("0").append(Integer.toHexString(x & 0xff));
}
else
{
sb.append(Integer.toHexString(x & 0xff));
}
}
return sb.toString();
}

/**
* 文件md5
*  @param inputFile
*  @return
*  @author ms
*/
public static String fileMD5(String inputFile)
{
// 缓冲区大小(这个可以抽出一个参数)
int bufferSize = 256 * 1024;
FileInputStream fileInputStream = null;
DigestInputStream digestInputStream = null;
try
{
// 拿到一个MD5转换器(同样,这里可以换成SHA1)
MessageDigest messageDigest = MessageDigest.getInstance("MD5");
// 使用DigestInputStream
fileInputStream = new FileInputStream(inputFile);
digestInputStream = new DigestInputStream(fileInputStream, messageDigest);
// read的过程中进行MD5处理,直到读完文件
byte[] buffer = new byte[bufferSize];
while (digestInputStream.read(buffer) > 0);
// 获取最终的MessageDigest
messageDigest = digestInputStream.getMessageDigest();
// 拿到结果,也是字节数组,包含16个元素
byte[] resultByteArray = messageDigest.digest();
// 同样,把字节数组转换成字符串
return byteArrayToHex(resultByteArray);
}
catch (Exception e)
{
return null;
}
finally
{
try
{
digestInputStream.close();
}
catch (Exception e)
{
e.printStackTrace();
}
try
{
fileInputStream.close();
}
catch (Exception e)
{
e.printStackTrace();
}
}
}

public static String byteArrayToHex(byte[] b)
{
String hs = "";
String stmp = "";
for (int n = 0; n < b.length; n++)
{
stmp = (Integer.toHexString(b[n] & 0XFF));
if (stmp.length() == 1)
{
hs = hs + "0" + stmp;
}
else
{
hs = hs + stmp;
}
if (n < b.length - 1)
{
hs = hs + "";
}
}
return hs;

}

}

第三步加密测试


public static void main(String[] args) {
	String s = MD5Util.getMd5("张三");
	System.out.println(s);
	
}

完成自己动手试试

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值