Java中的 SHA-224 哈希
SHA-2 系列加密散列函数由六个散列函数组成。这些都是:
- SHA-224,具有 224 位哈希值
- SHA-256,具有 256 位哈希值
- SHA-384,具有 384 位哈希值
- SHA-512,具有 512 位哈希值
- SHA-512/224,具有 512 位哈希值
- SHA-512/256,具有 512 位哈希值
其中,SHA-256 和 SHA-512 是最普遍接受和使用的哈希函数,分别使用 32 位和 64 位字计算。 SHA-224 和 SHA-384 分别是 SHA-256 和 SHA-512 的截断版本,使用不同的初始值计算。
为了在Java中计算加密哈希值,使用了Java.security包下的MessageDigest 类。
MessagDigest 类提供以下加密哈希函数来查找文本的哈希值,如下所示:
- MD2
- MD5
- SHA-1
- SHA-224
- SHA-256
- SHA-384
- SHA-512
这些算法在名为getInstance()的静态方法中初始化。选择算法后,计算消息摘要值并将结果作为字节数组返回。 BigInteger 类用于将生成的字节数组转换为其符号表示。然后将此表示转换为十六进制格式以获得预期的 MessageDigest。
例子:
Input : hello world
Output :
2f05477fc24bb4faefd86517156dafdecec45b8ad3cf2522a563582bInput : GeeksForGeeks
Output :
c9e0629b317667db73eaa051cf05f4c5896f5c0c7c2cec4589919d02程序:下面的程序显示了 SHA-224 哈希在Java中的实现。
// Java program to calculate SHA-224 hash value import java.math.BigInteger; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class GFG { public static String encryptThisString(String input) { try { // getInstance() method is called with algorithm SHA-224 MessageDigest md = MessageDigest.getInstance("SHA-224"); // digest() method is called // to calculate message digest of the input string // returned as array of byte byte[] messageDigest = md.digest(input.getBytes()); // Convert byte array into signum representation BigInteger no = new BigInteger(1, messageDigest); // Convert message digest into hex value String hashtext = no.toString(16); // Add preceding 0s to make it 32 bit while (hashtext.length() < 32) { hashtext = "0" + hashtext; } // return the HashText return hashtext; } // For specifying wrong message digest algorithms catch (NoSuchAlgorithmException e) { throw new RuntimeException(e); } } // Driver code public static void main(String args[]) throws NoSuchAlgorithmException { System.out.println("HashCode Generated by SHA-224 for: "); String s1 = "GeeksForGeeks"; System.out.println("\n" + s1 + " : " + encryptThisString(s1)); String s2 = "hello world"; System.out.println("\n" + s2 + " : " + encryptThisString(s2)); } }
输出:HashCode Generated by SHA-224 for: GeeksForGeeks : c9e0629b317667db73eaa051cf05 f4c5896f5c0c7c2cec4589919d02 hello world : 2f05477fc24bb4faefd86517156daf decec45b8ad3cf2522a563582b
应用:
- 密码学
- 数据的完整性