Java加密解密之对称加密算法DES.docxVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Java 加密解密之对称加密算法DES 本文转自网络 数据加密算法(Data Encryption Algorithm,DEA)是一种对称加密算法,很可能是使用最广泛的密钥系统,特别是在保护金融数据的安全中,最初开发的DEA是嵌入硬件中的。通常,自动取款机(Automated Teller Machine,ATM)都使用DEA。它出自IBM的研究工作,IBM也曾对它拥有几年的专利权,但是在1983年已到期后,处于公有范围中,允许在特定条件下可以免除专利使用费而使用。1977年被美国政府正式采纳。 ? 1998年后实用化DES破译机的出现彻底宣告DES算法已不具备安全性,1999年NIST颁布新标准,规定DES算法只能用于遗留加密系统,但不限制使用DESede算法。当今DES算法正是推出历史舞台,AES算法称为他的替代者。(详见:? HYPERLINK /admin/blogs/1133494 \t _blank Java 加密解密之对称加密算法AES?) ? 加密原理 DES 使用一个 56 位的密钥以及附加的 8 位奇偶校验位,产生最大 64 位的分组大小。这是一个迭代的分组密码,使用称为 Feistel 的技术,其中将加密的文本块分成两半。使用子密钥对其中一半应用循环功能,然后将输出与另一半进行“异或”运算;接着交换这两半,这一过程会继续下去,但最后一个循环不交换。DES 使用 16 个循环,使用异或,置换,代换,移位操作四种基本运算。 ? JDK对DES算法的支持 密钥长度:56位? 工作模式:ECB/CBC/PCBC/CTR/CTS/CFB/CFB8 to CFB128/OFB/OBF8 to OFB128 填充方式:Nopadding/PKCS5Padding/ISO10126Padding/ ? 工作模式和填充方式请参考:??? ?? HYPERLINK /blog/1129339 \t _blank JAVA加密解密基础 十六进制工具类Hex.java,见:??? HYPERLINK /blog/1129228 \t _blank java byte数组与十六进制字符串互转 DES加密解密的java实现:? DESCoder.java Java代码?? import?java.security.Key;?? ?? import?javax.crypto.Cipher;?? import?javax.crypto.KeyGenerator;?? import?javax.crypto.SecretKey;?? import?javax.crypto.SecretKeyFactory;?? import?javax.crypto.spec.DESKeySpec;?? ?? /**? ?*?DES?Coderbr/? ?*?secret?key?length:???56?bit,?default:????56?bitbr/? ?*?mode:????ECB/CBC/PCBC/CTR/CTS/CFB/CFB8?to?CFB128/OFB/OBF8?to?OFB128br/? ?*?padding:?Nopadding/PKCS5Padding/ISO10126Padding/? ?*?@author?Aub? ?*?? ?*/?? public?class?DESCoder?{?? ?????? ????/**? ?????*?密钥算法? ????*/?? ????private?static?final?String?KEY_ALGORITHM?=?DES;?? ?????? ????private?static?final?String?DEFAULT_CIPHER_ALGORITHM?=?DES/ECB/PKCS5Padding;?? //??private?static?final?String?DEFAULT_CIPHER_ALGORITHM?=?DES/ECB/ISO10126Padding;?? ?????? ?????? ????/**? ?????*?初始化密钥? ?????*?? ?????*?@return?byte[]?密钥?? ?????*?@throws?Exception? ?????*/?? ????public?static?byte[]?initSecretKey()?throws?Exception{?? ????????//返回生成指定算法的秘密密钥的?KeyGenerator?对象?? ????????KeyGenerator?kg?=?KeyGenerator.getInstance(KEY_ALGORITHM);?? ????????//初始化此密钥生

文档评论(0)

185****7617 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档