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 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(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(); } } }
附上输出结果:
Key : 619b862f5e2aad40 加密结果 : D98FA80E83593710C0686370665C2FEC 解密结果 : Hello,sahadev!
以上就是java DES实现对称加密的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
本文向大家介绍java 实现DES 加密解密的示例,包括了java 实现DES 加密解密的示例的使用技巧和注意事项,需要的朋友参考一下 以上就是java 实现DES 加密解密的示例代码的详细内容,更多关于java des加密解密的资料请关注呐喊教程其它相关文章!
本文向大家介绍java 中DH的方式实现非对称加密的实例,包括了java 中DH的方式实现非对称加密的实例的使用技巧和注意事项,需要的朋友参考一下 java 中DH的方式实现非对称加密的实例 实现代码: 附上结果: 以上就是DH实现非对称加密的实例,如有 疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
本文向大家介绍java 中RSA的方式实现非对称加密的实例,包括了java 中RSA的方式实现非对称加密的实例的使用技巧和注意事项,需要的朋友参考一下 java 中RSA的方式实现非对称加密的实例 RSA通俗理解: 你只要去想:既然是加密,那肯定是不希望别人知道我的消息,所以只有我才能解密,所以可得出公钥负责加密,私钥负责解密;同理,既然是签名,那肯定是不希望有人冒充我发消息,只有我才能发布这个签
本文向大家介绍Java对称加密算法DES实例详解,包括了Java对称加密算法DES实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Java对称加密算法DES。分享给大家供大家参考,具体如下: 一 DES算法概述 1、介绍 DES:Data Encryption Standard 数据加密标准。 2、DES算法参数 二 DES算法Java实现 三 实现效果 jdk des encry
本文向大家介绍java基于Des对称加密算法实现的加密与解密功能详解,包括了java基于Des对称加密算法实现的加密与解密功能详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了java基于Des对称加密算法实现的加密与解密功能。分享给大家供大家参考,具体如下: Des 加密相关类介绍: SecureRandom 这个类是继承自java.util.Random 这个类 SecureRan
本文向大家介绍详解Java利用实现对称加密(DES、3DES、AES),包括了详解Java利用实现对称加密(DES、3DES、AES)的使用技巧和注意事项,需要的朋友参考一下 有两句话是这么说的: 1)算法和数据结构就是编程的一个重要部分,你若失掉了算法和数据结构,你就把一切都失掉了。 2)编程就是算法和数据结构,算法和数据结构是编程的灵魂。 注意,这可不是我说的,是无数程序员总结的,话说的很实在