0

復号化または暗号化用の AES クラスを終了したところです。Windows では問題なく動作しますが、Linux では実行できず、次のようなエラーがスローされます。

最終ブロックが適切にパディングされていない場合

次のように完全なコード:

/**
 * AESTest.java
 * 
 * @author liuyincan
 * @Time 2013-12-12 下午1:25:44
 */
public class AES {


public static String generateKey(int len) {
    try {
        KeyGenerator keyGen = KeyGenerator.getInstance("AES");
        keyGen.init(len);
        Key key = keyGen.generateKey();

        return ParserStringUtils.toHexString(key.getEncoded());
    } catch (Exception e) {
        return null;
    }
}


/**
 * 加密
 * 
 * @param content
 *            待加密内容
 * @param key
 *            加密的密钥
 * @return
 */
public static String encode(String content, String key) {
    try {
        KeyGenerator kgen = KeyGenerator.getInstance("AES");
        kgen.init(128, new SecureRandom(key.getBytes()));
        SecretKey secretKey = kgen.generateKey();
        byte[] enCodeFormat = secretKey.getEncoded();
        SecretKeySpec secretKeySpec = new SecretKeySpec(enCodeFormat, "AES");
        Cipher cipher = Cipher.getInstance("AES");
        byte[] byteContent = content.getBytes("utf-8");
        cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
        byte[] byteRresult = cipher.doFinal(byteContent);
        StringBuffer sb = new StringBuffer();
        for (int i = 0; i < byteRresult.length; i++) {
            String hex = Integer.toHexString(byteRresult[i] & 0xFF);
            if (hex.length() == 1) {
                hex = '0' + hex;
            }
            sb.append(hex.toUpperCase());
        }
        return sb.toString();
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    } catch (NoSuchPaddingException e) {
        e.printStackTrace();
    } catch (InvalidKeyException e) {
        e.printStackTrace();
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    } catch (IllegalBlockSizeException e) {
        e.printStackTrace();
    } catch (BadPaddingException e) {
        e.printStackTrace();
    }
    return null;
}

/**
 * 解密
 * 
 * @param content
 *            待解密内容
 * @param key
 *            解密的密钥
 * @return
 */
public static String decode(String content, String key) {
    if (content.length() < 1)
        return null;
    byte[] byteRresult = new byte[content.length() / 2];
    for (int i = 0; i < content.length() / 2; i++) {
        int high = Integer.parseInt(content.substring(i * 2, i * 2 + 1), 16);
        int low = Integer.parseInt(content.substring(i * 2 + 1, i * 2 + 2), 16);
        byteRresult[i] = (byte) (high * 16 + low);
    }
    try {
        KeyGenerator kgen = KeyGenerator.getInstance("AES");
        kgen.init(128, new SecureRandom(key.getBytes()));
        SecretKey secretKey = kgen.generateKey();
        byte[] enCodeFormat = secretKey.getEncoded();
        SecretKeySpec secretKeySpec = new SecretKeySpec(enCodeFormat, "AES");
        Cipher cipher = Cipher.getInstance("AES");
        cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
        byte[] result = cipher.doFinal(byteRresult);
        return new String(result);
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    } catch (NoSuchPaddingException e) {
        e.printStackTrace();
    } catch (InvalidKeyException e) {
        e.printStackTrace();
    } catch (IllegalBlockSizeException e) {
        e.printStackTrace();
    } catch (BadPaddingException e) {
        e.printStackTrace();
    }
    return null;
}

問題を解決するのを手伝ってください。そうしないと、上司が私をクビにするでしょう。どうもありがとう

4

1 に答える 1

-1

Cipher.getInstance("AES");- これにより、AES のデフォルトの実装が提供されます。

Oracle Java 6 と後期 Java 7 の間のどこかで、これは に変更さAES/ECB/NoPaddingれましたAES/ECB/PKCS5Padding

そのような行を次のように変更します。

  • Cipher.getInstance("AES/ECB/PKCS5Padding");
于 2016-08-08T12:07:35.793 に答える