MD5加密 java类及解释

MD5是一种典型的不可逆数据
理论上可以把较大的数据加密成定长的字符串
是存在数据丢失的 所以理论上是不可能被反向解密的
java的加密依赖于一个MD5的工具类
源代码如下

package cn.itcast.estore.utils;

import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class MD5Utils {
	/**
	 * 使用md5的算法进行加密
	 */
	public static String md5(String plainText) {
		byte[] secretBytes = null;
		try {
			secretBytes = MessageDigest.getInstance("md5").digest(
					plainText.getBytes());
		} catch (NoSuchAlgorithmException e) {
			throw new RuntimeException("没有md5这个算法!");
		}
		String md5code = new BigInteger(1, secretBytes).toString(16);// 16进制数字
		// 如果生成数字未满32位,需要前面补0
		for (int i = 0; i < 32 - md5code.length(); i++) {
			md5code = "0" + md5code;
		}
		return md5code;
	}

	public static void main(String[] args) {
		System.out.println(md5("123"));
	}

}

猜你喜欢

转载自blog.csdn.net/qq_41009846/article/details/82908457
今日推荐