Java 中的 SHA-384 哈希

原文:https://www.geeksforgeeks.org/sha-384-hash-in-java/

SHA-2 密码散列函数家族由六个散列函数组成。这些是:

  1. SHA-224,具有 224 位哈希值
  2. SHA-256,具有 256 位哈希值
  3. SHA-384,384 位哈希值
  4. SHA-512,512 位哈希值
  5. SHA-512/224,具有 512 位哈希值
  6. SHA-512/256, with 512 bit hash values

    其中,SHA-256 和 SHA-512 是最普遍接受和使用的散列函数,分别用 32 位和 64 位字计算。SHA-224 和 SHA-384 分别是 SHA-256 和 SHA-512 的截断版本,用不同的初始值计算。

    为了计算 Java 中的加密散列值,使用了包 java.security 下的消息摘要类

    MessagDigest 类提供以下加密哈希函数来查找文本的哈希值,如下所示:

    • MD2
    • 讯息摘要 5
    • SHA-1
    • SHA-224
    • SHA-256
    • SHA-384
    • SHA-512

    这些算法在名为 getInstance() 的静态方法中初始化。选择算法后,计算消息摘要值,并将结果作为字节数组返回。使用 BigInteger 类,将结果字节数组转换为它的符号表示。然后,该表示被转换为十六进制格式,以获得预期的消息摘要。

    示例:

    输入 : hello world 输出: BD 8e 75 a67f29f 701a 4e 040385 e2e 23986333 e 10239211 af 907 fcbb 83578 B3 e 417 CB 71 ce 646 EFD 0819 DD 8c 088 de 1 BD

    输入 : GeeksForGeeks 输出: 19cc 78d 220368 a 892 cc 9 c 54 d2f 43 d5e 1823534 f3e 22 b 0d 475 de 18 e 030 E7 C4 b 411704 c 79 e 9600 bb 93399688 E7 f 09 bb 226

    程序:下面的程序展示了 SHA-384 哈希在 Java 中的实现。

    ```java // Java program to calculate SHA-384 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-384             MessageDigest md = MessageDigest.getInstance("SHA-384");

    // 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-384 for: ");

    String s1 = "GeeksForGeeks";         System.out.println("\n" + s1 + " : " + encryptThisString(s1));

    String s2 = "hello world";         System.out.println("\n" + s2 + " : " + encryptThisString(s2));     } } ```

    Output:

    ```java HashCode Generated by SHA-384 for:

    GeeksForGeeks : 19cc78d220368a892cc9c54d2f43d5e1823 534f3e22b0d475de18e030e7c4b411704c79e9600bb93399688 e7f09bb226

    hello world : fdbd8e75a67f29f701a4e040385e2e2398630 3ea10239211af907fcbb83578b3e417cb71ce646efd0819dd8c 088de1bd

    ```

    应用:

    • 密码系统
    • 数据完整性