我目前正在尝试使用NodeJs和SOAP实现对Royal Mail API的调用;我在按照示例python脚本
重新创建安全标头实现时遇到了困难python脚本如下
#!/usr/local/bin/python2.7
import os
import sha
import binascii
import base64
password = 'test'
CREATIONDATE = '2016-03-29T14:03:46Z'
nonce = '7715776714'
HASH = sha.new(password).digest()
BASE64PASSWORD = base64.b64encode(HASH)
digest = sha.new(nonce + CREATIONDATE + HASH).digest()
PASSWORDDIGEST = base64.b64encode(digest)
ENCODEDNONCE = base64.b64encode(nonce)
print 'NONCE = ', nonce
print 'BASE64PASSWORD', BASE64PASSWORD
print 'PASSWORDDIGEST ', PASSWORDDIGEST
print 'ENCODEDNONCE ', ENCODEDNONCE
print 'CREATIONDATE ', CREATIONDATE
哪个输出:
NONCE 7715776714
BASE64PASSWORD qUqP5cyxm6YcTAhz05Hph5gvu9M=
PASSWORDDIGEST coDzcnSZObFfrM0FY33GcfxjOj4=
ENCODEDNONCE NzcxNTc3NjcxNA==
CREATIONDATE 2016-03-29T14:03:46Z
我使用NodeJ重新创建了这个,但我似乎得到了不同的输出 - 在python版本中输入正确的密码并使用结果数据允许我使用输出对API进行有效调用从NodeJs给我授权失败
节点Js代码
var createdDate, password = 'test', nonce;
createdDate = '2016-03-29T14:03:46Z';
nonce = '7715776714';
var crypto = require("crypto"),
passHash = crypto.createHash('sha1'),
digestHash = crypto.createHash('sha1');
passHash.update(password);
var HASH = passHash.digest();
console.log('NONCE ' + nonce)
console.log('BASE64PASSWORD ' + base64_encode_string(HASH))
digestHash.update(nonce + createdDate + HASH);
var digest = digestHash.digest();
var PASSWORDDIGEST = base64_encode_string(digest);
console.log('PASSWORDDIGEST ' + PASSWORDDIGEST);
var ENCODEDNONCE = base64_encode_string(nonce.toString());
console.log('ENCODEDNONCE ' + ENCODEDNONCE);
console.log('CREATIONDATE ' + createdDate);
哪个输出
NONCE 7715776714
BASE64PASSWORD qUqP5cyxm6YcTAhz05Hph5gvu9M=
PASSWORDDIGEST FRMDpkDOi1j9KB/sDHg1b7BYQgA=
ENCODEDNONCE NzcxNTc3NjcxNA==
CREATIONDATE 2016-03-29T14:03:46Z
似乎HASH的Sha是相同的,但是第二个Sha(摘要)在NodeJs版本中给出了不同的结果。我指出哪里出错了?
供参考我在python中使用sha库,在NodeJs中使用crypto
答案 0 :(得分:0)
一个问题是你隐式将HASH
缓冲区转换为UTF-8字符串,这在将二进制转换为UTF-8时容易导致输出损坏。相反,您可以多次调用.update()
并在HASH
中保留二进制数据:
digestHash.update(nonce + createdDate);
digestHash.update(HASH);
var digest = digestHash.digest();
在不相关的说明中,您不需要base64_encode_string()
缓冲区,就像您可以buffer.toString('base64')
(例如HASH.toString('base64')
)那样。{/ p>