1. 程式人生 > >Java SHA-256 演算法例項

Java SHA-256 演算法例項

一)java.security.MessageDigest 類:

   此 MessageDigest 類為應用程式提供資訊摘要演算法的功能,如 MD5 或 SHA 演算法。資訊摘要是安全的單向雜湊函式,它接收任意大小的資料,並輸出固定長度的雜湊值。

MessageDigest 物件開始被初始化。該物件通過使用 update 方法處理資料。任何時候都可以呼叫 reset 方法重置摘要。一旦所有需要更新的資料都已經被更新了,應該呼叫 digest 方法之一完成雜湊計算。

對於給定數量的更新資料,digest 方法只能被呼叫一次。在呼叫 digest 之後,MessageDigest 物件被重新設定成其初始狀態。

該實現可隨意選擇是否實現 Cloneable 介面。客戶端應用程可以通過嘗試複製和捕獲 CloneNotSupportedException 來測試可複製性:

 MessageDigest md = MessageDigest.getInstance("SHA");

 try {
     md.update(toChapter1);
     MessageDigest tc1 = md.clone();
     byte[] toChapter1Digest = tc1.digest();
     md.update(toChapter2);
     ...etc.
 } catch (CloneNotSupportedException cnse) {
     throw new DigestException("couldn't make digest of partial content");
 }
 

注意,如果給定的實現是不可複製的,而事先已經知道摘要的數目,則仍然能夠通過例項化幾個例項計算中間摘要。

注意,由於歷史原因,此類是抽象類,是從 MessageDigestSpi 擴充套件的。應用程式開發人員只需注意在此 MessageDigest 類中定義的方法;超類中的所有方法是供希望提供自己的資訊摘要演算法實現的加密服務提供者使用的。

二)例項程式碼:

package org.zhang.sha_256;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class StringEncrypt {
    /**
     * 對字串加密,加密演算法使用MD5,SHA-1,SHA-256,預設使用SHA-256
     *
     * @param strSrc
     *            要加密的字串
     * @param encName
     *            加密型別
     * @return
     */
    public static String Encrypt(String strSrc, String encName) {
        MessageDigest md = null;
        String strDes = null;

        byte[] bt = strSrc.getBytes();
        try {
            if (encName == null || encName.equals("")) {
                encName = "SHA-256";
            }
            md = MessageDigest.getInstance(encName);
            md.update(bt);
            strDes = bytes2Hex(md.digest()); // to HexString
        } catch (NoSuchAlgorithmException e) {
            return null;
        }
        return strDes;
    }

    public static String bytes2Hex(byte[] bts) {
        String des = "";
        String tmp = null;
        for (int i = 0; i < bts.length; i++) {
            tmp = (Integer.toHexString(bts[i] & 0xFF));
            if (tmp.length() == 1) {
                des += "0";
            }
            des += tmp;
        }
        return des;
    }
   
    public static void main(String args[]){
     String s=StringEncrypt.Encrypt("汪業培", "");
     System.out.println(s);
    }
}