原文链接:http://blog.csdn.net/hbcui1984/article/details/5065506
DES加密介绍
DES是一种对称加密算法,所谓对称加密算法即:加密和解密使用相同密钥的算法。DES加密算法出自IBM的研究,后来被美国政府正式采用,之后开始广泛流传,但是近些年使用越来越少,因为DES使用56位密钥,以现代计算能力,24小时内即可被破解。虽然如此,在某些简单应用中,我们还是可以使用DES加密算法,本文简单讲解DES的JAVA实现。
public class DesDemo {
/**
* @param args
*/
public static void main(String[] args) {
demoDES();
}
private static void demoDES() {
//需要加密的数据源
byte[] datasource = { 'k', 'f', 'c' };
//加密使用的密码,加密和解密用的是同一个密码(密钥),所以DES加密是一种对称加密
//DES加密的密码长度必须是8的倍数。
String password = "12345678";
//加密之后的数据
byte[] res = DesUtil.desCrypto(datasource, password);
// System.out.println(new String(res));
//加密之后的数据一般是看不懂的
//一般不会将加密之后的数据转换成String类型
//解密。
byte[] data=DesUtil.decrypt(res, password);
System.out.println(new String(data));//kfc
}
}
public class DesUtil {
/**
* 使用DES对数据进行加密
*
* @param datasource
* @param password
* @return
*/
public static byte[] desCrypto(byte[] datasource, String password) {
if (password.length() < 8 || (password.length() % 8 != 0)) {
return "password的长度必须为8的倍数".getBytes();
}
try {
SecureRandom random = new SecureRandom();
DESKeySpec deskey = new DESKeySpec(password.getBytes());
// 创建一个密钥工厂
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
// 使用密钥工厂把DESKeySpec转换成SecretKey
SecretKey secretKey = keyFactory.generateSecret(deskey);
// Cipher对象实际完成加密操作
Cipher cipher = Cipher.getInstance("DES");
// 用密钥初始化Cipher对象
cipher.init(Cipher.ENCRYPT_MODE, secretKey, random);
// 现在,获取数据并加密
// 正式执行加密操作
return cipher.doFinal(datasource);
} catch (Exception e) {
}
return null;
}
/**
* 使用DES对数据进行解密
*
* @param src
* @param password
* @return
*/
public static byte[] decrypt(byte[] src, String password) {
if (password.length() < 8 || (password.length() % 8 != 0)) {
return "password的长度必须为8的倍数".getBytes();
}
try {
// DES算法要求有一个可信任的随机数源
SecureRandom random = new SecureRandom();
// 创建一个DESKeySpec对象
DESKeySpec desKey = new DESKeySpec(password.getBytes());
// 创建一个密匙工厂
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
// 将DESKeySpec对象转换成SecretKey对象
SecretKey securekey = keyFactory.generateSecret(desKey);
// Cipher对象实际完成解密操作
Cipher cipher = Cipher.getInstance("DES");
// 用密匙初始化Cipher对象
cipher.init(Cipher.DECRYPT_MODE, securekey, random);
// 真正开始解密操作
return cipher.doFinal(src);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
}