java中以DES的方式实现对称加密并提供密钥的实例
java中以DES的方式实现对称加密并提供密钥的实例
加密原理
DES使用一个56位的密钥以及附加的8位奇偶校验位,产生最大64位的分组大小。这是一个迭代的分组密码,使用称为Feistel的技术,其中将加密的文本块分成两半。使用子密钥对其中一半应用循环功能,然后将输出与另一半进行“异或”运算;接着交换这两半,这一过程会继续下去,但最后一个循环不交换。DES使用16个循环,使用异或,置换,代换,移位操作四种基本运算。
注释都在代码里了,干了:
importjavax.crypto.Cipher;
importjavax.crypto.KeyGenerator;
importjavax.crypto.SecretKey;
importjavax.crypto.spec.SecretKeySpec;
importjavax.xml.bind.annotation.adapters.HexBinaryAdapter;
importorg.apache.commons.codec.binary.Hex;
publicclassMain{
staticStringsrc="Hello,sahadev!";
publicstaticvoidmain(String[]args){
DES();
}
publicstaticvoidDES(){
try{
//以DES的方式初始化Key生成器
KeyGeneratorkeyGenerator=KeyGenerator.getInstance("DES");
keyGenerator.init(56);//设置密钥的长度为56位
//生成一个Key
SecretKeygenerateKey=keyGenerator.generateKey();
//转变为字节数组
byte[]encoded=generateKey.getEncoded();
//生成密钥字符串
StringencodeHexString=Hex.encodeHexString(encoded);
System.out.println("Key:"+encodeHexString);
//再把我们的字符串转变为字节数组,可以用于另一方使用,验证
byte[]decodeHex=Hex.decodeHex(encodeHexString.toCharArray());
//生成密钥对象
SecretKeySpecsecretKeySpec=newSecretKeySpec(decodeHex,"DES");
//获取加解密实例
Ciphercipher=Cipher.getInstance("DES/ECB/PKCS5Padding");
//初始化加密模式
cipher.init(Cipher.ENCRYPT_MODE,secretKeySpec);
//加密
byte[]doFinal=cipher.doFinal(src.getBytes());
System.out.println("加密结果:"+newHexBinaryAdapter().marshal(doFinal));
//初始化解密模式
cipher.init(Cipher.DECRYPT_MODE,secretKeySpec);
//解密
byte[]doFinal2=cipher.doFinal(doFinal);
//输出解密结果
System.out.println("解密结果:"+newString(doFinal2));
}catch(Exceptione){
e.printStackTrace();
}
}
}
附上输出结果:
Key:619b862f5e2aad40 加密结果:D98FA80E83593710C0686370665C2FEC 解密结果:Hello,sahadev!
以上就是javaDES实现对称加密的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!