当前位置: 移动技术网 > IT编程>开发语言>Java > java中以DES的方式实现对称加密并提供密钥的实例

java中以DES的方式实现对称加密并提供密钥的实例

2019年07月19日  | 移动技术网IT编程  | 我要评论
java中以des的方式实现对称加密并提供密钥的实例 加密原理 des 使用一个 56 位的密钥以及附加的 8 位奇偶校验位,产生最大 64 位的分组大小。这是一个

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实现对称加密的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网