package com.sica.sha;
import com.google.common.base.Strings;
import java.security.MessageDigest;
/**
* Created by xiang.li on 2015/2/11.
*/
public class SHA {
/**
* 定義加密方式
*/
private final static String KEY_SHA = "SHA";
private final static String KEY_SHA1 = "SHA-1";
/**
* 全局數組
*/
private final static String[] hexDigits = { "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };
/**
* 構造函數
*/
public SHA() {
}
/**
* SHA 加密
* @param data 需要加密的字節數組
* @return 加密之后的字節數組
* @throws Exception
*/
public static byte[] encryptSHA(byte[] data) throws Exception {
// 創建具有指定算法名稱的信息摘要
// MessageDigest sha = MessageDigest.getInstance(KEY_SHA);
MessageDigest sha = MessageDigest.getInstance(KEY_SHA1);
// 使用指定的字節數組對摘要進行最后更新
sha.update(data);
// 完成摘要計算並返回
return sha.digest();
}
/**
* SHA 加密
* @param data 需要加密的字符串
* @return 加密之后的字符串
* @throws Exception
*/
public static String encryptSHA(String data) throws Exception {
// 驗證傳入的字符串
if (Strings.isNullOrEmpty(data)) {
return "";
}
// 創建具有指定算法名稱的信息摘要
MessageDigest sha = MessageDigest.getInstance(KEY_SHA);
// 使用指定的字節數組對摘要進行最后更新
sha.update(data.getBytes());
// 完成摘要計算
byte[] bytes = sha.digest();
// 將得到的字節數組變成字符串返回
return byteArrayToHexString(bytes);
}
/**
* 將一個字節轉化成十六進制形式的字符串
* @param b 字節數組
* @return 字符串
*/
private static String byteToHexString(byte b) {
int ret = b;
//System.out.println("ret = " + ret);
if (ret < 0) {
ret += 256;
}
int m = ret / 16;
int n = ret % 16;
return hexDigits[m] + hexDigits[n];
}
/**
* 轉換字節數組為十六進制字符串
* @param bytes 字節數組
* @return 十六進制字符串
*/
private static String byteArrayToHexString(byte[] bytes) {
StringBuffer sb = new StringBuffer();
for (int i = 0; i < bytes.length; i++) {
sb.append(byteToHexString(bytes[i]));
}
return sb.toString();
}
/**
* 測試方法
* @param args
*/
public static void main(String[] args) throws Exception {
String key = "123";
System.out.println(encryptSHA(key));
}
}