Lua实现md5算法(纯)
2021-07-24 本文已影响0人
binx6
-- 纯Lua实现md5算法
function string.md5(code)
local code = tostring(code)
local HexTable = {"0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F"}
local A = 0x67452301
local B = 0xefcdab89
local C = 0x98badcfe
local D = 0x10325476
local S11 = 7
local S12 = 12
local S13 = 17
local S14 = 22
local S21 = 5
local S22 = 9
local S23 = 14
local S24 = 20
local S31 = 4
local S32 = 11
local S33 = 16
local S34 = 23
local S41 = 6
local S42 = 10
local S43 = 15
local S44 = 21
local function F(x,y,z)
return (x & y) | ((~x) & z)
end
local function G(x,y,z)
return (x & z) | (y & (~z))
end
local function H(x,y,z)
return x ~ y ~ z
end
local function I(x,y,z)
return y ~ (x | (~z))
end
local function FF(a,b,c,d,x,s,ac)
a = a + F(b,c,d) + x + ac
a = (((a & 0xffffffff) << s) | ((a & 0xffffffff) >> 32 - s)) + b
return a & 0xffffffff
end
local function Lua(a,b,c,d,x,s,ac)
a = a + G(b,c,d) + x + ac
a = (((a & 0xffffffff) << s) | ((a & 0xffffffff) >> 32 - s)) + b
return a & 0xffffffff
end
local function HH(a,b,c,d,x,s,ac)
a = a + H(b,c,d) + x + ac
a = (((a & 0xffffffff) << s) | ((a & 0xffffffff) >> 32 - s)) + b
return a & 0xffffffff
end
local function II(a,b,c,d,x,s,ac)
a = a + I(b,c,d) + x + ac
a = (((a & 0xffffffff) << s) | ((a & 0xffffffff) >> 32 - s)) + b
return a & 0xffffffff
end
local function MD5StringFill(s)
local len = s:len()
local mod512 = len * 8 % 512
local fillSize = (448 - mod512) // 8
if mod512 > 448 then
fillSize = (960 - mod512) // 8
end
local rTab = {}
local byteIndex = 1
for i = 1,len do
local index = (i - 1) // 4 + 1
rTab[index] = rTab[index] or 0
rTab[index] = rTab[index] | (s:byte(i) << (byteIndex - 1) * 8)
byteIndex = byteIndex + 1
if byteIndex == 5 then
byteIndex = 1
end
end
local b0x80 = false
local tLen = #rTab
if byteIndex ~= 1 then
rTab[tLen] = rTab[tLen] | 0x80 << (byteIndex - 1) * 8
b0x80 = true
end
for i = 1,fillSize // 4 do
if not b0x80 and i == 1 then
rTab[tLen + i] = 0x80
else
rTab[tLen + i] = 0x0
end
end
local bitLen = math.floor(len * 8)
tLen = #rTab
rTab[tLen + 1] = bitLen & 0xffffffff
rTab[tLen + 2] = bitLen >> 32
return rTab
end
function getmd5(s)
local fillTab = MD5StringFill(s)
local result = {A,B,C,D}
for i = 1,#fillTab // 16 do
local a = result[1]
local b = result[2]
local c = result[3]
local d = result[4]
local offset = (i - 1) * 16 + 1
a = FF(a, b, c, d, fillTab[offset + 0], S11, 0xd76aa478)
d = FF(d, a, b, c, fillTab[offset + 1], S12, 0xe8c7b756)
c = FF(c, d, a, b, fillTab[offset + 2], S13, 0x242070db)
b = FF(b, c, d, a, fillTab[offset + 3], S14, 0xc1bdceee)
a = FF(a, b, c, d, fillTab[offset + 4], S11, 0xf57c0faf)
d = FF(d, a, b, c, fillTab[offset + 5], S12, 0x4787c62a)
c = FF(c, d, a, b, fillTab[offset + 6], S13, 0xa8304613)
b = FF(b, c, d, a, fillTab[offset + 7], S14, 0xfd469501)
a = FF(a, b, c, d, fillTab[offset + 8], S11, 0x698098d8)
d = FF(d, a, b, c, fillTab[offset + 9], S12, 0x8b44f7af)
c = FF(c, d, a, b, fillTab[offset + 10], S13, 0xffff5bb1)
b = FF(b, c, d, a, fillTab[offset + 11], S14, 0x895cd7be)
a = FF(a, b, c, d, fillTab[offset + 12], S11, 0x6b901122)
d = FF(d, a, b, c, fillTab[offset + 13], S12, 0xfd987193)
c = FF(c, d, a, b, fillTab[offset + 14], S13, 0xa679438e)
b = FF(b, c, d, a, fillTab[offset + 15], S14, 0x49b40821)
a = Lua(a, b, c, d, fillTab[offset + 1], S21, 0xf61e2562)
d = Lua(d, a, b, c, fillTab[offset + 6], S22, 0xc040b340)
c = Lua(c, d, a, b, fillTab[offset + 11], S23, 0x265e5a51)
b = Lua(b, c, d, a, fillTab[offset + 0], S24, 0xe9b6c7aa)
a = Lua(a, b, c, d, fillTab[offset + 5], S21, 0xd62f105d)
d = Lua(d, a, b, c, fillTab[offset + 10], S22, 0x2441453)
c = Lua(c, d, a, b, fillTab[offset + 15], S23, 0xd8a1e681)
b = Lua(b, c, d, a, fillTab[offset + 4], S24, 0xe7d3fbc8)
a = Lua(a, b, c, d, fillTab[offset + 9], S21, 0x21e1cde6)
d = Lua(d, a, b, c, fillTab[offset + 14], S22, 0xc33707d6)
c = Lua(c, d, a, b, fillTab[offset + 3], S23, 0xf4d50d87)
b = Lua(b, c, d, a, fillTab[offset + 8], S24, 0x455a14ed)
a = Lua(a, b, c, d, fillTab[offset + 13], S21, 0xa9e3e905)
d = Lua(d, a, b, c, fillTab[offset + 2], S22, 0xfcefa3f8)
c = Lua(c, d, a, b, fillTab[offset + 7], S23, 0x676f02d9)
b = Lua(b, c, d, a, fillTab[offset + 12], S24, 0x8d2a4c8a)
a = HH(a, b, c, d, fillTab[offset + 5], S31, 0xfffa3942)
d = HH(d, a, b, c, fillTab[offset + 8], S32, 0x8771f681)
c = HH(c, d, a, b, fillTab[offset + 11], S33, 0x6d9d6122)
b = HH(b, c, d, a, fillTab[offset + 14], S34, 0xfde5380c)
a = HH(a, b, c, d, fillTab[offset + 1], S31, 0xa4beea44)
d = HH(d, a, b, c, fillTab[offset + 4], S32, 0x4bdecfa9)
c = HH(c, d, a, b, fillTab[offset + 7], S33, 0xf6bb4b60)
b = HH(b, c, d, a, fillTab[offset + 10], S34, 0xbebfbc70)
a = HH(a, b, c, d, fillTab[offset + 13], S31, 0x289b7ec6)
d = HH(d, a, b, c, fillTab[offset + 0], S32, 0xeaa127fa)
c = HH(c, d, a, b, fillTab[offset + 3], S33, 0xd4ef3085)
b = HH(b, c, d, a, fillTab[offset + 6], S34, 0x4881d05)
a = HH(a, b, c, d, fillTab[offset + 9], S31, 0xd9d4d039)
d = HH(d, a, b, c, fillTab[offset + 12], S32, 0xe6db99e5)
c = HH(c, d, a, b, fillTab[offset + 15], S33, 0x1fa27cf8)
b = HH(b, c, d, a, fillTab[offset + 2], S34, 0xc4ac5665)
a = II(a, b, c, d, fillTab[offset + 0], S41, 0xf4292244)
d = II(d, a, b, c, fillTab[offset + 7], S42, 0x432aff97)
c = II(c, d, a, b, fillTab[offset + 14], S43, 0xab9423a7)
b = II(b, c, d, a, fillTab[offset + 5], S44, 0xfc93a039)
a = II(a, b, c, d, fillTab[offset + 12], S41, 0x655b59c3)
d = II(d, a, b, c, fillTab[offset + 3], S42, 0x8f0ccc92)
c = II(c, d, a, b, fillTab[offset + 10], S43, 0xffeff47d)
b = II(b, c, d, a, fillTab[offset + 1], S44, 0x85845dd1)
a = II(a, b, c, d, fillTab[offset + 8], S41, 0x6fa87e4f)
d = II(d, a, b, c, fillTab[offset + 15], S42, 0xfe2ce6e0)
c = II(c, d, a, b, fillTab[offset + 6], S43, 0xa3014314)
b = II(b, c, d, a, fillTab[offset + 13], S44, 0x4e0811a1)
a = II(a, b, c, d, fillTab[offset + 4], S41, 0xf7537e82)
d = II(d, a, b, c, fillTab[offset + 11], S42, 0xbd3af235)
c = II(c, d, a, b, fillTab[offset + 2], S43, 0x2ad7d2bb)
b = II(b, c, d, a, fillTab[offset + 9], S44, 0xeb86d391)
result[1] = result[1] + a
result[2] = result[2] + b
result[3] = result[3] + c
result[4] = result[4] + d
result[1] = result[1] & 0xffffffff
result[2] = result[2] & 0xffffffff
result[3] = result[3] & 0xffffffff
result[4] = result[4] & 0xffffffff
end
local retStr = ""
for i = 1,4 do
for _ = 1,4 do
local temp = result[i] & 0x0F
local str = HexTable[temp + 1]
result[i] = result[i] >> 4
temp = result[i] & 0x0F
retStr = retStr .. HexTable[temp + 1] .. str
result[i] = result[i] >> 4
end
end
return string.lower(retStr)
end
return getmd5(code)
end
-- 例: print(string.md5("a1b2c3d4e5f6g7h8i9j0"))
-- 输出: e6600c23ece4f2efb72d1575be275198