HMAC-SHA1各語言版本實現
阿新 • • 發佈:2019-02-04
在各大開放平臺大行其道的網際網路開發潮流中,呼叫各平臺的API介面過程中,無一例外都會用到計算簽名值(sig值)。而在各種計算簽名的方法中,經常被採用的就是HMAC-SHA1,現對HMAC-SHA1做一個簡單的介紹:
HMAC,雜湊訊息鑑別碼,基於金鑰的Hash演算法認證協議。實現原理為:利用已經公開的Hash函式和私有的金鑰,來生成固定長度的訊息鑑別碼;
SHA1、MD5等Hash演算法是比較常用的不可逆Hash簽名計算方法;
BASE64,將任意序列的8位元組字元轉換為人眼無法直接識別的符號編碼的一種方法;
各個語言版本的實現為:
Python版:
import hmac
import hashlib
import base64
C++版(Openssl):
HMAC( EVP_sha1(),
/*key len*/ strKey.size(),
/*data */(unsigned char*) strRandom.data(),
/*data len*/ strRandom.size(), digest, &digest_len)) Shell版: echo -n '3f88a95c532bea70' | openssl dgst -hmac '123' -sha1 -binary | base64