1

我需要使用 CBC Rijndael 加密对文本进行编码/解码。

输入: 这个 looooooooooooooooooo000000000ooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooong String

编码输入: ?†´Ú½mΗ“AŽyÝ¢ƒô]5X-å;'Bdž.̵¼èüÈíÖXÈ*©Ã¼ç–hKBµ$híƒEu-ȸU ¤'AÓÈÿ?Ÿûä¸:OW?B>ÐZ²ñ ,zÅë(C' ®5ÐixRópE%€.@vhrm6µ5©bŠ?Ç¡$q¿J^÷g“e†ì??bt ì%q'ÕQÚ5µã?ƒ

解码输入: “在这种loooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo oooooo oooooooo oooo oooo oooo oooo oooo oooo oooo oooo oooo ooooo ooooo ooooo ooooo,最高为0。

我错过了最后的字节。谁能告诉我为什么?

这是我的代码:

公共类 BouncyDecoder {

byte[] IV = null;
byte[] encryptionKey = null;
Cipher cipher;
SecretKeySpec key;
BlockCipher blockCipher;
ParametersWithIV _param;

PaddedBufferedBlockCipher mode;
int blockSize;

public BouncyDecoder() {
    Security.addProvider(new BouncyCastleProvider());
    try {
        IV = "1234567891234567891234567891234".getBytes("UTF-8");
        encryptionKey = "1234567891123453456789123456781".getBytes("UTF-8");

        blockCipher = new CBCBlockCipher(new RijndaelEngine(256));
        _param = new ParametersWithIV(new KeyParameter(encryptionKey), IV);
        mode = new PaddedBufferedBlockCipher(blockCipher);
        blockSize = blockCipher.getBlockSize();
    } catch (Exception e) {
    }
}

public byte[] decrypt(byte[] encodedText) {
    byte[] decoded = new byte[mode.getOutputSize(encodedText.length)];
    try {
        mode.init(false, _param);

        int bytesProcessed = 0;
        int i=0;
        for (i = 0; i < (encodedText.length / 32) ; i++){               
            bytesProcessed += mode.processBytes(encodedText, i * blockSize, blockSize, decoded, bytesProcessed);
        }

        mode.doFinal(decoded, (i-1)*blockSize);
    } catch (Exception e) {
    }
    return decoded;
}

public byte[] encrypt(byte[] normalText) {
    byte[] encryptedText = new byte[mode.getOutputSize(normalText.length)];
    try {
        mode.init(true, _param);

        int bytesProcessed = 0;
        int i=0;
        for (i = 0; i < (normalText.length / 32); i++) {
            bytesProcessed += mode
                    .processBytes(normalText, i * blockSize, blockSize, encryptedText, bytesProcessed);
        }

        mode.doFinal(encryptedText, (i-1)*blockSize);

    } catch (Exception e) {
        e.printStackTrace();
    }
    return encryptedText;
}

}

4

1 回答 1

1

您的循环似乎没有处理输入字符串中的所有字节:

for (i = 0; i < (normalText.length / 32); i++) {
        bytesProcessed += mode
                .processBytes(normalText, i * blockSize, blockSize, encryptedText, bytesProcessed);
}

它只处理从 0 到(text.Length/32)*blockSize.

因此,如果输入数组的长度为 35 个字节,则永远不会处理最后 3 个字节。

不如改用这样的东西:

bytesProcessed = mode.processBytes(normalText, 0, normalText.length, encryptedText,0);
//second argument of doFinal is offset in output buffer.
mode.doFinal(encryptedText, bytesProcessed);

如果这个工作正常,您肯定会知道问题是循环计数器中的一个错误。

更新:或者如果你想一次加密一个块,你可以尝试这样的事情:

for(int i=0; i<=(normalText.length/blockSize); i++) {
     int offset = i*blockSize;
     //To handle last block of bytes in input
     int len = Math.min(blockSize,normalText.length-offset);
     bytesProcessed += mode.processBytes(normalText,offset,len,encryptedText,bytesProcessed);
}
mode.doFinal(encryptedText, bytesProcessed);

解密也是一样

于 2013-06-25T13:31:47.393 回答