轉自:http://blog.csdn.net/jiang1013nan/article/details/17318133
在各大開放平臺大行其道的互聯網開發潮流中,調用各平臺的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))