HMAC-SHA1加密

 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;
     }
相关文章
相关标签/搜索