java加密体系-SHA256
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import org.apache.commons.codec.digest.DigestUtils;
/**
* SHA256 单向散列函数 指纹 消息摘要算法 哈希函数
* 值为32个字节
* @author NP0612
*/
public class LukeSHA256 {
/**
* 利用java原生的摘要实现SHA256加密
* @param bytes 加密后的报文
* @return
*/
public static String sha256Hex(byte[] bytes){
MessageDigest messageDigest;
String encodeStr = "";
try {
messageDigest = MessageDigest.getInstance("SHA-256");
messageDigest.update(bytes);
encodeStr = byte2Hex(messageDigest.digest());
} catch (NoSuchAlgorithmException 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();
}
public static void main(String[] args) {
byte[] bytes = new byte[2];
bytes[0] = 44;
bytes[1] = 11;
System.out.println(LukeSHA256.sha256Hex(bytes));
System.out.println(DigestUtils.sha256Hex(bytes));
//16进制字符串两位占一个字节
System.out.println(DigestUtils.sha256Hex(bytes).length());
}
}
还没有评论,来说两句吧...