「已注销」 2018-01-22 09:41 采纳率: 75%
浏览 1565
已结题

求采用DES对称加密算法-JAVA代码

【加密方法】:
采用DES对称加密算法,使用字符串“hnzt”生成加密的密钥
则组合的字符串为:851-2110599902&ZIQI&SONG&HKG&CN&1503560275539&24

加密后为:
af5a8b0e4680161606b7a72de89295733e05f8e4aec1866056f2850df1e2578bc6bd35f2003534e15a271a5bb03876d047cc1c5c0c2e1913

加密的JAVA代码如下,为什么会报错
package com.test;

import java.math.BigInteger;

import javax.crypto.Cipher;

import javax.crypto.SecretKey;

import javax.crypto.SecretKeyFactory;

import javax.crypto.spec.DESKeySpec;

import org.junit.Test;

/**

  • 对称加密DES算法
  • @author Administrator
  • /

    public class DESTest {

    /
    * 算法名称 /

    static final String ALGORITHM = "DES";

    /
    算法名称/加密模式/填充方式 **/

    static final String CIPHER_ALGORITHM = "DES/ECB/pkcs5Padding";

    /** 密钥,getBytes的长度必须大于等于8 **/

    // static final String SECRET_KEY = "!@#$%^&*";
    static final String SECRET_KEY = "hnzt";

    @Test
    public void test() throws Exception {

    String data = "851-2110599902&ZIQI&SONG&HKG&CN&1503560275539&24";

    //加密

    String hex = encryption(data);

    System.out.println(hex);

    System.out.println("-----------------------------------------");  
    // 解密  
    String origin = decryption(hex);  
    System.out.println(origin);  
    

    }

    /**

    • 加密,返回16进制的字符串
    • @param data
    • @return
    • @throws Exception */
      private static String encryption(String data) throws Exception{
      // 创建密钥
      DESKeySpec desKeySpec = new DESKeySpec(SECRET_KEY.getBytes("UTF-8"));
      SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);
      SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
      // 加密
      Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM);
      cipher.init(Cipher.ENCRYPT_MODE, secretKey);
      byte[] bs = cipher.doFinal(data.getBytes("UTF-8"));
      // 编码成16进制字符串
      BigInteger bi = new BigInteger(1, bs);
      return bi.toString(16); }

    /**

    • 解密
    • @param hex
    • @return
    • @throws Exception */
      private static String decryption(String hex) throws Exception {
      // 解码16进制字符串
      BigInteger bi = new BigInteger(hex, 16);
      byte[] bs = bi.toByteArray();// 该数组包含此 BigInteger 的二进制补码表示形式。
      byte[] originBs = new byte[bs.length - 1];
      byte[] target = bs;
      if (bs[0] == 0) {
      System.out.println("去补码...");
      System.arraycopy(bs, 1, originBs, 0, originBs.length); // 去掉补码
      target = originBs;
      }
      // 创建密钥
      DESKeySpec desKeySpec = new DESKeySpec(SECRET_KEY.getBytes("UTF-8"));
      SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);
      SecretKey secretKey = keyFactory.generateSecret(desKeySpec);
      // 解密
      Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM);
      cipher.init(Cipher.DECRYPT_MODE, secretKey);
      byte[] decryptionBs = cipher.doFinal(target);
      return new String(decryptionBs, "UTF-8");
      }
      } 图片说明

而网上却可以,我代码写错了吗?
图片说明

  • 写回答

2条回答 默认 最新

  • devmiao 2018-01-22 15:18
    关注
     package util;
    
    import java.security.SecureRandom;
    import javax.crypto.spec.DESKeySpec;
    import javax.crypto.SecretKeyFactory;
    import javax.crypto.SecretKey;
    import javax.crypto.Cipher;
    
    /**
    DES加密介绍
    DES是一种对称加密算法,所谓对称加密算法即:加密和解密使用相同密钥的算法。DES加密算法出自IBM的研究,
    后来被美国政府正式采用,之后开始广泛流传,但是近些年使用越来越少,因为DES使用56位密钥,以现代计算能力,
    24小时内即可被破解。虽然如此,在某些简单应用中,我们还是可以使用DES加密算法,本文简单讲解DES的JAVA实现
    。
    注意:DES加密和解密过程中,密钥长度都必须是8的倍数
    */
    public class DES {
    public DES() {
    }
    //测试
    public static void main(String args[]) {
    //待加密内容
    String str = "测试内容";
    //密码,长度要是8的倍数
    String password = "9588028820109132570743325311898426347857298773549468758875018579537757772163084478873699447306034466200616411960574122434059469100235892702736860872901247123456";
    
    byte[] result = DES.encrypt(str.getBytes(),password);
    System.out.println("加密后:"+new String(result));
    
    //直接将如上内容解密
    try {
    byte[] decryResult = DES.decrypt(result, password);
    System.out.println("解密后:"+new String(decryResult));
    } catch (Exception e1) {
    e1.printStackTrace();
    }
    
    }
    
    /**
    * 加密
    * @param datasource byte[]
    * @param password String
    * @return byte[]
    */
    public static byte[] encrypt(byte[] datasource, String password) { 
    try{
    SecureRandom random = new SecureRandom();
    DESKeySpec desKey = new DESKeySpec(password.getBytes());
    //创建一个密匙工厂,然后用它把DESKeySpec转换成
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
    SecretKey securekey = keyFactory.generateSecret(desKey);
    //Cipher对象实际完成加密操作
    Cipher cipher = Cipher.getInstance("DES");
    //用密匙初始化Cipher对象
    cipher.init(Cipher.ENCRYPT_MODE, securekey, random);
    //现在,获取数据并加密
    //正式执行加密操作
    return cipher.doFinal(datasource);
    }catch(Throwable e){
    e.printStackTrace();
    }
    return null;
    }
    /**
    * 解密
    * @param src byte[]
    * @param password String
    * @return byte[]
    * @throws Exception
    */
    public static byte[] decrypt(byte[] src, String password) throws Exception {
    // DES算法要求有一个可信任的随机数源
    SecureRandom random = new SecureRandom();
    // 创建一个DESKeySpec对象
    DESKeySpec desKey = new DESKeySpec(password.getBytes());
    // 创建一个密匙工厂
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
    // 将DESKeySpec对象转换成SecretKey对象
    SecretKey securekey = keyFactory.generateSecret(desKey);
    // Cipher对象实际完成解密操作
    Cipher cipher = Cipher.getInstance("DES");
    // 用密匙初始化Cipher对象
    cipher.init(Cipher.DECRYPT_MODE, securekey, random);
    // 真正开始解密操作
    return cipher.doFinal(src);
    }
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥50 汇编语言除法溢出问题
  • ¥65 C++实现删除N个数据列表共有的元素
  • ¥15 Visual Studio问题
  • ¥15 state显示变量是字符串形式,但是仍然红色,无法引用,并显示类型不匹配
  • ¥20 求一个html代码,有偿
  • ¥100 关于使用MATLAB中copularnd函数的问题
  • ¥20 在虚拟机的pycharm上
  • ¥15 jupyterthemes 设置完毕后没有效果
  • ¥15 matlab图像高斯低通滤波
  • ¥15 针对曲面部件的制孔路径规划,大家有什么思路吗