求采用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");
      }
      } 图片说明

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

 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);
}
}

密码一定是8的位数吗?可是需求给的是4个字母,而网站上4个字母页可以加密啊 难道做特殊处理了