使用Python中的秘密键应用HMAC SHA-512算法



我正在尝试使用python中的秘密键应用HMAC SHA-512算法,但我没有找到正确的签名方法。

我能够使用nodejs和c#进行python

nodejs

return crypto.createHmac('sha512', new Buffer(secretString, 'base64')).update(new Buffer(stringToSign)).digest('base64');

在C#

byte[] secretkeyBytes = Encoding.UTF8.GetBytes(apiSecret);
byte[] inputBytes = Encoding.UTF8.GetBytes(stringToSign);
using (var hmac = new HMACSHA512(secretkeyBytes))
{
  byte[] hashValue = hmac.ComputeHash(inputBytes);
  signature = System.Convert.ToBase64String(hashValue);
}

但是,在Python中,我没有想到一种方法。我已经尝试了:

b_secret_string=base64.b64encode(secret_string.encode('utf-8'))
hash = hmac.new(base64.b64encode(b_secret_string),'',sha512)
hash.update(string_to_sign.encode('utf-8'))
signature = base64.b64encode(hash.digest())

hashed = hmac.new(str(secret_string.encode('utf-8')),'',sha512)
hashed.update(string_to_sign.encode('utf-8'))
signature = base64.b64encode(hashed.digest())

,但它不起作用。如果可能的话,有人可以给我照亮吗?我真的很感激。

更新:

还尝试了以下内容:

string_to_sign = string_to_sign.encode('utf-8')
secret_string = secret_string.encode('utf-8')
hash = hmac.new(secret_string, string_to_sign, hashlib.sha512)
signature = base64.b64encode(hash.digest())

也尝试使用hexdigest():

signature = base64.b64encode(hash.hexdigest())

如果有人想测试它。应在Nodejs中返回与此代码相同的。

var crypto = require('crypto');
a = new Buffer('PRIVATE_KEY', 'base64');
hash = crypto.createHmac('sha512', a)
stringToSign = 'Stack OverFlow Funtime';
hash.update(new Buffer(stringToSign));
console.log(hash.digest('base64'));
$ node example.js
ugmH0VdttdAxGdpzNJnaNn1KlVS4wBzoK//dsPuvK65Zsl8FgT+3aLGnsEubThlv5/3chfyMmsUH//LdS1MXqg==

我找到了一种在Python中进行相同操作的方法。如果有人在以后的同一问题中通过同一问题,请在这里回答。

    hmac_key = base64.b64decode(secret_string)
    signature = hmac.new(hmac_key, string_to_sign, hashlib.sha512)
    signature_b64 = signature.digest().encode('base64')
    signature_lines = signature_b64.splitlines()
    signature_b64 = ''.join(signature_lines)

怎么样:

import hashlib    
print hashlib.sha512('some string').hexdigest()

最新更新