我已经在这大约 10 个小时了,无论我为 swift 使用什么 HMAC 组合,我都无法让它与 python 生成的密钥相匹配。
蟒蛇代码:
signature = hmac.new(secret.decode('hex'), msg=datastring, digestmod=hashlib.sha256).hexdigest()
SWIFT代码:
let key = SymmetricKey(data: self.secret.data(using: .utf8)!)
let hexData = HMAC<SHA256>.authenticationCode(for: datastring.data(using: .utf8)!, using: key)
let signature = Data(hexData).map { String(format: "%02hhx", $0) }.joined()
对我在 Swift 中做错(或遗漏)的任何帮助将不胜感激。
在此基础上的假设self.secret
是一个String
包含密钥的十六进制表示,两者之间的差异归结为你的使用:
self.secret.data(using: .utf8)!
它只会直接转换为底层字节,而不是将每个字符对转换为相应的字节,如下所示:
secret.decode('hex')
在 Python 2 中执行。
据我所知,Swift 标准库中没有执行此转换的函数,但您可以使用以下方法进行转换:
func bytes(fromHex input: String) -> Data {
var result = Data()
var byte: UInt8 = 0
for (index, character) in input.enumerated() {
let codeUnit = character.utf8[character.utf8.startIndex]
var nibble: UInt8 = 0
switch codeUnit {
case 0x30..<0x3a:
nibble = codeUnit - 0x30
case 0x61..<0x67:
nibble = codeUnit - 0x57
default:
break
}
if index % 2 == 0 {
byte |= (nibble << 4)
} else {
byte |= nibble
result.append(contentsOf: [byte])
byte = 0
}
}
return result
}
然后你的代码会变成:
let key = SymmetricKey(data: bytes(fromHex: self.secret))
let hexData = HMAC<SHA256>.authenticationCode(for: datastring.data(using: .utf8)!, using: key)
let signature = Data(hexData).map { String(format: "%02hhx", $0) }.joined()
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句