如何使用 bouncy castle 在 Java 中创建 SHA512 摘要字符串?
该单元测试失败:
public void testDigest() throws NoSuchAlgorithmException {
String hashExpected = "150a14ed5bea6cc731cf86c41566ac427a8db48ef1b9fd626664b3bfbb99071fa4c922f33dde38719b8c8354e2b7ab9d77e0e67fc12843920a712e73d558e197";
MessageDigest md = new MessageDigest();
String hashActual = new String(md.digest("hi"));
Assert.assertEquals(hashExpected, hashActual);
}
下面是我的 MessageDigest 类的实现:
import java.io.IOException;
import java.io.InputStream;
import java.security.NoSuchAlgorithmException;
import java.security.Security;
导入 org.bouncycastle.crypto.Digest;
导入 org.bouncycastle.crypto.digests.SHA512Digest;
导入 org.bouncycastle.crypto.io.DigestInputStream;
导入 org.bouncycastle.jce.provider.BouncyCastleProvider;
公共类消息摘要{
私人摘要消息摘要;
public MessageDigest() throws NoSuchAlgorithmException {
Security.addProvider(new BouncyCastleProvider());
messageDigest = new SHA512Digest();
}
public byte[] digest(String message) {
byte[] retValue = new byte[messageDigest.getDigestSize()];
messageDigest.update(message.getBytes(), 0, message.length());
messageDigest.doFinal(retValue, 0);
return retValue;
}
}
测试失败,原因如下:
junit.framework.ComparisonFailure: expected:<150a14ed5bea6cc731cf86c41566ac427a8db48ef1b9fd626664b3bfbb99071fa4c922f33dde38719b8c8354e2b7ab9d77e0e67fc12843920a712e73d558e197> but was:<
í[êlÇ1φÄf¬Bz�´Žñ¹ýbfd³¿»™¤É"ó=Þ8q›ŒƒTâ·«�wàæÁ(C’
q.sÕXá
当我将 byte[] 摘要转换为字符串时,我有一种感觉没有使用正确的编码方案。任何帮助将不胜感激。
This unit test is failing:
public void testDigest() throws NoSuchAlgorithmException {
String hashExpected = "150a14ed5bea6cc731cf86c41566ac427a8db48ef1b9fd626664b3bfbb99071fa4c922f33dde38719b8c8354e2b7ab9d77e0e67fc12843920a712e73d558e197";
MessageDigest md = new MessageDigest();
String hashActual = new String(md.digest("hi"));
Assert.assertEquals(hashExpected, hashActual);
}
Below is my implementation of my MessageDigest class:
import java.io.IOException;
import java.io.InputStream;
import java.security.NoSuchAlgorithmException;
import java.security.Security;
import org.bouncycastle.crypto.Digest; import org.bouncycastle.crypto.digests.SHA512Digest; import org.bouncycastle.crypto.io.DigestInputStream; import org.bouncycastle.jce.provider.BouncyCastleProvider;
public class MessageDigest { private Digest messageDigest;
public MessageDigest() throws NoSuchAlgorithmException {
Security.addProvider(new BouncyCastleProvider());
messageDigest = new SHA512Digest();
}
public byte[] digest(String message) {
byte[] retValue = new byte[messageDigest.getDigestSize()];
messageDigest.update(message.getBytes(), 0, message.length());
messageDigest.doFinal(retValue, 0);
return retValue;
}
}
The test fails with the following reason:
junit.framework.ComparisonFailure: expected:<150a14ed5bea6cc731cf86c41566ac427a8db48ef1b9fd626664b3bfbb99071fa4c922f33dde38719b8c8354e2b7ab9d77e0e67fc12843920a712e73d558e197> but was:<
í[êlÇ1φÄf¬Bz�´Žñ¹ýbfd³¿»™¤É"ó=Þ8q›ŒƒTâ·«�wàæÁ(C’
q.sÕXá
I have a feeling I'm not using the right encoding scheme when I convert my byte[] digest into a string. Any help would be appreciated.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
您期望的值是十六进制编码的值。您正在基于原始字节创建一个字符串,这是行不通的。
您应该尽可能使用标准 Java Crypto API,而不是 BouncyCastle 特定的 API。
尝试以下操作(十六进制库来自 commons-codec):
The value you're expecting is a Hex-encoded value. You're creating a String based on the raw bytes, which won't work.
You should use the standard Java Crypto API whenever possible instead of BouncyCastle specific APIs.
Try the following (the Hex library comes from commons-codec):
只是对 Kevin 的回答的补充:从 Java 5 开始,您可以使用
String.format("%0128x", new BigInteger(1,digesta))
而不是 commons-codec 将字节数组格式化为带前导零的 128 位十六进制编码数字。Just an addition to Kevin's answer: Since Java 5, you can use
String.format("%0128x", new BigInteger(1, digesta))
instead of commons-codec to format the byte array as a 128 digit hex encoded number with leading zeros.是的,您需要将字节数组转换为十六进制字符串。 :-) 查看 Apache Commons Codec,尤其是 Hex 类。
Yes, you need to turn your byte array into a hex string. :-) Look into Apache Commons Codec, especially the Hex class.
从 BouncyCastle 1.49 开始,
Hex
类中有一些toHexString
方法。例如:将以十六进制格式的 Java
String
形式返回哈希摘要。有关参考,请参阅 BouncyCastle javadoc 或 grepcode。
Since BouncyCastle 1.49 there is a handful
toHexString
method in theHex
class. For example:will return you the hash digest as a Java
String
in a hexadecimal format.For reference see BouncyCastle javadoc or grepcode.