我正在开发一个需要执行 sha3-256 哈希的JAVA项目。 由于Bouncy Castle在其最新更新中实施了Sha3,我计划使用它们的实现。这是我的代码:
public static String sha3(final String input) {
String hash = "";
final SHA3.DigestSHA3 md = new SHA3.DigestSHA3(256);
md.update(input.getBytes());
hash = Main2.toString(md.digest());
return hash;
}
运行System.out.println(Main2.sha3(""));
时,我得到以下输出:
C5D2460186F7233C927E7DB2DCC703C0E500B653CA82273B7BFAD8045D85A470
当我搜索来自以下的基本sha3输出时:
维基百科:https://en.wikipedia.org/wiki/SHA-3
要么
NIST标准:http://csrc.nist.gov/groups/ST/toolkit/documents/Examples/SHA3-256_Msg0.pdf
,似乎我应该获得:
a7ffc6f8bf1ed76651c14756a061d662f580ff4de43b49fa82d80a4b80f8434a
我的代码中有错误吗?充气城堡的输出和NIST之间的任何联系?在充气城堡的实施中会出现错误吗?
感谢您的时间和问候。
答案 0 :(得分:6)
您的SHA3应该正确计算。
您的问题中的代码存在问题:
Main2.toString(String)
以下哈希值并将字节转换为十六进制字符串:
import java.security.MessageDigest;
import org.bouncycastle.jcajce.provider.digest.SHA3.DigestSHA3;
import org.bouncycastle.jcajce.provider.digest.SHA3.Digest256;
public class TestSha3 {
public static void main(String[] args) {
System.out.println(sha3(""));
}
public static String sha3(final String input) {
final DigestSHA3 sha3 = new Digest256();
sha3.update(input.getBytes());
return TestSha3.hashToString(sha3);
}
public static String hashToString(MessageDigest hash) {
return hashToString(hash.digest());
}
public static String hashToString(byte[] hash) {
StringBuffer buff = new StringBuffer();
for (byte b : hash) {
buff.append(String.format("%02x", b & 0xFF));
}
return buff.toString();
}
}
a7ffc6f8bf1ed76651c14756a061d662f580ff4de43b49fa82d80a4b80f8434a
我在Maven构建中使用了以下工件
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15on</artifactId>
<version>1.53</version>
</dependency>
答案 1 :(得分:2)
充气城堡图书馆版本的问题 如果你使用bouncy castle 1.50库(输入:SHA3-256(“”)) 弹性输出与NIST输出不匹配。
使用bouncy castle 1.54版本弹性输出等于NIST示例值(https://en.wikipedia.org/wiki/SHA-3中的示例值)
由于
答案 2 :(得分:1)
我猜你错误的Main2.toString
逻辑。 Main2.toString
应将byte[]
转换为十六进制字符串。
这是一个实现:
final protected static char[] hexArray = "0123456789ABCDEF".toCharArray();
public static String bytesToHex(byte[] bytes) {
char[] hexChars = new char[bytes.length * 2];
for ( int j = 0; j < bytes.length; j++ ) {
int v = bytes[j] & 0xFF;
hexChars[j * 2] = hexArray[v >>> 4];
hexChars[j * 2 + 1] = hexArray[v & 0x0F];
}
return new String(hexChars);
}
我试过你的代码,输出是:
A7FFC6F8BF1ED76651C14756A061D662F580FF4DE43B49FA82D80A4B80F8434A
/**
* Created by chenzhongpu on 19/10/2015.
*/
import org.bouncycastle.jcajce.provider.digest.*;
public class TestSHA3 {
final protected static char[] hexArray = "0123456789ABCDEF".toCharArray();
public static String bytesToHex(byte[] bytes) {
char[] hexChars = new char[bytes.length * 2];
for ( int j = 0; j < bytes.length; j++ ) {
int v = bytes[j] & 0xFF;
hexChars[j * 2] = hexArray[v >>> 4];
hexChars[j * 2 + 1] = hexArray[v & 0x0F];
}
return new String(hexChars);
}
public static String sha3(final String input){
String hash = "";
SHA3.DigestSHA3 md = new SHA3.DigestSHA3(256);
md.update(input.getBytes());
hash = bytesToHex(md.digest());
return hash;
}
public static void main(String[] args) {
System.out.println(sha3(""));
}
}
答案 3 :(得分:0)
无需创建自定义方法将byteArray转换为String,使用内置函数
public static String hashPassword(String password) {
DigestSHA3 md = new DigestSHA3(256);
md.update(password.getBytes());
byte[] digest = md.digest();
return Hex.toHexString(digest);
}
maven条目
<!-- https://mvnrepository.com/artifact/org.bouncycastle/bcprov-jdk15on -->
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15on</artifactId>
<version>1.56</version>
</dependency>