如何用Sha256進行簡單的加密或者解密

 個人是今天第一次使用Sha256對數據進行加密操作,以往都是直接使用MD5加密最多也就是加鹽之後再進行加密

不過可能是個人應用的只是簡單的一個對數據的加密,所以感覺目前和MD5差距並不是很大.

1.首先要找到一個合適的加密工具類(網上一搜一大堆),我的放在最下面了

2.我目前的應用步驟

  • 我這邊先使用時候,我會根據id+key(這兩個都是生成的Longl類型的串)儲在數據庫中
  • 將兩者拼接在一起的字符串使用工具類加密,返還給接收數據的頁面
  • 查詢數據的時候,調用的地方會給我回傳id,和一個密匙
  • 我首先先通過id,查詢出數據庫真實的數據,之前數據在存儲數據庫中會存儲一個key,
  • 拿出這個ke與id按照之前的加密方式在加密一次,之後與前端頁面傳來的密匙進行比較,
  • 當兩者一致時候,我把正確的數據回傳給調用者,不一致則提示密匙錯誤

因爲是第一次使用sha256,所以只是簡單的應用,可能與每個人的應用不一樣,也可能我的使用方式錯了,請您指出來,我好及時改正

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class Sha256Util {

    /**
     * 利用java原生的類實現SHA256加密
     * @param str 加密後的報文
     * @return
     */
    public static String getSHA256(String str){
        MessageDigest messageDigest;
        String encodestr = "";
        try {
            messageDigest = MessageDigest.getInstance("SHA-256");
            messageDigest.update(str.getBytes("UTF-8"));
            encodestr = byte2Hex(messageDigest.digest());
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }
        return encodestr;
    }
    /**
     * 將byte轉爲16進制
     * @param bytes
     * @return
     */
    private static String byte2Hex(byte[] bytes){
        StringBuffer stringBuffer = new StringBuffer();
        String temp = null;
        for (int i=0;i<bytes.length;i++){
            temp = Integer.toHexString(bytes[i] & 0xFF);
            if (temp.length()==1){
                //1得到一位的進行補0操作
                stringBuffer.append("0");
            }
            stringBuffer.append(temp);
        }
        return stringBuffer.toString();
    }
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章