gpt4 book ai didi

java - Objective C 和 Java 中的 Sha256 哈希

转载 作者:行者123 更新时间:2023-11-30 10:46:39 24 4
gpt4 key购买 nike

Sha256 哈希函数在 objective-c 中给出了比 Java 更长的哈希字符串。在 Objective-C 中添加了额外的零,我怎样才能使散列合理化?

Objective-C :

-(NSString*) sha256:(NSString *)clear{
const char *s=[clear cStringUsingEncoding:NSASCIIStringEncoding];
NSData *keyData=[NSData dataWithBytes:s length:strlen(s)];
uint8_t digest[CC_SHA256_DIGEST_LENGTH]={0};
CC_SHA256(keyData.bytes, keyData.length, digest);
NSData *out=[NSData dataWithBytes:digest
length:CC_SHA256_DIGEST_LENGTH];
NSString *hash=[out description];
hash = [hash stringByReplacingOccurrencesOfString:@" " withString:@""];
hash = [hash stringByReplacingOccurrencesOfString:@"<" withString:@""];
hash = [hash stringByReplacingOccurrencesOfString:@">" withString:@""];

return hash;
}

Java

 public static  String generateHashString(String data)
{
try {
MessageDigest md = MessageDigest.getInstance("SHA-256");
byte[] dataInBytes = data.getBytes(StandardCharsets.UTF_8);
md.update(dataInBytes);
byte[] mdbytes = md.digest();
StringBuffer hexString = new StringBuffer();
for (int i=0;i<mdbytes.length;i++) {
hexString.append(Integer.toHexString(0xFF & mdbytes[i]));
}

return hexString.toString();

} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}

return null;
}

最佳答案

对于小于 16 的整数,Integer.toHexString() 将只有一个字符长,而您需要额外的“0”字符。

你可以使用 String.format():

for (int i = 0; i < mdbytes.length; i++) {
hexString.append(String.format("%02x", 0xFF & mdbytes[i]));
}

此外,在这种情况下,您确实应该使用 StringBuilder 而不是 StringBuffer,因为只涉及一个线程。

参见 Java code To convert byte to Hexadecimal用于在 Java 中对字节数组进行十六进制编码的一些替代解决方案。

关于java - Objective C 和 Java 中的 Sha256 哈希,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36428662/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com