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

 更新时间:2017年08月07日 09:35:08   作者:Sahadev_  
这篇文章主要介绍了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; 
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实现对称加密的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • Springboot容器级后置处理器BeanDefinitionRegistryPostProcessor

    Springboot容器级后置处理器BeanDefinitionRegistryPostProcessor

    这篇文章主要介绍了Springboot容器级后置处理器BeanDefinitionRegistryPostProcessor,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2023-01-01
  • Feign调用中的两种Header传参方式小结

    Feign调用中的两种Header传参方式小结

    这篇文章主要介绍了Feign调用中的两种Header传参方式小结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • 解决JD-GUI for mac big sur打不开问题

    解决JD-GUI for mac big sur打不开问题

    这篇文章主要介绍了解决JD-GUI for mac big sur打不开问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • JMeter参数化4种实现方式(小结)

    JMeter参数化4种实现方式(小结)

    参数化是自动化测试脚本的一种常用技巧,可将脚本中的某些输入使用参数来代替,JMeter提供了多种参数化方式,下面就其中常用的4种展开阐述,感兴趣的可以来了解一下
    2021-12-12
  • springboot整合JSR303参数校验与全局异常处理的方法

    springboot整合JSR303参数校验与全局异常处理的方法

    JSR-303 是 JAVA EE 6 中的一项子规范,叫做 Bean Validation,官方参考实现是Hibernate Validator,这篇文章主要介绍了springboot整合JSR303参数校验与全局异常处理,需要的朋友可以参考下
    2022-09-09
  • 一篇文章带你了解SpringMVC数据绑定

    一篇文章带你了解SpringMVC数据绑定

    这篇文章主要给大家介绍了关于如何通过一篇文章弄懂Spring MVC的参数绑定,文中通过示例代码以及图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2021-08-08
  • Java微信扫码登录功能并实现认证授权全过程

    Java微信扫码登录功能并实现认证授权全过程

    这篇文章主要给大家介绍了关于Java微信扫码登录功能并实现认证授权的相关资料,要在Java中实现微信扫码登录,您可以按照以下步骤进行操作,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-10-10
  • Java生成二维码可添加logo和文字功能

    Java生成二维码可添加logo和文字功能

    这篇文章主要介绍了Java生成二维码可添加logo和文字功能,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • Java开发常用类库之Hutool详解

    Java开发常用类库之Hutool详解

    这篇文章主要介绍了Java开发常用类库之Hutool,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • 深入理解Mybatis一级缓存

    深入理解Mybatis一级缓存

    客户端向数据库服务器发送同样的sql查询语句,如果每次都去访问数据库,会导致性能的降低,那么怎么提高呢?下面小编给大家分享下mybatis为我们提供了一级缓存的策略
    2016-12-12

最新评论