java中使用MD5加密技術


    在項目中經常會對一些信息進行加密,現在常用的信息加密技術有:MD5、RSA、DES等,今天主要說一下,md5加密,以及如何在java代碼根據自己的業務需求使用md5。

    MD5簡介:

    MD5即Message-Digest Algorithm 5(信息-摘要算法5),用於確保信息傳輸完整一致。是計算機廣泛使用的雜湊算法之一(又譯摘要算法、哈希算法),主流編程語言普遍已有MD5實現。將數據(如漢字)運算為另一固定長度值,是雜湊算法的基礎原理,MD5的前身有MD2、MD3和MD4。

    MD5算法具有以下特點:
    1、壓縮性:任意長度的數據,算出的MD5值長度都是固定的。
    2、容易計算:從原數據計算出MD5值很容易。
    3、抗修改性:對原數據進行任何改動,哪怕只修改1個字節,所得到的MD5值都有很大區別。
    4、強抗碰撞:已知原數據和其MD5值,想找到一個具有相同MD5值的數據(即偽造數據)是非常困難的。
    MD5的作用是讓大容量信息在用數字簽名軟件簽署私人密鑰前被"壓縮"成一種保密的格式(就是把一個任意長度的字節串變換成一定長的十六進制數字串)。除了MD5以外,其中比較有名的還有sha-1、RIPEMD以及Haval等。
    MD5在java中如何使用:
 1 package com.ow.util;
 2 
 3 import java.security.MessageDigest;
 4 
 5 /** 
 6  * 采用MD5加密解密  
 7  */  
 8 public class MD5Util {  
 9   
10     /*** 
11      * MD5加碼 生成32位md5碼 
12      */  
13     public static String string2MD5(String inStr){
14         MessageDigest md5 = null;  
15         try{  
16             md5 = MessageDigest.getInstance("MD5");  
17         }catch (Exception e){  
18             System.out.println(e.toString());  
19             e.printStackTrace();  
20             return "";  
21         }  
22         char[] charArray = inStr.toCharArray();  
23         byte[] byteArray = new byte[charArray.length];  
24   
25         for (int i = 0; i < charArray.length; i++)  
26             byteArray[i] = (byte) charArray[i];  
27         byte[] md5Bytes = md5.digest(byteArray);  
28         StringBuffer hexValue = new StringBuffer();  
29         for (int i = 0; i < md5Bytes.length; i++){  
30             int val = ((int) md5Bytes[i]) & 0xff;  
31             if (val < 16)  
32                 hexValue.append("0");  
33             hexValue.append(Integer.toHexString(val));  
34         }  
35         return hexValue.toString();  
36   
37     }
38     /**
39      * 根據自己的規則進行MD5加密
40      * 例如,現在需求是有字符串傳入zhang,xy
41      * 其中zhang是傳入的字符
42      * 然后需要將zhang的字符進行拆分z,和hang,
43      * 最后需要加密的字段為zxyhang
44      */
45     public static String MD5Test(String inStr){
46         String xy = "xy";
47         String finalStr="";
48         if(inStr!=null){
49             String fStr = inStr.substring(0, 1);
50             String lStr = inStr.substring(1, inStr.length());
51             finalStr = string2MD5( fStr+xy+lStr);
52             
53         }else{
54             finalStr = string2MD5(xy);
55         }
56         return finalStr;  
57     }
58     
59     // 測試 
60     public static void main(String args[]) { 
61         String s1 = "zhang";
62         System.out.println("使用工具類進行加密的為 "+MD5Test(s1));
63   
64     }  
65 }  

    其中函數MD5Test中的邏輯可以自己修改,修改成為與自己項目相關的代碼邏輯即可。

    參考文章:http://blog.csdn.net/xiangsuixinsheng/article/details/6871868


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM