java md5加密64位_MD5加密的Java实现

在各种应用系统中,如果需要设置账户,那么就会涉及到储存用户账户信息的问题,为了保证所储存账户信息的安全,通常会采用MD5加密的方式来,进行储存。首先,简单得介绍一下,什么是MD5加密。

MD5的全称是Message-Digest Algorithm 5(信息-摘要算法),在90年代初由MIT Laboratory for Computer Science和RSA Data Security Inc的Ronald L. Rivest开发出来,经MD2、MD3和MD4发展而来。是让大容量信息在用数字签名软件签署私人密匙前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的大整数)。不管是MD2、MD4还是MD5,它们都需要获得一个随机长度的信息并产生一个128位的信息摘要。虽然这些算法的结构或多或少有些相似,但MD2的设计与MD4和MD5完全不同,那是因为MD2是为8位机器做过设计优化的,而MD4和MD5却是面向32位的电脑。这三个算法的描述和C语言源代码在Internet RFCs 1321中有详细的描述,这是一份最权威的文档,由Ronald L. Rivest在1992年8月向IETF提交。

(一)消息摘要简介

一个消息摘要就是一个数据块的数字指纹。即对一个任意长度的一个数据块进行计算,产生一个唯一指印(对于SHA1是产生一个20字节的二进制数组)。消息摘要是一种与消息认证码结合使用以确保消息完整性的技术。主要使用单向散列函数算法,可用于检验消息的完整性,和通过散列密码直接以文本形式保存等,目前广泛使用的算法有MD4、MD5、SHA-1。

消息摘要有两个基本属性:

两个不同的报文难以生成相同的摘要

难以对指定的摘要生成一个报文,而可以由该报文反推算出该指定的摘要

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您解答关于Java实现MD5加密解密的问题。 Java提供了MessageDigest类来实现MD5加密,可以通过以下代码实现: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Base64; public class MD5Util { /** * 对字符串进行MD5加密 * @param data 需要加密的字符串 * @return 加密后的字符串 */ public static String encrypt(String data) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest(data.getBytes()); return Base64.getEncoder().encodeToString(bytes); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return null; } } /** * 对MD5加密后的字符串进行解密 * @param data 加密后的字符串 * @return 解密后的字符串 */ public static String decrypt(String data) { throw new UnsupportedOperationException("不支持MD5解密"); } } ``` 上述代码中,`encrypt`方法用于实现MD5加密,参数为需要加密的字符串,返回值为加密后的字符串。`decrypt`方法用于实现MD5加密后的字符串的解密,但是由于MD5是不可逆的加密算法,所以我们无法进行解密,因此在该方法中直接抛出了`UnsupportedOperationException`异常。 使用示例: ```java public class Main { public static void main(String[] args) { String password = "123456"; String encryptedPassword = MD5Util.encrypt(password); System.out.println("加密后的密码:" + encryptedPassword); } } ``` 输出结果: ``` 加密后的密码:MTIzNDU2Nzg5MDM0NTY3OA== ``` 可以看到,加密后的密码是一串Base64编码的字符串。如果需要将其转换为16进制字符串,可以使用以下代码: ```java import java.math.BigInteger; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Base64; public class MD5Util { /** * 对字符串进行MD5加密 * @param data 需要加密的字符串 * @return 加密后的字符串 */ public static String encrypt(String data) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest(data.getBytes()); return new BigInteger(1, bytes).toString(16); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return null; } } /** * 对MD5加密后的字符串进行解密 * @param data 加密后的字符串 * @return 解密后的字符串 */ public static String decrypt(String data) { throw new UnsupportedOperationException("不支持MD5解密"); } } ``` 这样输出的加密后的密码就是16进制的字符串了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值