java中以DES的方式实现对称加密并提供密钥的实例
短信预约 -IT技能 免费直播动态提醒
java中以DES的方式实现对称加密并提供密钥的实例
加密原理
DES 使用一个 56 位的密钥以及附加的 8 位奇偶校验位,产生最大 64 位的分组大小。这是一个迭代的分组密码,使用称为 Feistel 的技术,其中将加密的文本块分成两半。使用子密钥对其中一半应用循环功能,然后将输出与另一半进行“异或”运算;接着交换这两半,这一过程会继续下去,但最后一个循环不交换。DES 使用 16 个循环,使用异或,置换,代换,移位操作四种基本运算。
注释都在代码里了,干了:
import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import javax.crypto.spec.SecretKeySpec; import javax.xml.bind.annotation.adapters.HexBinaryAdapter; import org.apache.commons.codec.binary.Hex; public class Main { static String class="lazy" data-src = "Hello,sahadev!"; public static void main(String[] args) { DES(); } public static void DES() { try { // 以DES的方式初始化Key生成器 KeyGenerator keyGenerator = KeyGenerator.getInstance("DES"); keyGenerator.init(56);// 设置密钥的长度为56位 // 生成一个Key SecretKey generateKey = keyGenerator.generateKey(); // 转变为字节数组 byte[] encoded = generateKey.getEncoded(); // 生成密钥字符串 String encodeHexString = Hex.encodeHexString(encoded); System.out.println("Key : " + encodeHexString); // 再把我们的字符串转变为字节数组,可以用于另一方使用,验证 byte[] decodeHex = Hex.decodeHex(encodeHexString.toCharArray()); // 生成密钥对象 SecretKeySpec secretKeySpec = new SecretKeySpec(decodeHex, "DES"); // 获取加解密实例 Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding"); // 初始化加密模式 cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec); // 加密 byte[] doFinal = cipher.doFinal(class="lazy" data-src.getBytes()); System.out.println("加密结果 : " + new HexBinaryAdapter().marshal(doFinal)); // 初始化解密模式 cipher.init(Cipher.DECRYPT_MODE, secretKeySpec); // 解密 byte[] doFinal2 = cipher.doFinal(doFinal); // 输出解密结果 System.out.println("解密结果 : " + new String(doFinal2)); } catch (Exception e) { e.printStackTrace(); } } }
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
java中以DES的方式实现对称加密并提供密钥的实例
下载Word文档到电脑,方便收藏和打印~
下载Word文档
猜你喜欢
java中以DES的方式实现对称加密并提供密钥的实例
java中以DES的方式实现对称加密并提供密钥的实例加密原理DES 使用一个 56 位的密钥以及附加的 8 位奇偶校验位,产生最大 64 位的分组大小。这是一个迭代的分组密码,使用称为 Feistel 的技术,其中将加密的文本块分成两半。使
2023-05-31
Java实现对称加密DES和AES的示例代码
这篇文章主要介绍了如何使用Java实现采用对称密码算法的应用软件,所用算法包括DES算法和AES算法,文中的示例代码讲解详细,感兴趣的可以了解一下
2023-05-14
java 中的非对称加密怎么利用DH方式实现
本篇文章为大家展示了java 中的非对称加密怎么利用DH方式实现,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。实现代码:package com.sahadev; import java.secur
2023-05-31
java项目中的非对称加密怎么利用RSA方式实现
java项目中的非对称加密怎么利用RSA方式实现?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。java 中RSA的方式实现非对称加密的实例RSA通俗理解:你只要
2023-05-31
2024-04-02
Java实现支付对接常用加密方式的示例代码
这篇文章主要为大家详细介绍了Java如何实现支付对接时常用加密方式,文中的示例代码讲解详细,对我们学习Java有一点帮助,需要的可以参考一下
2023-02-09