Java MD5 加密

Java MD5 加密

/**
 * @author fangzheng
 * @date 2016年9月24日 下午9:28:13
 */
public class MD5 {
	/*
	 * 四个链接变量
	 */
	private final int A = 0x67452301;
	private final int B = 0xefcdab89;
	private final int C = 0x98badcfe;
	private final int D = 0x10325476;
	/*
	 * ABCD的临时变量
	 */
	private int Atemp, Btemp, Ctemp, Dtemp;

	/*
	 * 常量ti公式:floor(abs(sin(i+1))×(2pow32)
	 */
	private final int K[] = { 0xd76aa478, 0xe8c7b756, 0x242070db, 0xc1bdceee,
			0xf57c0faf, 0x4787c62a, 0xa8304613, 0xfd469501, 0x698098d8,
			0x8b44f7af, 0xffff5bb1, 0x895cd7be, 0x6b901122, 0xfd987193,
			0xa679438e, 0x49b40821, 0xf61e2562, 0xc040b340, 0x265e5a51,
			0xe9b6c7aa, 0xd62f105d, 0x02441453, 0xd8a1e681, 0xe7d3fbc8,
			0x21e1cde6, 0xc33707d6, 0xf4d50d87, 0x455a14ed, 0xa9e3e905,
			0xfcefa3f8, 0x676f02d9, 0x8d2a4c8a, 0xfffa3942, 0x8771f681,
			0x6d9d6122, 0xfde5380c, 0xa4beea44, 0x4bdecfa9, 0xf6bb4b60,
			0xbebfbc70, 0x289b7ec6, 0xeaa127fa, 0xd4ef3085, 0x04881d05,
			0xd9d4d039, 0xe6db99e5, 0x1fa27cf8, 0xc4ac5665, 0xf4292244,
			0x432aff97, 0xab9423a7, 0xfc93a039, 0x655b59c3, 0x8f0ccc92,
			0xffeff47d, 0x85845dd1, 0x6fa87e4f, 0xfe2ce6e0, 0xa3014314,
			0x4e0811a1, 0xf7537e82, 0xbd3af235, 0x2ad7d2bb, 0xeb86d391 };
	/*
	 * 向左位移数,计算方法未知
	 */
	private final int s[] = { 7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22, 7,
			12, 17, 22, 5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20,
			4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23, 6, 10,
			15, 21, 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21 };

	/*
	 * 初始化函数
	 */
	private void init() {
		Atemp = A;
		Btemp = B;
		Ctemp = C;
		Dtemp = D;
	}

	/*
	 * 移动一定位数
	 */
	private int shift(int a, int s) {
		return (a << s) | (a >>> (32 - s));// 右移的时候,高位一定要补零,而不是补充符号位
	}

	/*
	 * 主循环
	 */
	private void MainLoop(int M[]) {
		int F, g;
		int a = Atemp;
		int b = Btemp;
		int c = Ctemp;
		int d = Dtemp;
		for (int i = 0; i < 64; i++) {
			if (i < 16) {
				F = (b & c) | ((~b) & d);
				g = i;
			} else if (i < 32) {
				F = (d & b) | ((~d) & c);
				g = (5 * i + 1) % 16;
			} else if (i < 48) {
				F = b ^ c ^ d;
				g = (3 * i + 5) % 16;
			} else {
				F = c ^ (b | (~d));
				g = (7 * i) % 16;
			}
			int tmp = d;
			d = c;
			c = b;
			b = b + shift(a + F + K[i] + M[g], s[i]);
			a = tmp;
		}
		Atemp = a + Atemp;
		Btemp = b + Btemp;
		Ctemp = c + Ctemp;
		Dtemp = d + Dtemp;

	}

	/*
	 * 填充函数处理后应满足bits≡448(mod512),字节就是bytes≡56(mode64)填充方式为先加一个0,其它位补零
	 * 最后加上64位的原来长度
	 */
	private int[] add(String str) {
		int num = ((str.length() + 8) / 64) + 1;// 以512位,64个字节为一组
		int strByte[] = new int[num * 16];// 64/4=16,所以有16个整数
		for (int i = 0; i < num * 16; i++) {// 全部初始化0
			strByte[i] = 0;
		}
		int i;
		for (i = 0; i < str.length(); i++) {
			strByte[i >> 2] |= str.charAt(i) << ((i % 4) * 8);// 一个整数存储四个字节,小端序
		}
		strByte[i >> 2] |= 0x80 << ((i % 4) * 8);// 尾部添加1
		/*
		 * 添加原长度,长度指位的长度,所以要乘8,然后是小端序,所以放在倒数第二个,这里长度只用了32位
		 */
		strByte[num * 16 - 2] = str.length() * 8;
		return strByte;
	}

	/*
	 * 调用函数
	 */
	public String getMD5(String source) {
		init();
		int strByte[] = add(source);
		for (int i = 0; i < strByte.length / 16; i++) {
			int num[] = new int[16];
			for (int j = 0; j < 16; j++) {
				num[j] = strByte[i * 16 + j];
			}
			MainLoop(num);
		}
		return changeHex(Atemp) + changeHex(Btemp) + changeHex(Ctemp)
				+ changeHex(Dtemp);

	}

	/*
	 * 整数变成16进制字符串
	 */
	private String changeHex(int a) {
		String str = "";
		for (int i = 0; i < 4; i++) {
			str += String.format("%2s",
					Integer.toHexString(((a >> i * 8) % (1 << 8)) & 0xff))
					.replace(' ', '0');

		}
		return str;
	}

	/*
	 * 单例
	 */
	private static MD5 instance;

	public static MD5 getInstance() {
		if (instance == null) {
			instance = new MD5();
		}
		return instance;
	}

	private MD5() {
	};

	public static void main(String[] args) {
		String str = MD5.getInstance().getMD5("regregregresgresgrs");
		System.out.println(str);
	}
}


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,可以使用MD5加密算法对数据进行加密。引用是一个示例代码,展示了如何使用MD5加密算法对输入的用户名和密码进行加密。代码中使用了一个Md5类,它包含了一个md5方法,用于对输入数据进行MD5加密。引用展示了Md5类的具体实现。 要使用MD5加密对密码进行加密,可以调用Md5类的md5方法,并传入要加密的字符串作为参数。该方法将返回加密后的字符串。 在加密时,可以使用“加盐”的方式增加密码的安全性。这意味着将用户的用户名作为额外的参数传入md5方法,与密码一起进行加密。这样即使两个用户使用相同的密码,最终的加密结果也会不同。 需要注意的是,MD5加密是不可逆的,即无法从加密后的密码还原出原始密码。因此,一般在登录时,会将用户输入的密码进行加密后,与数据库中存储的加密后的密码进行比对来验证登录信息。引用展示了一个示例,其中将用户输入的密码进行MD5加密后,再与数据库中存储的密码进行比对。 综上所述,要在Java中进行MD5加密,可以使用Md5类的md5方法,将要加密的字符串作为参数传入。为了增加密码的安全性,可以使用“加盐”的方式,将用户的用户名作为额外的参数传入md5方法进行加密。在登录时,将用户输入的密码进行MD5加密后,与数据库中存储的加密后的密码进行比对来验证登录信息。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Java md5加密](https://blog.csdn.net/weixin_65637841/article/details/124889207)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值