SHA-1(安全哈希算法,也称为 SHS、安全哈希标准)是由美国政府发布的一种加密哈希算法。
HmacSHA1:
HMAC,全称为“Hash Message Authentication Code”,中文名“散列消息鉴别码”,主要是利用哈希算法,以一个密钥和一个消息为输入,生成一个消息摘要作为输出。一般的,消息鉴别码用于验证传输于两个共 同享有一个密钥的单位之间的消息。HMAC 可以与任何迭代散列函数捆绑使用。MD5 和 SHA-1 就是这种散列函数。HMAC 还可以使用一个用于计算和确认消息鉴别值的密钥
- public static String getHmacSHA1(String message, String key) {
- String hmacSha1 = null;
- try {
- // url encode
- message = URLEncoder.encode(message, "UTF-8");
- // hmac-sha1加密
- Mac mac = Mac.getInstance("HmacSHA1");
- SecretKeySpec spec = new SecretKeySpec(key.getBytes(), "HmacSHA1");
- mac.init(spec);
- byte[] byteHMAC = mac.doFinal(message.getBytes());
- // base64 encode
- hmacSha1 = new BASE64Encoder().encode(byteHMAC);
- } catch (NoSuchAlgorithmException e) {
- DevLog.error("NoSuchAlgorithmException: ",e);
- PA18LogUtil.error(log, "NoSuchAlgorithmException: ",e);
- } catch (InvalidKeyException e) {
- DevLog.info("InvalidKeyException: "+e);
- PA18LogUtil.error(log, "InvalidKeyException: ",e);
- } catch (UnsupportedEncodingException e) {
- DevLog.info("UnsupportedEncodingException: "+e);
- PA18LogUtil.error(log, "UnsupportedEncodingException: ",e);
- }
- return hmacSha1;
- }