使用字节数组而非字符串作为输入的 Pure Lua md5

我正在使用这个链接中找到的算法 Pure Lua implementation of md5 来在嵌入式系统中使用,但它使用字符串作为输入。

对于我的特定应用,哈希需要接收类似于这样的十六进制数组:85202599ee7e0165ee32be43336755595955544554554747。

如何更改下面的函数以使用上面的数组计算哈希?

function md5.Calc(s)
  local msgLen=string.len(s)
  local padLen=56- msgLen % 64
  if msgLen % 64 > 56 then padLen=padLen+64 end
  if padLen==0 then padLen=64 end
  s=s..string.char(128)..string.rep(string.char(0),padLen-1)
  s=s..leIstr(8*msgLen)..leIstr(0)
  assert(string.len(s) % 64 ==0)
  local t=md5.consts
  local a,b,c,d=t[65],t[66],t[67],t[68]
  for i=1,string.len(s),64 do
    local X=leStrCuts(string.sub(s,i,i+63),4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4)
    assert(#X==16)
    X[0]=table.remove(X,1) -- zero based!
    a,b,c,d=md5.transform(a,b,c,d,X)
  end
  local swap=function (w) return beInt(leIstr(w)) end
  return string.format("%08x%08x%08x%08x",swap(a),swap(b),swap(c),swap(d))
end

return md5.Calc("85202599ee7e0165ee32be43336755595955544554554747"); -- 返回:cc238dfd3cf48d588714774efeaf9a1f
-- 但我需要像在 https://cryptii.com/pipes/md5-hash 中计算的返回值:c7e9f863554dc9a410c414f8758b307d
点赞
用户589259
用户589259

Lua字符串可以包含二进制数据:每个“字符”都是一个字节。这就是上面代码中使用的方式。您可以看到字符128(“0x80”或“0b10000000”)和零被用于填充。

因此,您不应更改上面的代码;而是应将十六进制字符串解码为二进制字符串,并将其用作上述函数的输入。

您可以在此处找到一种有趣而简洁的十六进制解码方法。

2020-06-27 23:16:20