我在python中有以下代码:
myBytes = m.digest()
for one in myBytes:
print(one, end=' ')
print(end='\n')
intlist = int.from_bytes(myBytes, 'little')
print("intlist", intlist)
以上代码打印以下结果
72 230 166 56 69 98 5 189 49 43 129 54 237 2 147 230
intlist 306485766027497339553611008967975560776
现在我想在java中实现完全相同的结果。到目前为止,这是我的代码:
byte[] myBytes = md.digest();
System.out.println(Arrays.toString(myBytes));
BigInteger intlist = new BigInteger(myBytes);
System.out.println("intlist=" + intlist);
我得到的结果如下:
[72,-26,-90,56,69,98,5,-67,49,43,-127,54,-19,2,-109, -26]
intList中= 96902015312221227689534558263304164326
java的结果对我想做的事情是错误的。我想获得与python代码完全相同的值。
有什么想法吗?
答案 0 :(得分:3)
你在Python中指定了little-endian字节顺序:
intlist = int.from_bytes(myBytes, 'little')
但Java BigInteger(byte[] val)
构造函数以big-endian顺序获取输入。此外,int.from_bytes
默认假设输入表示无符号整数,而BigInteger(byte[] val)
将其输入解释为2的补码有符号整数。
如果要在Java中复制Python结果,请颠倒数组的顺序,并使用符号/幅度BigInteger(int signum, byte[] magnitude)
构造函数将数组视为表示正数:
byte[] bytes = {72, -26, -90, 56, 69, 98, 5, -67, 49, 43, -127, 54, -19, 2, -109, -26};
for (int i = 0; i < bytes.length / 2; i++) {
byte temp = bytes[i];
bytes[i] = bytes[bytes.length - i - 1];
bytes[bytes.length - i - 1] = temp;
}
System.out.println(new BigInteger(1, bytes));
输出:
306485766027497339553611008967975560776