JAVA MD5的误区

下面这句话引用自百度百科:
MD5还广泛用于操作系统的登陆认证上,如Unix、各类BSD系统登录密码、数字签名等诸多方面。如在Unix系统中用户的密码是以MD5(或其它类似的算法)经Hash运算后存储在文件系统中。当用户登录的时候,系统把用户输入的密码进行MD5 Hash运算,然后再去和保存在文件系统中的MD5值进行比较,进而确定输入的密码是否正确。通过这样的步骤,系统在并不知道用户密码的明码的情况下就可以确定用户登录系统的合法性。这可以避免用户的密码被具有系统管理员权限的用户知道。

也就是说,MD5并不是我们通常理解的加密和解密,它并没有解密这个功能。那它有什么用呢,从上面我们可以知道每一个明文都对应唯一的一个密文(但我并没有说一个密文也对应的唯一的一个明文,因为我也不知道是不是一一映射)。但是密文到明文是不可逆的(不过由于技术的革新,好像现在可逆了)。以下是示例:

import java.security.MessageDigest;  
import java.security.NoSuchAlgorithmException;  
public class CreateMD5 {  
    public static String getMd5(String plainText) {  
        try {  
            MessageDigest md = MessageDigest.getInstance("MD5");  
            md.update(plainText.getBytes());  
            byte b[] = md.digest();  
            return new String(b);   
        } catch (NoSuchAlgorithmException e) {  
            e.printStackTrace();  
            return null;  
        }  
    }  
    public static void main(String[] args) {
        for(int i=0;i<10;i++){
            System.out.println(CreateMD5.getMd5("hello"));  
        }

    }  
}

这里写图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章