DES加密

原文链接: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;
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值