在项目中经常会对一些信息进行加密,现在常用的信息加密技术有:MD5、RSA、DES等,今天主要说一下,md5加密,以及如何在java代码根据自己的业务需求使用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等。
MD5在java中如何使用:
package com.ow.util; import java.security.MessageDigest; /**
* 采用MD5加密解密
*/
public class MD5Util { /***
* MD5加码 生成32位md5码
*/
public static String string2MD5(String inStr){
MessageDigest md5 = null;
try{
md5 = MessageDigest.getInstance("MD5");
}catch (Exception e){
System.out.println(e.toString());
e.printStackTrace();
return "";
}
char[] charArray = inStr.toCharArray();
byte[] byteArray = new byte[charArray.length]; for (int i = 0; i < charArray.length; i++)
byteArray[i] = (byte) charArray[i];
byte[] md5Bytes = md5.digest(byteArray);
StringBuffer hexValue = new StringBuffer();
for (int i = 0; i < md5Bytes.length; i++){
int val = ((int) md5Bytes[i]) & 0xff;
if (val < 16)
hexValue.append("0");
hexValue.append(Integer.toHexString(val));
}
return hexValue.toString(); }
/**
* 根据自己的规则进行MD5加密
* 例如,现在需求是有字符串传入zhang,xy
* 其中zhang是传入的字符
* 然后需要将zhang的字符进行拆分z,和hang,
* 最后需要加密的字段为zxyhang
*/
public static String MD5Test(String inStr){
String xy = "xy";
String finalStr="";
if(inStr!=null){
String fStr = inStr.substring(0, 1);
String lStr = inStr.substring(1, inStr.length());
finalStr = string2MD5( fStr+xy+lStr); }else{
finalStr = string2MD5(xy);
}
return finalStr;
} // 测试
public static void main(String args[]) {
String s1 = "zhang";
System.out.println("使用工具类进行加密的为 "+MD5Test(s1)); }
}
其中函数MD5Test中的逻辑可以自己修改,修改成为与自己项目相关的代码逻辑即可。
参考文章:http://blog.csdn.net/xiangsuixinsheng/article/details/6871868