java加密技术一(单向加密算法)
Posted rage_angel
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java加密技术一(单向加密算法)相关的知识,希望对你有一定的参考价值。
</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;
以上是关于java加密技术一(单向加密算法)的主要内容,如果未能解决你的问题,请参考以下文章