如何将 Python HMAC 请求翻译成 Swift

废物

我已经在这大约 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] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章