博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
转: java DES的算法片码
阅读量:6856 次
发布时间:2019-06-26

本文共 3096 字,大约阅读时间需要 10 分钟。

转自: https://www.zhihu.com/question/36767829

 

作者:郭无心
链接:https://www.zhihu.com/question/36767829/answer/68911532
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

一、DES算法的历史

  美国国家标准局1973年开始研究除国防部外的其它部门的计算机系统的数据加密标准,于1973年5月15日和1974年8月27日先后两次向公众发出了征求加密算法的公告。加密算法要达到的目的(通常称为DES 密码算法要求)主要为以下四点:

☆提供高质量的数据保护,防止数据未经授权的泄露和未被察觉的修改;

☆具有相当高的复杂性,使得破译的开销超过可能获得的利益,同时又要便于理解和掌握;

☆DES密码体制的安全性应该不依赖于算法的保密,其安全性仅以加密密钥的保密为基础;

☆实现经济,运行有效,并且适用于多种完全不同的应用。

1977年1月,美国政府颁布:采纳IBM公司设计的方案作为非机密数据的正式

数据加密标准(DES Data Encryption Standard)。

二、DES算法的应用

  目前在国内,随着三金工程尤其是金卡工程的启动,DES算法在POS、ATM、磁卡及智能卡(IC卡)、加油站、高速公路收费站等领域被广泛应用,以此来实现关键数据的保密,如信用卡持卡人的PIN的加密传输,IC卡与POS间的双向认证、金融交易数据包的MAC校验等,均用到DES算法。

Java的DES加密例子
import java.security.SecureRandom;import javax.crypto.spec.DESKeySpec;import javax.crypto.SecretKeyFactory;import javax.crypto.SecretKey;import javax.crypto.Cipher;/** * DES加密介绍 DES是一种对称加密算法,所谓对称加密算法即:加密和解密使用相同密钥的算法。DES加密算法出自IBM的研究, * 后来被美国政府正式采用,之后开始广泛流传,但是近些年使用越来越少,因为DES使用56位密钥,以现代计算能力, * 24小时内即可被破解。虽然如此,在某些简单应用中,我们还是可以使用DES加密算法,本文简单讲解DES的JAVA实现 。 * 注意:DES加密和解密过程中,密钥长度都必须是8的倍数 */public class DES{	public DES()	{	}	// 测试	public static void main(String args[])	{		// 待加密内容		String str = "测试内容";		// 密码,长度要是8的倍数		String password = "9588028820109132570743325311898426347857298773549468758875018579537757772163084478873699447306034466200616411960574122434059469100235892702736860872901247123456";		byte[] result = DES.encrypt(str.getBytes(), password);		System.out.println("加密后:" + new String(result));		// 直接将如上内容解密		try		{			byte[] decryResult = DES.decrypt(result, password);			System.out.println("解密后:" + new String(decryResult));		} catch (Exception e1)		{			e1.printStackTrace();		}	}	/**	 * 加密	 * 	 * @param datasource	 *            byte[]	 * @param password	 *            String	 * @return byte[]	 */	public static byte[] encrypt(byte[] datasource, String password)	{		try		{			SecureRandom random = new SecureRandom();			DESKeySpec desKey = new DESKeySpec(password.getBytes());			// 创建一个密匙工厂,然后用它把DESKeySpec转换成			SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");			SecretKey securekey = keyFactory.generateSecret(desKey);			// Cipher对象实际完成加密操作			Cipher cipher = Cipher.getInstance("DES");			// 用密匙初始化Cipher对象			cipher.init(Cipher.ENCRYPT_MODE, securekey, random);			// 现在,获取数据并加密			// 正式执行加密操作			return cipher.doFinal(datasource);		} catch (Throwable e)		{			e.printStackTrace();		}		return null;	}	/**	 * 解密	 * 	 * @param src	 *            byte[]	 * @param password	 *            String	 * @return byte[]	 * @throws Exception	 */	public static byte[] decrypt(byte[] src, String password) throws Exception	{		// 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);	}}
你可能感兴趣的文章
Android学习笔记(16):绝对布局AbsoluteLayout、常用距离单位
查看>>
[华为机试真题]66.单词搜索
查看>>
[From My Companion]memmem
查看>>
Magento--给EAV模型新增非EAV属性
查看>>
ASP.NET 系统支持数据库访问设计
查看>>
Use OpenVSwitch & bridge & Docker & pipework fast build complicated testing ENV
查看>>
一分钟了解阿里云产品:阿里云免费企业邮箱特点介绍及免费申请过程
查看>>
Linux查找find命令详解
查看>>
客户案例—北京优络时代科技有限公司
查看>>
runc 1.0-rc7 发布之际
查看>>
AutoNet-ios (ios 强大好用的网络框架, 加入了新的拦截器概念)
查看>>
微信小程序 wx.request 的封装
查看>>
js学习总结
查看>>
iOS开发 iOS9 Spotlight 应用内搜索简单介绍
查看>>
分享:你会写一个vue的双向数据绑定吗?
查看>>
微信支付(公众号支付JSAPI)
查看>>
2017-12-24学习笔记
查看>>
linux 安装 node
查看>>
智能合约从入门到精通:Lib工具库(一)
查看>>
“不劳而获”的数字货币真的存在么?
查看>>