2012-12-01 86 views
2

我有這些信息:AES解密在CTR模式(Java)的

CTR鍵:36f18357be​​4dbd77f050515c73fcf9f2

CTR密文1:69dda8455c7dd4254bf353b773304eec0ec7702330098ce7f7520d1cbbb20fc3 \ 88d1b0adb5054dbd7370849dbf0b88d393f252e764f1f5f7ad97ef79d59ce29f5f51eeca32eabedd9afa9329

注意,16字節的加密IV被選擇是隨機的並且被預置爲密文。文本在CTR模式下用AES加密。

我發現明文 爲此,我寫了一個簡短的Java程序,但它不工作,我沒有找到原因:/

這是Java程序

import java.nio.charset.Charset; 
import javax.crypto.Cipher; 
import javax.crypto.KeyGenerator; 
import javax.crypto.spec.IvParameterSpec; 
import javax.crypto.spec.SecretKeySpec; 

public class AES { 

/** 
* @param args 
*/ 
public static void main(String[] args) throws Exception { 
    // TODO Auto-generated method stub 

    //Dernier exemple CTR mode 
    //Clé 16 bits 
    byte[] keyBytes = new byte[] { (byte)0x36,(byte)0xf1,(byte)0x83,(byte)0x57,(byte)0xbe,(byte)0x4d,(byte)0xbd,(byte)0x77,(byte)0xf0,(byte)0x50,(byte)0x51,(byte)0x5c,0x73,(byte)0xfc,(byte)0xf9,(byte)0xf2}; 
    //IV 16 bits (préfixe du cipherText) 
    byte[] ivBytes = new byte[] {(byte)0x69,(byte)0xdd,(byte)0xa8,(byte)0x45,(byte)0x5c,(byte)0x7d,(byte)0xd4,(byte)0x25,(byte)0x4b,(byte)0xf3,(byte)0x53,(byte)0xb7,(byte)0x73,(byte)0x30,(byte)0x4e,(byte)0xec}; 

    //Initialisation 
    SecretKeySpec key = new SecretKeySpec(keyBytes, "AES"); 
    IvParameterSpec ivSpec = new IvParameterSpec(ivBytes); 

    //Mode 
    Cipher cipher = Cipher.getInstance("AES/CTR/NoPadding"); 

    byte[] cipherText = new byte[] {(byte)0x0e,(byte)0xc,(byte)0x77,(byte)0x02,(byte)0x33,(byte)0x00,(byte)0x98,(byte)0xce,(byte)0x7f,(byte)0x75,(byte)0x20,(byte)0xd1,(byte)0xcb,(byte)0xbb,(byte)0x20,(byte)0xfc,(byte)0x38,(byte)0x8d,(byte)0x1b,(byte)0x0a,(byte)0xdb,(byte)0x50,(byte)0x54,(byte)0xdb,(byte)0xd7,(byte)0x37,(byte)0x08,(byte)0x49,(byte)0xdb,(byte)0xf0,(byte)0xb8,(byte)0x8d,(byte)0x39,(byte)0x3f,(byte)0x25,(byte)0x2e,(byte)0x76,(byte)0x4f,(byte)0x1f,(byte)0x5f,(byte)0x7a,(byte)0xd9,(byte)0x7e,(byte)0xf7,(byte)0x9d,(byte)0x59,(byte)0xce,(byte)0x29,(byte)0xf5,(byte)0xf5,(byte)0x1e,(byte)0xec,(byte)0xa3,(byte)0x2e,(byte)0xab,(byte)0xed,(byte)0xd9,(byte)0xaf,(byte)0xa9,(byte)0x32,(byte)0x29}; 
    cipher.init(Cipher.DECRYPT_MODE, key, ivSpec); 
    byte [] original = cipher.doFinal(cipherText); 
    String plaintext = new String(original); 
    System.out.println("plaintext: " + plaintext); 
} 

}

結果是=>明文:CŸUnfpL¨KH¹)VPA | EO9}FÅgÿžQ3Š®¹zÛ~±<þãh¤ÔÆË「M±§| @ +0H5§ 所以它似乎是錯誤的

預先感謝您:)

+0

密文和純文本由字節組成,而不是字符。因此,在直接翻譯*系統字符集之後,您可能無法獲得可打印的內容。確保你爲'String'構造函數使用了正確的字符集。 –

回答

7

可能有其他的問題,但在你的問題的密文,16個第一字節後,與0ec770開始,而在Java代碼中的密文與

開始
0x0e, 0xc, 0x77 

它們不匹配。

+0

何感謝JB Nizet,這是一個愚蠢的錯誤... – Joe