目标C和Java中的Sha256哈希

罗诺·金

Sha256散列函数在目标c中给出的散列字符串比Java长。在目标C中添加了多余的零,如何使哈希合理化?

目标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;
}

爪哇

 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中对字节数组进行十六进制编码的一些替代解决方案,请参见将字节转换为十六进制的Java代码

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章