java写的des加密解密

阅读更多

首先说一下什么是DES加密

DES算法为密码体制中的对称密码体制,又被成为美国数据加密标准,是1972年美国IBM公司研制的对称密码体制加密算法。其密钥长度为56位,明文按64位进行分组,将分组后的明文组和56位的密钥按位替代或交换的方法形成密文组的加密方法。

基本原理

  入口参数有三个:key、data、mode。 key为加密解密使用的密钥,data为加密解密的数据,mode为其工作模式。当模式为加密模式时,明文按照64位进行分组,形成明文组,key用于对 数据加密,当模式为解密模式时,key用于对数据解密。实际运用中,密钥只用到了64位中的56位,这样才具有高的安全性。   DES( Data Encryption Standard)算法,于1977年得到美国政府的正式许可,是一种用56位密钥来加密64位数据的方法。虽然56位密钥的DES算法已经风光不在,而 且常有用Des加密的明文被破译的报道,但是了解一下昔日美国的标准加密算法总是有益的,而且目前DES算法得到了广泛的应用,在某些场合,仍然发挥着余 热。

package p;

import java.security.Key;
import java.security.SecureRandom;

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;

import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;

public class DES {
   
  Key key;

  public DES(String str) {
    setKey(str);//生成密匙
  }

  public DES() {
    setKey("siyue_qi");
  }

  /**
   * 根据参数生成KEY
   */
  public void setKey(String strKey) {
      try {
        KeyGenerator _generator = KeyGenerator.getInstance("DES");
        _generator.init(new SecureRandom(strKey.getBytes()));
        this.key = _generator.generateKey();
        _generator = null;
      } catch (Exception e) {
        throw new RuntimeException(
            "Error initializing SqlMap class. Cause: " + e);
      }
  }

  /**
   * 加密String明文输入,String密文输出
   */
  public String getEncString(String strMing) {
      byte[] byteMi = null;
      byte[] byteMing = null;
      String strMi = "";
      BASE64Encoder base64en = new BASE64Encoder();
      try {
        byteMing = strMing.getBytes("UTF8");
        byteMi = this.getEncCode(byteMing);
        strMi = base64en.encode(byteMi);
      } catch (Exception e) {
        throw new RuntimeException(
            "Error initializing SqlMap class. Cause: " + e);
      } finally {
        base64en = null;
        byteMing = null;
        byteMi = null;
      }
      return strMi;
  }

  /**
   * 解密 以String密文输入,String明文输出
   * @param strMi
   * @return
   */
  public String getDesString(String strMi) {
      BASE64Decoder base64De = new BASE64Decoder();
      byte[] byteMing = null;
      byte[] byteMi = null;
      String strMing = "";
      try {
        byteMi = base64De.decodeBuffer(strMi);
        byteMing = this.getDesCode(byteMi);
        strMing = new String(byteMing, "UTF8");
      } catch (Exception e) {
        throw new RuntimeException(
            "Error initializing SqlMap class. Cause: " + e);
      } finally {
        base64De = null;
        byteMing = null;
        byteMi = null;
      }
      return strMing;
  }

  /**
   * 加密以byte[]明文输入,byte[]密文输出
   * @param byteS
   * @return
   */
  private byte[] getEncCode(byte[] byteS) {
      byte[] byteFina = null;
      Cipher cipher;
      try {
        cipher = Cipher.getInstance("DES");
        cipher.init(Cipher.ENCRYPT_MODE, key);
        byteFina = cipher.doFinal(byteS);
      } catch (Exception e) {
        throw new RuntimeException(
            "Error initializing SqlMap class. Cause: " + e);
      } finally {
        cipher = null;
      }
      return byteFina;
  }

  /**
   * 解密以byte[]密文输入,以byte[]明文输出
   * @param byteD
   * @return
   */
  private byte[] getDesCode(byte[] byteD) {
      Cipher cipher;
      byte[] byteFina = null;
      try {
        cipher = Cipher.getInstance("DES");
        cipher.init(Cipher.DECRYPT_MODE, key);
        byteFina = cipher.doFinal(byteD);
      } catch (Exception e) {
        throw new RuntimeException(
            "Error initializing SqlMap class. Cause: " + e);
      } finally {
        cipher = null;
      }
      return byteFina;
  }

  public static void main(String args[]) {
      DES des = new DES();
      // 设置密钥
      //des.setKey("12345678");

      String str1 = "密文";
      //DES加密
      String str2 = des.getEncString(str1);
      String deStr = des.getDesString(str2);
      System.out.println("密文:" + str2);
      //DES解密
      System.out.println("明文:" + deStr);
  }
 

 

 

你可能感兴趣的:(Java,算法,Security,SUN,IBM)