Hash 纯LuaMD5使用字节数组而不是字符串作为输入

Hash 纯LuaMD5使用字节数组而不是字符串作为输入,hash,lua,cryptography,md5,Hash,Lua,Cryptography,Md5,我一直在研究一种算法,我在这个链接中找到了这种算法:用于嵌入式系统,但它使用字符串作为输入 对于我的特定应用程序,散列需要接收如下十六进制数组:85202599EE7E0165EE32BE4333675559555445544747 如何更改下面的函数以使用上面的数组计算哈希 function md5.Calc(s) local msgLen=string.len(s) local padLen=56- msgLen % 64 if msgLen % 64 > 56 then

我一直在研究一种算法,我在这个链接中找到了这种算法:用于嵌入式系统,但它使用字符串作为输入

对于我的特定应用程序,散列需要接收如下十六进制数组:85202599EE7E0165EE32BE4333675559555445544747

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

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"); -- returns: cc238dfd3cf48d588714774efeaf9a1f
-- but I need a return like that calculated in https://cryptii.com/pipes/md5-hash: c7e9f863554dc9a410c414f8758b307d

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

所以你根本不应该改变上面的代码;相反,您应该将十六进制字符串解码为二进制字符串,并将其用作上述函数的输入


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

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

所以你根本不应该改变上面的代码;相反,您应该将十六进制字符串解码为二进制字符串,并将其用作上述函数的输入


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

和?你认为这个答案有用吗?请跟进您的问题,并说明答案是否缺乏细节,或者是否可以接受。以及?你认为这个答案有用吗?请跟进您的问题,并指出答案是否缺乏细节,或者是否可以接受。