HMAC-SHA1各語言版本實現

轉自: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

              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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章