2017-10-09 108 views
0

在Java和Swift中计算sha256时,它不匹配。Java sha256不匹配Swift sha256

的Java:

MessageDigest digest = MessageDigest.getInstance("SHA-256"); 
digest.update(secretKey.getBytes("UTF-8")); 

byte[] secretKeyBytes = secretKey.getBytes("UTF-8"); 

byte[] keyBytes = new byte[16]; 
System.arraycopy(digest.digest(), 0, keyBytes, 0, keyBytes.length); 

结果:[44, 112, -31, 43, 122, 6, 70, -7, 34, 121, -12, 39, -57, -77, -114, 115]

斯威夫特:

let secretKeyBytes = [UInt8](secretKey.utf8) 

var digest = SHA2(variant: SHA2.Variant.sha256) 
try digest.update(withBytes: secretKeyBytes) 
let keyDigest = try digest.finish() 

let keyBytes = Array(keyDigest[0...15]) 

结果:[44, 112, 225, 43, 122, 6, 70, 249, 34, 121, 244, 39, 199, 179, 142, 115]

它始于相同的值,但随后开始不同

+0

您的Java代码溢出并产生负值。 – the4kman

+0

[SHA256散列结果在Android和iOS中对于大数字有不同的结果](https://stackoverflow.com/questions/39018731/sha256-hash-results-different-across-android-ios-for-big-numbers) – pedrofb

回答

5

Bytes in Java are signed,因此它们只能表示-128到127的值,因此当它试图表示225(第三个字节)时,它会溢出到-31。两个字节的实际二进制表示将与1110 0001相同。

+0

任何想法如何解决这个问题,而无需修改Java代码?我现在无法改变这一点。试图将Swift中的'UInt8'转换为'Int8',但它不被CryptoSwift库接受。 –

+1

@JakubGruber,你可以使用'Int8(bitPattern:)' – user28434

+0

将得到的'keyBytes'映射到'[Int8]'中,但是库不接受[Int8] –