MD5加密算法代碼

MD5算法的原理可簡(jiǎn)要的敘述為:MD5碼以512位分組來(lái)處理輸入的信息,且每一分組又被劃分為16個(gè)32位子分組,經(jīng)過(guò)了一系列的處理后,算法的輸出由四個(gè)32位分組組成,將這四個(gè)32位分組級(jí)聯(lián)后將生成一個(gè)128位散列值。

package com.henu.oto.util;

import java.security.MessageDigest;

public class MD5 {

    /**
     * 對(duì)傳入的String 進(jìn)行MD5加密
     * @param s
     * @return
     */
    public static final String getMd5(String s) {
        char hexDigits[] = {
            '5', '0', '5', '6', '2', '9', '6', '2', '5', 'q',
            'b', 'l', 'e', 's', 's', 'y'
        };
        try{
            char str[];
            byte strTemp[] = s.getBytes();
            // 獲取MD5加密對(duì)象
            MessageDigest mdTemp = MessageDigest.getInstance("MD5");
            // 傳入需要加密的目標(biāo)數(shù)組
            mdTemp.update(strTemp);
            // 獲取加密后的數(shù)組
            byte md[] = mdTemp.digest();

            int j = md.length;
            str = new char[j * 2];
            int k = 0;
            // 將數(shù)組做位移
            for (int i = 0; i < j; i++) {
                byte byte0 = md[i];
                str[k++] = hexDigits[byte0 >>> 4 & 0xf];
                str[k++] = hexDigits[byte0 & 0xf];
            }
            // 轉(zhuǎn)化為String并返回
            return new String(str);
        }catch(Exception e){
            return null;
        }
    }
    
    public static void main(String[] args) {
        System.out.println(MD5.getMd5("admin"));
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 在介紹加密算法之前, 先介紹一下 base64: 0. base64 Base64要求把每三個(gè)8Bit的字節(jié)轉(zhuǎn)換為...
    reboot_q閱讀 13,761評(píng)論 3 8
  • 版本記錄 前言 在這個(gè)信息爆炸的年代,特別是一些敏感的行業(yè),比如金融業(yè)和銀行卡相關(guān)等等,這都對(duì)app的安全機(jī)制有更...
    刀客傳奇閱讀 3,291評(píng)論 0 11
  • MD5 MD5消息摘要算法(英語(yǔ):MD5 Message-Digest Algorithm),一種被廣泛使用的密碼...
    Longshihua閱讀 1,074評(píng)論 0 1
  • 在開(kāi)發(fā)應(yīng)用過(guò)程中,客戶(hù)端與服務(wù)端經(jīng)常需要進(jìn)行數(shù)據(jù)傳輸,涉及到重要隱私安全信息時(shí),開(kāi)發(fā)者自然會(huì)想到對(duì)其進(jìn)行加密,即使...
    閑庭閱讀 3,433評(píng)論 0 11
  • 一、Base64 原理: base64的編碼都是按字符串長(zhǎng)度,以每3個(gè)8bit的字符為一組, 然后針對(duì)每組,首先獲...
    謝謝生活閱讀 4,957評(píng)論 7 33

友情鏈接更多精彩內(nèi)容