MD5算法
就是将已知的明文密码转换成固定长度的MD5
MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。将数据(如汉字)运算为另一固定长度值,是杂凑算法的基础原理,MD5的前身有MD2、MD3和MD4。
MD5算法具有以下特点:
1、压缩性:任意长度的数据,算出的MD5值长度都是固定的。
2、容易计算:从原数据计算出MD5值很容易。
3、抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。
4、强抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。
MD5的作用是让大容量信息在用数字签名软件签署私人密钥前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的十六进制数字串)。除了MD5以外,其中比较有名的还有sha-1、RIPEMD以及Haval等。
JAVA中的摘要算法简单示例:
- package com.zhuifeng.util;
- import java.security.MessageDigest;
- /**
- * @author guoxk
- *
- * @version 创建时间 2016年1月7日 下午1:47:06
- *
- * 类描述:MD5加密工具类
- *
- */
- public class MD5Util{
- /**
- * @author guoxk
- *
- * 方法描述:MD5加密方法
- * @param str 明文
- * @param charSet 字符编码
- * @return 密文
- */
- public static String MD5(String str,String charSet) {
- MessageDigest messageDigest = null;
- try {
- messageDigest = MessageDigest.getInstance("MD5");
- messageDigest.reset();
- if(charSet==null){
- messageDigest.update(str.getBytes());
- }else{
- messageDigest.update(str.getBytes(charSet));
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- byte[] byteArray = messageDigest.digest();
- StringBuffer md5StrBuff = new StringBuffer();
- for (int i = 0; i < byteArray.length; i++) {
- if (Integer.toHexString(0xFF & byteArray[i]).length() == 1)
- md5StrBuff.append("0").append(Integer.toHexString(0xFF & byteArray[i]));
- else
- md5StrBuff.append(Integer.toHexString(0xFF & byteArray[i]));
- }
- return md5StrBuff.toString();
- }
- /**
- * @author guoxk
- *
- * 方法描述:MD5加密方法 --- UTF-8编码
- * @param s 明文
- * @return 密文
- */
- public static String MD5(String s) {
- char hexDigits[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
- try {
- byte[] btInput = s.getBytes("utf-8");
- // 获得MD5摘要算法的 MessageDigest 对象
- MessageDigest mdInst = MessageDigest.getInstance("MD5");
- // 使用指定的字节更新摘要
- mdInst.update(btInput);
- // 获得密文
- byte[] md = mdInst.digest();
- // 把密文转换成十六进制的字符串形式
- int j = md.length;
- char str[] = new char[j * 2];
- int k = 0;
- for (int i = 0; i < j; i++) {
- byte byte0 = md[i];
- str[k++] = hexDigits[byte0 >>> 4 & 0xf];
- str[k++] = hexDigits[byte0 & 0xf];
- }
- return new String(str);
- } catch (Exception e) {
- e.printStackTrace();
- return null;
- }
- }
- public static void main(String[] args) {
- String password = "ming wen mi ma";
- System.out.println("原明文:" + password);
- String pw = MD5(password);//默认utf-8编码加密,32位大写,
- System.out.println("32位大写UTF-8加密后:" + pw);//C0389AC882DFCCA5592628F139F7A975
- String pw2 = MD5(password,"GBK");//自定义编码加密,32位小写
- System.out.println("32位小写自定义编码加密后:" + pw2);//c0389ac882dfcca5592628f139f7a975
- }
- }