您的位置:首页 > 编程语言 > Java开发

java加密技术一(单向加密算法)

2016-07-06 11:28 423 查看
</pre>java加密之单向加密算法:MD5,SHA,HMAC。<p></p><p>一、MD5加密算法:</p><p></p><pre code_snippet_id="1747607" snippet_file_name="blog_20160706_2_8502972" name="code" class="java">/**
* MD5加密算法
*
* @param data 要加密的数据
*/
public static byte[] MD5Encrypt(byte[] data) {
byte[] b = null;
try {
MessageDigest md = MessageDigest.getInstance(“MD5”);
md.update(data);
b = md.digest();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return b;
}


二、SHA加密算法

/**
* SHA加密算法
*
* @param data 要加密的数据
*/
public static byte[] SHAEncrypt(byte[] data) {
byte[] b = null;
try {
MessageDigest md = MessageDigest.getInstance("SHA");
md.update(data);
b = md.digest();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return b;
}
三、HMAC加密算法

HMAC(Hash Message Authentication Code,散列消息鉴别码,基于密钥的Hash算法的认证协议。消息鉴别码实现鉴别的原理是,用公开函数和密钥产生一个固定长度的值作为认证标识,用这个标识鉴别消息的完整性。使用一个密钥生成一个固定大小的小数据块,即MAC,并将其加入到消息中,然后传输。接收方利用与发送方共享的密钥进行鉴别认证等。
3.1、初始化秘钥

/**
* 初始化HMAC秘钥
*
* @return
*/
public static String iniHMACKey() {
String key = "";
try {
KeyGenerator keyGenerator = KeyGenerator.getInstance(HMAC_KEY);
SecretKey secretKey = keyGenerator.generateKey();
BASE64Encoder encoder = new BASE64Encoder();
key = encoder.encode(secretKey.getEncoded());
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return key;
}
3.2、用HMAC的秘钥对数据进行加密
/**
*
* @param data 加密数据
* @param key 秘钥
* @return
*/
public static byte[] HMACEncrypt(byte[] data, String key) {
SecretKey secretKey = new SecretKeySpec(BASE64D(key), HMAC_KEY);
byte[] b = null;
try {
Mac mac = Mac.getInstance(secretKey.getAlgorithm());
mac.init(secretKey);
b = mac.doFinal(data);

} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (InvalidKeyException e) {
e.printStackTrace();
}
return b;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  加密技术 算法 md5