加密算法:DigestUtils與java MessageDigest


1.使用Spring的DigestUtils

public class StringUtilTest {  
  
    static final String TARGET = "changeme";      
      
    /*  
     * 不可逆算法  MD5  
     */    
    @Test    
    public void Md5()    
    {    
        String str = DigestUtils.md5DigestAsHex(TARGET.getBytes());    
        System.out.println("md5Hex:     "+str);    
    }    
}  

 

        結果為:

 

        md5Hex:     4cb9c8a8048fd02294477fcb1a41191a


        缺點為:只提供了MD5的加密算法

 

2.使用commons-codec(需要提供commons-codec包)

 

public class UtilTest {  
  
    static final String TARGET = "中文123abc,./";      
      
    /*  
     * 不可逆算法  MD5  
     */    
    @Test    
    public void Md5()    
    {    
        String str = DigestUtils.md5Hex(TARGET);    
        System.out.println("md5Hex:     "+str);    
    }    
    /*  
     * 不可逆算法  SHA1  
     */    
    @Test    
    public void Sha1()    
    {    
        String str = DigestUtils.shaHex(TARGET);    
        print("shaHex:     "+str);    
        str = DigestUtils.sha256Hex(TARGET);    
        print("sha256Hex:  "+str);    
        str = DigestUtils.sha384Hex(TARGET);    
        print("sha384Hex:  "+str);    
        str = DigestUtils.sha512Hex(TARGET);    
        print("sha512Hex:  "+str);    
    }    
        
       
     /*  
      * 可逆算法  BASE64  
      */  
         
    @Test    
    public void Base64()    
    {    
        //加密    
        byte[] b = Base64.encodeBase64(TARGET.getBytes(), true);    
        String str = new String(b);    
        print("BASE64:     "+str);    
            
        //解密    
        byte[] b1 = Base64.decodeBase64(str);    
        print("解密之后內容為:  "+new String(b1));    
    }    
    public void print(Object obj)    
    {    
        System.out.println(obj);    
    }    
}  

 

支持MD5\Sha1\Base64加密和Bse64解密

運行結果:

原始字符串為:中文123abc,./
MD5加密為:9ba58cffe5815ea9f365b86a3f473ad5
Sha1加密為:ec2f9a1f8f601dd5e6889d65204a7a998a0aa389
Base64加密為:5Lit5paHMTIzYWJjLC4v


Base64解密為:中文123abc,./

3.java MessageDigest

@Test  
public void test()   
{  
    try   
    {  
        String password = "12345psw";  
          
        //MD5表示加密算法,可以選擇其他參數,如SHA-1等  
        MessageDigest digest = MessageDigest.getInstance("MD5");  
        //先調用update,再調動digest  
        digest.update(password.getBytes());  
        byte[] byteResult = digest.digest();  
          
        //因為加密完為字節數組,需要轉化為字符串  
        String result = convertbyte2String(byteResult);  
          
        System.out.println(result);  
    }  
    catch (NoSuchAlgorithmException e)   
    {  
        e.printStackTrace();  
    }  
      
}  
  
//將字節數組轉化為字符串  
private String convertbyte2String(byte[] byteResult)   
{  
    char[] hexDigits = {'0','1','2','3','4','5','6','7','8','9', 'A','B','C','D','E','F' };  
      
    //4位代表一個16進制,所以長度需要變為原來2倍  
    char[] result = new char[byteResult.length*2];  
      
    int index = 0;  
    for(byte b:byteResult)  
    {  
        //先轉換高4位  
        result[index++] = hexDigits[(b>>>4)& 0xf];  
        result[index++] = hexDigits[b& 0xf];  
    }  
    return new String(result);  
}  

 


免責聲明!

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



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