0

我有以下循环(解密程序的一部分):

for(int i=0; i < inputd.length; i++){
        byte[] blockd = this.fromHex(inputd[i]);
        byte[] pt = cipher.doFinal(blockd); // Problem?

        if(plainText == null)
            plainText = new String(pt);
        else
            plainText+=new String(pt);
}

在标记语句中,cipher.doFinal(blockd)返回不同大小的数组。问题是如果在一个大小为 30 的迭代数组中返回 30 并且在下一次迭代中说它的 25(更小)然后赋值替换前 25 个字符并且前一次迭代的最后 5 个字符仍在数组中。

这是fromHex()功能:

    private byte[] fromHex(String b){
            byte[] bt = (new BigInteger(b, 16)).toByteArray();
            if(bt.length > 64){
                bt = Arrays.copyOfRange(bt, 1, 65);
            }
            return bt;
    }

我应该如何解决这个问题?在循环结束之前将 null 分配给两者都没有帮助。

4

1 回答 1

1

由于每次您在每次迭代中都创建 byte[]pt 的新实例,因此无需担心此数组的先前大小。
尝试使用此方法转换十六进制。字符串到字节数组

private byte[] toBytes(String s)
{
    int len = s.length();     
    byte[] data = new byte[len / 2];     
    for (int i = 0; i < len; i += 2) 
    {         
        data[i / 2] = (byte) ((Character.digit(s.charAt(i), 16) << 4)+ Character.digit(s.charAt(i+1), 16));     
    }     
    return data; 
}
于 2013-03-31T07:42:05.980 回答