在Java中的MD2 hash哈希

作者: Arvin Chen 分类: Java 来源: Break易站(www.breakyizhan.com)

所述MD2是消息摘要算法。它是由Ronald Rivest于1989年开发的加密哈希函数。它针对8位计算机进行了优化。MD2算法在公钥基础结构中用作MD2和RSA生成的证书的一部分。从2014年开始,此算法现在不被视为安全算法。

要在Java中计算加密散列值,请在java.security包下使用MessageDigest类

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

  • MD2
  • MD5
  • SHA-1
  • SHA-224
  • SHA-256
  • SHA-384
  • SHA-512

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

例子:

输入:hello world
输出:d9cce882ee690a5c1ce70beff3a78c77

输入:GeeksForGeeks
输出:787df774a3d25dca997b1f1c8bfee4af

下面的程序显示了Java中MD2 hash哈希的实现。

// Java program to calculate MD2 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 MD2
            MessageDigest md = MessageDigest.getInstance("MD2");
  
            // 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 MD2 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 MD2 for: 

GeeksForGeeks : 787df774a3d25dca997b1f1c8bfee4af

hello world : d9cce882ee690a5c1ce70beff3a78c77

应用:

  • 加密
  • 数据的完整性
  •   本文标题:在Java中的MD2 hash哈希 - Break易站
    转载请保留页面地址:https://www.breakyizhan.com/java/6734.html
    扫描二维码添加微信 
  • ,领取淘宝优惠券,淘宝购物更优惠。现在添加微信,还可以领取机械键盘优惠券!添加微信后,分享淘宝选中的机械键盘给淘宝机器人即可领取!
    支持我们,就用微信淘宝!

    发表笔记

    电子邮件地址不会被公开。 必填项已用*标注

    更多阅读