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; }