- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Java 加密解密对称加密算法DES
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);??
????????//初始化此密钥生成
您可能关注的文档
最近下载
- 黄芪商品规格等级标准.doc VIP
- 光伏项目地质灾害危险性评估报告(内审稿).docx
- 基于毫米波的工业5G创新应用白皮书(2024)v2.1.pdf VIP
- 工程有限公司叉车安全风险分级管控清单.docx VIP
- 配送人员组织架构及分工职责描述.docx VIP
- T∕CACM 1021.6-2018 中药材商品规格等级 甘草.docx VIP
- DBJ61_T 186-2021 二次供水工程技术规程.pdf
- (2025秋新版)人教版三年级数学上册《第三单元 毫米、分米和千米》PPT课件.pptx
- 注册会计师财务成本管理《本量利分析微信做题》模拟练习卷.doc VIP
- 呼吸系统感染的防控和护理要点PPT.pptx VIP
文档评论(0)