久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

AES 錯誤:給定的最終塊未正確填充

AES Error: Given final block not properly padded(AES 錯誤:給定的最終塊未正確填充)
本文介紹了AES 錯誤:給定的最終塊未正確填充的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我需要有關此錯誤的幫助:給定最終塊未正確填充.從標題可以看出,我正在使用 AES.

I need help with this error: Given final block not properly padded. As you can see from the title, I am working with AES.

這是錯誤所在行的代碼:

Here is the code of line where is error:

 byte[] decrypted = cipher.doFinal(bytes);

這里是完整的代碼:

public class AESCrypt {
private final Cipher cipher;
private final SecretKeySpec key;
private String encryptedText, decryptedText;

public AESCrypt(String password) throws Exception {
    // hash password with SHA-256 and crop the output to 128-bit for key
    MessageDigest digest = MessageDigest.getInstance("SHA-256");
    digest.update(password.getBytes("UTF-8"));
    byte[] keyBytes = new byte[16];
    System.arraycopy(digest.digest(), 0, keyBytes, 0, keyBytes.length);

    cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
    key = new SecretKeySpec(keyBytes, "AES");
}

public String encrypt(String plainText) throws Exception {
    byte[] iv = new byte[cipher.getBlockSize()];
    new SecureRandom().nextBytes(iv);
    AlgorithmParameterSpec spec = new IvParameterSpec(iv);
    cipher.init(Cipher.ENCRYPT_MODE, key, spec);
    byte[] encrypted = cipher.doFinal(plainText.getBytes());
    encryptedText = asHex(encrypted);
    return encryptedText;
}

public String decrypt(String cryptedText) throws Exception {
    byte[] iv = new byte[cipher.getBlockSize()];
    AlgorithmParameterSpec spec = new IvParameterSpec(iv);
    cipher.init(Cipher.DECRYPT_MODE, key, spec);
    // decrypt the message
    byte[] bytes = cryptedText.getBytes("UTF-8");
    byte[] decrypted = cipher.doFinal(bytes);
    decryptedText = asHex(decrypted);
    System.out.println("Desifrovani tekst: " + decryptedText + "
");

    return decryptedText;
}

public static String asHex(byte buf[]) {
    StringBuilder strbuf = new StringBuilder(buf.length * 2);
    int i;
    for (i = 0; i < buf.length; i++) {
        if (((int) buf[i] & 0xff) < 0x10) {
            strbuf.append("0");
        }
        strbuf.append(Long.toString((int) buf[i] & 0xff, 16));
    }
    return strbuf.toString();
}

public static void main(String[] args) throws Exception {

    System.out.print("....AES....
");

    String message = "MESSAGE";
    String password = "PASSWORD";

    System.out.println("MSG:" + message);

    AESCrypt aes = new AESCrypt(password);
    String encryptedText = aes.encrypt(message).toString();
    System.out.println("SIFROVANA PORUKA: " + encryptedText);
    String decryptedText = aes.decrypt(encryptedText).toString();       
    System.out.print("DESIFROVANA PORUKA: " + decryptedText);
}

}

推薦答案

根據您的評論,您已經非常接近讓加密貨幣工作了.

Per your comment, you are pretty close to getting the crypto working.

您需要將 IV 生成代碼從您的加密/解密方法移到其他地方,就像這樣

You need to move the IV generation code from your encryption/decryption methods to somewhere else, like so

public AlgorithmParameterSpec getIV() {
AlgorithmParameterSpec ivspec;
byte[] iv = new byte[cipher.getBlockSize()];
new SecureRandom().nextBytes(iv);
ivspec = new IvParameterSpec(iv);
}

然后將該 ivspec 傳遞給加密和解密方法(使它們看起來像 encrypt(String,AlgorithmParameterSpec)),以便加密和解密具有相同的 iv.

then pass that ivspec into both the encrypt and decrypt methods (making them look like encrypt(String,AlgorithmParameterSpec)), so that you have the same iv for both encryption and decryption.

另外,不要在decryptedByteArray上調用printBase64Binary,而是調用new String(decryptedByteArray, "UTF-8")

Also, don't call printBase64Binary on the decryptedByteArray, instead call new String(decryptedByteArray, "UTF-8")

這篇關于AES 錯誤:給定的最終塊未正確填充的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

Java Remove Duplicates from an Array?(Java從數組中刪除重復項?)
How to fix Invocation failed Unexpected Response from Server: Unauthorized in Android studio(如何修復調用失敗來自服務器的意外響應:在 Android 工作室中未經授權)
AES encryption, got extra trash characters in decrypted file(AES 加密,解密文件中有多余的垃圾字符)
Detecting incorrect key using AES/GCM in JAVA(在 JAVA 中使用 AES/GCM 檢測不正確的密鑰)
AES-256-CBC in Java(Java 中的 AES-256-CBC)
Using BouncyCastle to encrypt with ECIES in Java(在 Java 中使用 BouncyCastle 使用 ECIES 進行加密)
主站蜘蛛池模板: 成人免费日韩 | 色综合99 | 日日日干干干 | 国产极品粉嫩美女呻吟在线看人 | 欧美日一区二区 | 久久国产精品99久久久久 | 九九热精品免费 | 精品九九 | 久热国产精品视频 | 91视频在线 | 精品一区二区三区免费视频 | 国产精品久久久乱弄 | 免费在线观看成人 | 一区二区三区不卡视频 | 成年网站在线观看 | 三级黄视频在线观看 | 日韩欧美久久精品 | 99视频免费 | 欧美国产日韩在线观看 | 久久99精品久久久久久国产越南 | 国产美女永久免费无遮挡 | 免费观看一级特黄欧美大片 | 欧美精品一区三区 | 综合久久久久 | 欧美日韩福利视频 | 日日骚视频 | 国产成人精品免费视频大全最热 | 九九福利| 台湾a级理论片在线观看 | 三级高清| 久久久av | 日韩欧美在线免费观看视频 | www..99re| 北条麻妃av一区二区三区 | 在线播放国产一区二区三区 | 在线一区视频 | 国产精品美女www爽爽爽 | 久久视频免费观看 | 国产精品区一区二区三 | 精品久久久久久亚洲精品 | 999www视频免费观看 |