在python中使用密钥应用HMAC SHA-512算法

时间:2015-05-04 15:43:13

标签: c# python node.js python-2.7 python-3.x

我正在尝试在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==

2 个答案:

答案 0 :(得分:3)

我找到了一种在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)

答案 1 :(得分:1)

怎么样:

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