`
danwind
  • 浏览: 232806 次
  • 性别: Icon_minigender_1
  • 来自: 广东
社区版块
存档分类
最新评论

不可逆加密算法之MD5,Java实现

    博客分类:
  • Java
阅读更多
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();
		}
	}
}
分享到:
评论

相关推荐

    java不可逆加密算法之md5加密算法使用示例

    MD5是一种广泛使用的不可逆加密算法,全称为Message-Digest Algorithm 5,它将任意长度的输入(也叫做预映射或message)转化为一个固定长度的输出,即128位(16字节)的摘要。这个摘要值通常表示为32个十六进制数字...

    常用MD5加密算法和3-DES加密算法java实现

    ### 常用MD5加密算法和3-DES加密算法Java实现 在现代软件开发过程中,数据的安全性变得越来越重要。对于数据传输和存储过程中的安全性保障,加密技术发挥着至关重要的作用。本文将详细介绍如何在Java环境中实现两种...

    java实现md5 加密解密

    java实现md5 加密解密(在网络中MD5是著名的不可逆算法,但是如果知道MD5的加密的字符串 则可以通过自己的加密算法对明文进行加密,对加密后的密文与字符串匹配; 匹配成功,表示找到明文;但是此程序的时间耗费较高!仅...

    java 实现MD5加密算法的简单实例

    Java中实现MD5加密算法的简单实例主要介绍了如何使用Java语言来实现MD5加密算法,提供了一个简单的实例帮助大家应用这样的加密算法。MD5加密算法是一种不可逆的加密算法,破解的难度很高,通常将加密后的密文保存在...

    基于JAVA技术的MD5加密算法的设计与实现

    ### 基于JAVA技术的MD5加密算法的设计与实现 #### 1. MD5算法概述 MD5(Message-Digest Algorithm 5)是一种广泛应用于数字签名、电子商务、信息加密等领域的散列算法。它能够将任意长度的消息压缩成一个固定长度...

    md5加密算法的两种方法

    在IT行业中,MD5常常用于数据校验,比如验证文件的完整性,或者在存储密码时,将密码转化为不可逆的MD5摘要,以增加安全性。 在给定的压缩包文件中,有两个MD5加密类:MD5.java和MD5_simple.java。这两个类可能实现...

    JAVA中MD5加密密码算法

    在Java编程语言中,MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希函数,主要目的是为了产生一个固定长度的、不可逆的数字摘要,常用于存储密码。MD5算法将任意长度的输入(也叫做预映射,pre-image)通过...

    MD5加密算法(java)

    在Java中,MD5加密算法常用于数据校验、密码存储等场景,因为它的计算速度快且结果具有高度的不可逆性。 **MD5的基本原理:** MD5算法基于消息摘要思想,它接收任意长度的消息,通过一系列的数学运算(如位移、异或...

    java实现可逆加密算法

    本文将详细介绍如何使用Java实现一个简单的可逆加密算法。 首先,理解可逆加密算法的关键在于,加密过程和解密过程是相互逆操作的。也就是说,一旦数据被加密,使用相同的密钥或方法就可以解密回原始数据。这与不...

    JAVA高手MD5加密算法底层源码完美实现

    在JAVA中,MD5主要用于数据的校验和密码的加密,因为它产生的哈希值具有不可逆性,即无法通过哈希值还原原始数据,这为数据安全提供了基础。 MD5算法的基本步骤包括: 1. **初始化:** MD5算法有四个32位的中间...

    base64/md5/RSA/SHA1等加密算法Java实现,附jar包

    本资源提供了base64、MD5、RSA和SHA1这四种常见加密算法的Java实现,并附带了相应的jar包,便于学习和应用。 首先,Base64是一种简单的编码方式,主要用于将二进制数据转换为可打印的ASCII字符,以便在网络传输或...

    JAVA与C#一致的32位MD5加密方法

    标题中的“JAVA与C#一致的32位MD5加密方法”指的是在Java和C#这两种编程语言中实现相同32位MD5哈希的过程。由于MD5算法本身是标准的,理论上在任何支持MD5的编程语言中都应该得到相同的输出,不论是在Java还是C#中。...

    MD5加密算法

    1. 不可逆性:MD5 加密算法是不可逆的,即无法通过摘要来恢复原始数据。 2.碰撞攻击:MD5 加密算法存在碰撞攻击的风险,即攻击者可以找到两个不同的输入数据,使其生成相同的摘要。 MD5 加密算法是一种常用的单向...

    浅析Java 常用的 4 种加密方式(MD5+Base64+SHA+BCrypt)

    MD5 加密的特点是不可逆,即无法从加密后的哈希值中恢复原始数据。Java 中可以使用 MessageDigest 类来实现 MD5 加密。 MD5Utils 是一个工具类,提供了 MD5Encode 方法来实现 MD5 加密。该方法将输入的字符串转换为...

    单向加密算法的Java实现

    在Java中,常见的单向加密算法包括MD5(Message-Digest Algorithm 5)、SHA(Secure Hash Algorithm)系列以及HMAC(Hash-based Message Authentication Code)。 **BASE64编码** 虽然BASE64不是真正的加密算法,...

    JAVA上加密算法的实现用例.doc

    在Java中实现加密算法涉及到多个重要的概念和技术,包括单钥密码体制、消息摘要、Diffie-Hellman密钥一致协议、非对称算法和公钥体系以及数字签名。下面将详细阐述这些知识点。 **1. 单钥密码体制** 单钥密码体制,...

    三种语言md5加密算法

    6. **使用说明**:`md5使用说明.txt`文件应该包含了如何在不同语言环境下使用这些MD5加密算法的详细步骤和示例。通常会包括代码片段、依赖库的安装指南、如何调用函数以及如何解释和比较MD5摘要等内容。 在实际项目...

    (Java密码加密)MD5方式

    Java作为广泛应用的编程语言,提供了多种加密方法来确保密码的安全。...总的来说,MD5在Java中的使用提供了一种简单的密码加密方式,但随着技术的发展,开发者应考虑使用更强大的加密策略来保护用户的敏感信息。

    MD5加密demo

    这个"MD5加密demo"包含了一些关键组件,帮助我们理解和实现MD5加密。 1. **MD5的原理与应用**: MD5设计的目标是让信息在经过哈希处理后,即使是微小的改动也会导致输出摘要的巨大变化,从而确保信息的完整性。它...

Global site tag (gtag.js) - Google Analytics