多平台统一管理软件接口,如何实现多平台统一管理软件接口
337
2023-04-23
java中以DES的方式实现对称加密并提供密钥的实例
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;
impohttp://rt javax.xml.bind.annotation.adapters.HexBinaryIPAcVoHLWEAdapter;
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实现对称加密的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~