1.简介
MD5即Message-Digest Algorithm 5(信息-摘要算法 5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。
将数据(如汉字)运算为另一固定长度值是杂凑算法的基础原理,MD5的前身有MD2、MD3和MD4。
MD5的典型应用是对一段信息(Message)产生信息摘要(Message-Digest),以防止被篡改。比如,在UNIX下有很多软件在下载的时候都有一个文件名相同,文件扩展名为.md5的文件,在这个文件中通常只有一行文本,大致结构如:
MD5 (tanajiya.tar.gz) = 0ca175b9c0f726a831d895e269332461
这就是tanajiya.tar.gz文件的数字签名。MD5将整个文件当作一个大文本信息,通过其不可逆的字符串变换算法,产生了这个唯一的MD5信息摘要。
2.java实现类
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class MD5Util {
/** */
/**
* The hex digits.
*/
private static final String[] hexDigits = { "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };
/** */
/**
* Transform the byte array to hex string.
*
* @param b
* @return
*/
public static String byteArrayToHexString(byte[] b) {
StringBuffer resultSb = new StringBuffer();
for (int i = 0; i < b.length; i++) {
resultSb.append(byteToHexString(b[i]));
}
return resultSb.toString();
}
/** */
/**
* Transform a byte to hex string.
*
* @param b
* @return
*/
private static String byteToHexString(byte b) {
int n = b;
if (n < 0)
n = 256 + n;
// get the first four bit
int d1 = n / 16;
// get the second four bit
int d2 = n % 16;
return hexDigits[d1] + hexDigits[d2];
}
/** */
/**
* Get the MD5 encrypt hex string of the origin string. <br/>
* The origin string won't validate here, so who use the API should validate
* by himself.
*
* @param origin
* @return
* @throws NoSuchAlgorithmException
*/
public static String MD5Encode(String origin)
throws NoSuchAlgorithmException {
MessageDigest md = MessageDigest.getInstance("MD5");
return byteArrayToHexString(md.digest(origin.getBytes()));
}
public static void main(String[] args) {
try {
System.out.println("md5 admin= " + MD5Util.MD5Encode("md5 admin") +
",length=" + MD5Util.MD5Encode("md5 admin").length() );
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
}
分享到:
相关推荐
MD5是一种广泛使用的不可逆加密算法,全称为Message-Digest Algorithm 5,它将任意长度的输入(也叫做预映射或message)转化为一个固定长度的输出,即128位(16字节)的摘要。这个摘要值通常表示为32个十六进制数字...
### 常用MD5加密算法和3-DES加密算法Java实现 在现代软件开发过程中,数据的安全性变得越来越重要。对于数据传输和存储过程中的安全性保障,加密技术发挥着至关重要的作用。本文将详细介绍如何在Java环境中实现两种...
java实现md5 加密解密(在网络中MD5是著名的不可逆算法,但是如果知道MD5的加密的字符串 则可以通过自己的加密算法对明文进行加密,对加密后的密文与字符串匹配; 匹配成功,表示找到明文;但是此程序的时间耗费较高!仅...
Java中实现MD5加密算法的简单实例主要介绍了如何使用Java语言来实现MD5加密算法,提供了一个简单的实例帮助大家应用这样的加密算法。MD5加密算法是一种不可逆的加密算法,破解的难度很高,通常将加密后的密文保存在...
### 基于JAVA技术的MD5加密算法的设计与实现 #### 1. MD5算法概述 MD5(Message-Digest Algorithm 5)是一种广泛应用于数字签名、电子商务、信息加密等领域的散列算法。它能够将任意长度的消息压缩成一个固定长度...
在IT行业中,MD5常常用于数据校验,比如验证文件的完整性,或者在存储密码时,将密码转化为不可逆的MD5摘要,以增加安全性。 在给定的压缩包文件中,有两个MD5加密类:MD5.java和MD5_simple.java。这两个类可能实现...
在Java编程语言中,MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希函数,主要目的是为了产生一个固定长度的、不可逆的数字摘要,常用于存储密码。MD5算法将任意长度的输入(也叫做预映射,pre-image)通过...
在Java中,MD5加密算法常用于数据校验、密码存储等场景,因为它的计算速度快且结果具有高度的不可逆性。 **MD5的基本原理:** MD5算法基于消息摘要思想,它接收任意长度的消息,通过一系列的数学运算(如位移、异或...
本文将详细介绍如何使用Java实现一个简单的可逆加密算法。 首先,理解可逆加密算法的关键在于,加密过程和解密过程是相互逆操作的。也就是说,一旦数据被加密,使用相同的密钥或方法就可以解密回原始数据。这与不...
在JAVA中,MD5主要用于数据的校验和密码的加密,因为它产生的哈希值具有不可逆性,即无法通过哈希值还原原始数据,这为数据安全提供了基础。 MD5算法的基本步骤包括: 1. **初始化:** MD5算法有四个32位的中间...
本资源提供了base64、MD5、RSA和SHA1这四种常见加密算法的Java实现,并附带了相应的jar包,便于学习和应用。 首先,Base64是一种简单的编码方式,主要用于将二进制数据转换为可打印的ASCII字符,以便在网络传输或...
标题中的“JAVA与C#一致的32位MD5加密方法”指的是在Java和C#这两种编程语言中实现相同32位MD5哈希的过程。由于MD5算法本身是标准的,理论上在任何支持MD5的编程语言中都应该得到相同的输出,不论是在Java还是C#中。...
1. 不可逆性:MD5 加密算法是不可逆的,即无法通过摘要来恢复原始数据。 2.碰撞攻击:MD5 加密算法存在碰撞攻击的风险,即攻击者可以找到两个不同的输入数据,使其生成相同的摘要。 MD5 加密算法是一种常用的单向...
MD5 加密的特点是不可逆,即无法从加密后的哈希值中恢复原始数据。Java 中可以使用 MessageDigest 类来实现 MD5 加密。 MD5Utils 是一个工具类,提供了 MD5Encode 方法来实现 MD5 加密。该方法将输入的字符串转换为...
在Java中,常见的单向加密算法包括MD5(Message-Digest Algorithm 5)、SHA(Secure Hash Algorithm)系列以及HMAC(Hash-based Message Authentication Code)。 **BASE64编码** 虽然BASE64不是真正的加密算法,...
在Java中实现加密算法涉及到多个重要的概念和技术,包括单钥密码体制、消息摘要、Diffie-Hellman密钥一致协议、非对称算法和公钥体系以及数字签名。下面将详细阐述这些知识点。 **1. 单钥密码体制** 单钥密码体制,...
6. **使用说明**:`md5使用说明.txt`文件应该包含了如何在不同语言环境下使用这些MD5加密算法的详细步骤和示例。通常会包括代码片段、依赖库的安装指南、如何调用函数以及如何解释和比较MD5摘要等内容。 在实际项目...
Java作为广泛应用的编程语言,提供了多种加密方法来确保密码的安全。...总的来说,MD5在Java中的使用提供了一种简单的密码加密方式,但随着技术的发展,开发者应考虑使用更强大的加密策略来保护用户的敏感信息。
这个"MD5加密demo"包含了一些关键组件,帮助我们理解和实现MD5加密。 1. **MD5的原理与应用**: MD5设计的目标是让信息在经过哈希处理后,即使是微小的改动也会导致输出摘要的巨大变化,从而确保信息的完整性。它...