java中DES加密解密

 更新时间:2015年03月12日 14:27:24   投稿:hebedich  
本文给大家分享的是一段java中实现des加密解密的代码,非常的实用,基本每个项目都可以用到,推荐给大家。

废话不多说,直接奉上代码:

代码一

package com.eabax.plugin.yundada.utils;
import java.io.IOException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.security.spec.InvalidKeySpecException;
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import org.apache.commons.codec.binary.Base64;
import sun.misc.BASE64Decoder;
public class DESEncryptHelper {
  private final static String DES = "DES";
  /**
   * 生成密钥
   * @param employeeCode
   */
  public static String getDESKey(String encryptStr){
    if (!CacheManager.getCache().containsKey("encryptKey_"+encryptStr)) {
      CacheManager.getCache().put("encryptKey_"+encryptStr, encryptStr+"tablemiyaokey");
    }
    String key = (String) CacheManager.getCache().get("encryptKey_"+encryptStr);
    return key;
  }
   /**
   * Description 根据键值进行解密
   * @param data
   * @param key 加密键byte数组
   * @return
   * @throws IOException
   * @throws Exception
   */
  public static String decrypt(String data, String key) throws IOException,
      Exception {
    if (data == null)
      return null;
    BASE64Decoder decoder = new BASE64Decoder();
    byte[] buf = decoder.decodeBuffer(data);
    byte[] bt = decrypt(buf,key.getBytes());
    return new String(bt);
  }
  /**
   * 对字符串加密 
   * @param str
   * @return
   * @throws InvalidKeyException
   * @throws IllegalBlockSizeException
   * @throws BadPaddingException
   * @throws InvalidKeySpecException
   * @throws NoSuchAlgorithmException
   * @throws NoSuchPaddingException
   */
  public static String getEncryptStr(String str,String encryptStr) throws InvalidKeyException,
      IllegalBlockSizeException, BadPaddingException,
      InvalidKeySpecException, NoSuchAlgorithmException,
      NoSuchPaddingException {
    //获取key
    String key = getDESKey(encryptStr);
    //获取密钥
    SecretKeyFactory factory = SecretKeyFactory.getInstance("DES");
    DESKeySpec keyspec = new DESKeySpec(key.getBytes());
    SecretKey deskey = factory.generateSecret(keyspec);
    // Cipher负责完成加密或解密工作
    Cipher c = Cipher.getInstance("DES");
    // 根据密钥,对Cipher对象进行初始化,DECRYPT_MODE表示加密模式 
    c.init(Cipher.ENCRYPT_MODE, deskey);
    byte[] src = str.getBytes();
    // 该字节数组负责保存加密的结果
    byte[] cipherByte = c.doFinal(src);
    String enstr = new String(Base64.encodeBase64(cipherByte));
    return enstr;
  }
   /**
   * Description 根据键值进行解密
   * @param data
   * @param key 加密键byte数组
   * @return
   * @throws Exception
   */
  private static byte[] decrypt(byte[] data, byte[] key) throws Exception {
    // 生成一个可信任的随机数源
    SecureRandom sr = new SecureRandom();
    // 从原始密钥数据创建DESKeySpec对象
    DESKeySpec dks = new DESKeySpec(key);
    // 创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
    SecretKey securekey = keyFactory.generateSecret(dks);
    // Cipher对象实际完成解密操作
    Cipher cipher = Cipher.getInstance(DES);
    // 用密钥初始化Cipher对象
    cipher.init(Cipher.DECRYPT_MODE, securekey, sr);
    return cipher.doFinal(data);
  }
}

代码二

package com.sinosoft.olyvem.common;

import java.security.SecureRandom;

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;

import sun.misc.BASE64Encoder;

public class DES ...{
  private byte[] desKey;

  public DES(byte[] desKey) ...{
    this.desKey = desKey;
  }

  public byte[] doEncrypt(byte[] plainText) throws Exception ...{
    // DES算法要求有一个可信任的随机数源
    SecureRandom sr = new SecureRandom();
    byte rawKeyData[] = desKey;/**//* 用某种方法获得密匙数据 */
    // 从原始密匙数据创建DESKeySpec对象
    DESKeySpec dks = new DESKeySpec(rawKeyData);
    // 创建一个密匙工厂,然后用它把DESKeySpec转换成
    // 一个SecretKey对象
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
    SecretKey key = keyFactory.generateSecret(dks);
    // Cipher对象实际完成加密操作
    Cipher cipher = Cipher.getInstance("DES");
    // 用密匙初始化Cipher对象
    cipher.init(Cipher.ENCRYPT_MODE, key, sr);
    // 现在,获取数据并加密
    byte data[] = plainText;/**//* 用某种方法获取数据 */
    // 正式执行加密操作
    byte encryptedData[] = cipher.doFinal(data);
    return encryptedData;
  }

