1. 程式人生 > >HMAC-SHA1各語言版本實現

HMAC-SHA1各語言版本實現

        在各大開放平臺大行其道的網際網路開發潮流中,呼叫各平臺的API介面過程中,無一例外都會用到計算簽名值(sig值)。而在各種計算簽名的方法中,經常被採用的就是HMAC-SHA1,現對HMAC-SHA1做一個簡單的介紹:

        HMAC,雜湊訊息鑑別碼,基於金鑰的Hash演算法認證協議。實現原理為:利用已經公開的Hash函式和私有的金鑰,來生成固定長度的訊息鑑別碼;

        SHA1、MD5等Hash演算法是比較常用的不可逆Hash簽名計算方法;

        BASE64,將任意序列的8位元組字元轉換為人眼無法直接識別的符號編碼的一種方法;

        各個語言版本的實現為:

        Python版:

              import hmac

              import hashlib

              import base64

              hmac.new(Token,data,hashlib.sha1).digest().encode('base64').rstrip()         PHP版: base64_encode(hash_hmac("SHA1",clientStr,Token , true))

          C++版(Openssl):

               HMAC(  EVP_sha1(),

                   /*key data*/ strKey.data(),
                   /*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