MD5加密算法(java版)

本文介绍了使用Java实现MD5加密算法的过程,包括字节数组到16进制字符串的转换方法,以及如何对原始字符串进行MD5编码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 1 package com.tencent.common;
 2 
 3 import java.security.MessageDigest;
 4 
 5 public class MD5 {
 6     private final static String[] hexDigits = {"0", "1", "2", "3", "4", "5", "6", "7",
 7             "8", "9", "a", "b", "c", "d", "e", "f"};
 8 
 9     /**
10      * 转换字节数组为16进制字串
11      * @param b 字节数组
12      * @return 16进制字串
13      */
14     public static String byteArrayToHexString(byte[] b) {
15         StringBuilder resultSb = new StringBuilder();
16         for (byte aB : b) {
17             resultSb.append(byteToHexString(aB));
18         }
19         return resultSb.toString();
20     }
21 
22     /**
23      * 转换byte到16进制
24      * @param b 要转换的byte
25      * @return 16进制格式
26      */
27     private static String byteToHexString(byte b) {
28         int n = b;
29         if (n < 0) {
30             n = 256 + n;
31         }
32         int d1 = n / 16;
33         int d2 = n % 16;
34         return hexDigits[d1] + hexDigits[d2];
35     }
36 
37     /**
38      * MD5编码
39      * @param origin 原始字符串
40      * @return 经过MD5加密之后的结果
41      */
42     public static String MD5Encode(String origin) {
43         String resultString = null;
44         try {
45             resultString = origin;
46             MessageDigest md = MessageDigest.getInstance("MD5");
47             resultString = byteArrayToHexString(md.digest(resultString.getBytes()));
48         } catch (Exception e) {
49             e.printStackTrace();
50         }
51         return resultString;
52     }
53 
54 }

 以上代码摘自微信支付官方Demo,仅作个人学习使用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值