常見的加密和解密算法—MD5

轉載:http://www.javashuo.com/article/p-ohdwjtsj-ey.htmlhtml

常見的加密和解密算法—MD5

1、MD5加密概述java

     Message Digest Algorithm MD5(中文名爲消息摘要算法第五版)爲計算機安全領域普遍使用的一種散列函數,用以提供消息的完整性保護。該算法的文件號爲RFC 1321(R.Rivest,MIT Laboratory for Computer Science and RSA Data Security Inc. April 1992)。web

MD5即Message-Digest Algorithm 5(信息-摘要算法5),用於確保信息傳輸完整一致。是計算機普遍使用的雜湊算法之一(又譯 摘要算法哈希算法),主流編程語言廣泛已有MD5實現。將數據(如漢字)運算爲另外一固定長度值,是雜湊算法的基礎原理,MD5的前身有MD二、 MD3MD4
MD5算法具備如下特色:
一、壓縮性:任意長度的數據,算出的MD5值長度都是固定的。
二、容易計算:從原數據計算出MD5值很容易。
三、抗修改性:對原數據進行任何改動,哪怕只修改1個字節,所獲得的MD5值都有很大區別。
四、強抗碰撞:已知原數據和其MD5值,想找到一個具備相同MD5值的數據(即僞造數據)是很是困難的。
MD5的做用是讓大容量信息在用 數字簽名軟件簽署私人 密鑰前被" 壓縮"成一種保密的格式(就是把一個任意長度的字節串變換成必定長的 十六進制數字串)。除了MD5之外,其中比較有名的還有 sha-1RIPEMD以及Haval等。
 
MD5 是非對稱的加密算法(PS:對稱加密就是加密用的密碼和解密用的密碼是同樣的,非對稱就是加密和解密用的密鑰不同)
 
參考鏈接: MD5加密

2、Java實現MD5加密解密算法

一、maven 引入apache的jar(不是maven項目,去網上下一個jar手動引入)apache

       <dependency>
                <groupId>org.apache.commons</groupId>
                <artifactId>commons-lang3</artifactId>
                <version>3.3.2</version>
            </dependency>

二、MD5使用代碼編程

package com.idailycar.ttqcweb.utils;

import org.apache.commons.codec.digest.DigestUtils;

public class MD5Util {
    /**
     * MD5方法
     *
     * @param text 明文
     * @param key 密鑰
     * @return 密文
     * @throws Exception
     */
    public static String md5(String text, String key) throws Exception {
        //加密後的字符串
        String encodeStr= DigestUtils.md5Hex(text + key);
        return encodeStr;
    }

    /**
     * MD5驗證方法
     *
     * @param text 明文
     * @param key 密鑰
     * @param md5 密文
     * @return true/false
     * @throws Exception
     */
    public static boolean verify(String text, String key, String md5) throws Exception {
        //根據傳入的密鑰進行驗證
        String md5Text = md5(text, key);
        if(md5Text.equalsIgnoreCase(md5))
        {
            return true;
        }

        return false;
    }
}
相關文章
相關標籤/搜索