当前位置: 移动技术网 > IT编程>开发语言>Java > Java实现DES加解密算法解析

Java实现DES加解密算法解析

2019年07月22日  | 移动技术网IT编程  | 我要评论

本文实例讲述了java实现des加解密算法解析。分享给大家供大家参考,具体如下:
 

简介:

数据加密算法(data encryption algorithm,dea)是一种对称加密算法,很可能是使用最广泛的密钥系统,特别是在保护金融数据的安全中,最初开发的dea是嵌入硬件中的。通常,自动取款机(automated teller machine,atm)都使用dea。它出自ibm的研究工作,ibm也曾对它拥有几年的专利权,但是在1983年已到期后,处于公有范围中,允许在特定条件下可以免除专利使用费而使用。1977年被美国政府正式采纳。

1998年后实用化des破译机的出现彻底宣告des算法已不具备安全性,1999年nist颁布新标准,规定des算法只能用于遗留加密系统,但不限制使用desede算法。当今des算法正是推出历史舞台,aes算法称为他的替代者。

加密原理:

des 使用一个 56 位的密钥以及附加的 8 位奇偶校验位,产生最大 64 位的分组大小。这是一个迭代的分组密码,使用称为 feistel 的技术,其中将加密的文本块分成两半。使用子密钥对其中一半应用循环功能,然后将输出与另一半进行“异或”运算;接着交换这两半,这一过程会继续下去,但 最后一个循环不交换。des 使用 16 个循环,使用异或,置换,代换,移位操作四种基本运算。

jdk对des算法的支持

密钥长度:56位

工作模式:ecb/cbc/pcbc/ctr/cts/cfb/cfb8 to cfb128/ofb/obf8 to ofb128

填充方式:nopadding/pkcs5padding/iso10126padding/

java 加密解密之对称加密算法desede

desede 即三重des加密算法,也被称为3des或者triple des。使用三(或两)个不同的密钥对数据块进行三次(或两次)des加密(加密一次要比进行普通加密的三次要快)。三重des的强度大约和112- bit的密钥强度相当。通过迭代次数的提高了安全性,但同时也造成了加密效率低的问题。正因desede算法效率问题,aes算法诞生了。

到目前为止,还没有人给出攻击三重des的有效方法。对其密钥空间中密钥进行蛮干搜索,那么由于空间太大,这实际上是不可行的。若用差分攻击的方法,相对于单一des来说复杂性以指数形式增长。

三重des有四种模型

  • des-eee3,使用三个不同密钥,顺序进行三次加密变换。
  • des-ede3,使用三个不同密钥,依次进行加密-解密-加密变换。
  • des-eee2,其中密钥k1=k3,顺序进行三次加密变换。
  • des-ede2, 其中密钥k1=k3,依次进行加密-解密-加密变换。

java对des算法的加密代码

package com.favccxx.codelib;
import java.security.securerandom;
import javax.crypto.cipher;
import javax.crypto.secretkey;
import javax.crypto.secretkeyfactory;
import javax.crypto.spec.deskeyspec;
public class encryptcoder {
           
  private final static string des = "des";
           
  public static byte[] encrypt(byte[] src, byte[] key) throws exception {
    // des算法要求有一个可信任的随机数源
    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.encrypt_mode, securekey, sr);
    // 正式执行加密操作
    return cipher.dofinal(src);
  }
           
  /**
   *
   * @param password 密码
   * @param key 加密字符串
   * @return
   */
  public final static string encrypt(string password, string key) {
    try {
      return byte2string(encrypt(password.getbytes(), key.getbytes()));
    } catch (exception e) {
    }
    return null;
  }
           
  public static string byte2string(byte[] b) {
    string hs = "";
    string stmp = "";
    for (int n = 0; n < b.length; n++) {
      stmp = (java.lang.integer.tohexstring(b[n] & 0xff));
      if (stmp.length() == 1)
        hs = hs + "0" + stmp;
      else
        hs = hs + stmp;
    }
    return hs.touppercase();
  }           
  public static void main(string[] args){
    string encryptstring = encrypt("is张三丰","test中英文杂七烂八混搭@123654{");
    system.out.println(encryptstring);
  }          
  //输出:b00542e93695f4cfce34fc4393c2f4bf          
}

java对des解密算法的实现

package com.favccxx.codelib;
import java.security.securerandom;
import javax.crypto.cipher;
import javax.crypto.secretkey;
import javax.crypto.secretkeyfactory;
import javax.crypto.spec.deskeyspec;
public class descryptcoder {
     
  private final static string des = "des";
     
  /**
   *
   * @param src 数据源
   * @param key 密钥,长度必须是8的倍数
   * @return
   * @throws exception
   */
  public static byte[] decrypt(byte[] src, byte[] key) throws exception {
    // des算法要求有一个可信任的随机数源
    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(src);
  }
     
  public final static string decrypt(string data, string key) {
    try {
      return new string(decrypt(string2byte(data.getbytes()), key.getbytes()));
    } catch (exception e) {
      e.printstacktrace();
    }
    return null;
  }
     
  public static byte[] string2byte(byte[] b) {
    if ((b.length % 2) != 0)
      throw new illegalargumentexception("长度不是偶数");
    byte[] b2 = new byte[b.length / 2];
    for (int n = 0; n < b.length; n += 2) {
      string item = new string(b, n, 2);
      b2[n / 2] = (byte) integer.parseint(item, 16);
    }
    return b2;
  }
     
  public static void main(string[] args){
    string desencryptstring = decrypt("b00542e93695f4cfce34fc4393c2f4bf","test中英文杂七烂八混搭@123654");
    system.out.println(desencryptstring);
  }
     
  //输出:is张三丰
}

希望本文所述对你有所帮助,java实现des加解密算法解析内容就给大家介绍到这里了。希望大家继续关注我们的网站!想要学习java可以继续关注本站。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网