  public byte[] doDecrypt(byte[] encryptText) throws Exception ...{
    // DES算法要求有一个可信任的随机数源
    SecureRandom sr = new SecureRandom();
    byte rawKeyData[] = desKey; /**//* 用某种方法获取原始密匙数据 */
    // 从原始密匙数据创建一个DESKeySpec对象
    DESKeySpec dks = new DESKeySpec(rawKeyData);
    // 创建一个密匙工厂,然后用它把DESKeySpec对象转换成
    // 一个SecretKey对象
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
    SecretKey key = keyFactory.generateSecret(dks);
    // Cipher对象实际完成解密操作
    Cipher cipher = Cipher.getInstance("DES");
    // 用密匙初始化Cipher对象
    cipher.init(Cipher.DECRYPT_MODE, key, sr);
    // 现在,获取数据并解密
    byte encryptedData[] = encryptText;/**//* 获得经过加密的数据 */
    // 正式执行解密操作
    byte decryptedData[] = cipher.doFinal(encryptedData);
    return decryptedData;
  }

  public static void main(String[] args) throws Exception ...{
    String key = "FtpXPass";
    String value = "olympic";
    BASE64Encoder base64Encoder = new BASE64Encoder();

    DES desEncrypt = new DES(key.getBytes());
    byte[] encryptText = desEncrypt.doEncrypt(value.getBytes());
    //System.out.println("doEncrypt  -  " + toHexString(encryptText));
    System.out.println("doEncrypt  -  "
        + base64Encoder.encode(encryptText));
    byte[] decryptText = desEncrypt.doDecrypt("r9NGYcKAtdo=".getBytes());
    System.out.println("doDecrypt  -  " + new String(decryptText));
    //System.out.println("doDecrypt  -  " + toHexString(decryptText));

  }

  public static String toHexString(byte[] value) ...{
    String newString = "";
    for (int i = 0; i < value.length; i++) ...{
      byte b = value[i];
      String str = Integer.toHexString(b);
      if (str.length() > 2) ...{
        str = str.substring(str.length() - 2);
      }
      if (str.length() < 2) ...{
        str = "0" + str;
      }
      newString += str;
    }
    return newString.toUpperCase();
  }

}

以上就是本文关于DES加密解密的代码了,希望对大家学习java有所帮助。

相关文章

  • 详解java一维数组及练习题实例

    详解java一维数组及练习题实例

    在本篇文章里小编给大家整理了关于java一维数组及练习题的相关知识点和实例代码,有需要的朋友们跟着学习下。
    2019-07-07
  • 在ssm中使用ModelAndView跳转页面失效的解决

    在ssm中使用ModelAndView跳转页面失效的解决

    这篇文章主要介绍了在ssm中使用ModelAndView跳转页面失效的解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • Java基础篇之List集合举例详解

    Java基础篇之List集合举例详解

    Java中的List集合是一种常用的数据结构,它提供了一种有序、可重复的元素集合,下面这篇文章主要给大家介绍了关于Java基础篇之List集合的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • Springboot中的三个基本架构

    Springboot中的三个基本架构

    这篇文章主要介绍了Springboot中的三个基本架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • 使用@Order控制配置类/AOP/方法/字段的加载顺序详解

    使用@Order控制配置类/AOP/方法/字段的加载顺序详解

    这篇文章主要介绍了使用@Order控制配置类/AOP/方法/字段的加载顺序详解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • IDEA在创建包时如何把包分开实现自动分层(方法详解)

    IDEA在创建包时如何把包分开实现自动分层(方法详解)

    这篇文章主要介绍了IDEA在创建包时如何把包分开实现自动分层,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • 利用java制作一个小的目录查询器的方法

    利用java制作一个小的目录查询器的方法

    下面小编就为大家带来一篇利用java制作一个小的目录查询器的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • 浅谈FileItem类的常用方法

    浅谈FileItem类的常用方法

    下面小编就为大家带来一篇浅谈FileItem类的常用方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • Spring注解驱动之AOP功能测试

    Spring注解驱动之AOP功能测试

    这篇文章主要介绍了Spring注解驱动之AOP功能测试,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • 详解Java中类的加载与其初始化

    详解Java中类的加载与其初始化

    这篇文章主要为大家详细介绍了Java中类的加载与其初始化的相关资料,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以了解一下
    2022-12-12

最新评论