MD5 介绍

大家都知道,地球上任何人都有自己独一无二的指纹,这常常成为公安机关鉴别罪犯身份最值得信赖的方法。与之类似,MD5 就可以为任何文件(不管其大小、格式、数量)产生一个同样独一无二的“数字指纹”,如果任何人对文件名做了任何改动,其 MD5 值也就是对应的“数字指纹”就会发生变化。

MD5 原理

MD5 加密原理是散列算法,散列算法也称哈希算法。
比如10除以3余数为一,4除以3余数也为一,但余数为一的就不知道这个数是哪个了。
所以 MD5 不能解密。也是为什么扣扣密码只能重置,不能找回的原因。

Java MD5 实现

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class MD5Util {
    //待加密的密码
    public static String password = "zjb0425";
	
    public static void main(String args[]) {
        //结果字符串
        String result = "";
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(password.getBytes());
            byte b[] = md.digest();
            int i;
            StringBuffer buf = new StringBuffer("");
            for (int offset = 0; offset < b.length; offset++) {
                  i = b[offset];
                  if (i < 0)
                  i += 256;
                  if (i < 16)
                  buf.append("0");
                  buf.append(Integer.toHexString(i));
            }
            result = buf.toString();
            System.out.println("MD5(" + password + ",32小写) = " + result);
            System.out.println("MD5(" + password + ",32大写) = " + result.toUpperCase());
        } catch (NoSuchAlgorithmException e) {
              e.printStackTrace();
        }
    }
}

MD5 + Salt 加密

我们知道,如果直接对密码进行散列,那么黑客可以对一个已知密码(简单的密码)进行散列,然后通过对比散列值得到某用户的密码。换句话说,虽然黑客不能取得某特定用户的密码,但他可以知道使用特定密码的用户有哪些。密码加 Salt 可以一定程度上解决这一问题。所谓加 Salt,是由系统随机生成的,并且只有系统知道的字符串。这样,即便两个用户使用了同一个密码,由于系统为它们生成的 Salt 值不同,他们的散列值也是不同的。

相关文章:

  • 2021-05-31
  • 2021-09-14
  • 2022-12-23
  • 2022-12-23
  • 2021-12-26
  • 2021-12-12
猜你喜欢
  • 2021-12-23
  • 2022-01-16
  • 2022-12-23
  • 2021-08-15
  • 2021-11-06
  • 2021-09-23
  • 2021-09-13
相关资源
相似解决方案