Guest User

Untitled

a guest
Oct 19th, 2018
86
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 6.42 KB | None | 0 0
  1. md5 = {}
  2.  
  3. local char, byte, format, rep, sub =
  4. string.char, string.byte, string.format, string.rep, string.sub
  5. local bit_or, bit_and, bit_not, bit_xor, bit_rshift, bit_lshift
  6.  
  7. do
  8. bit_not = bit.bnot
  9.  
  10. local tobit = function(n)
  11. return n <= 0x7fffffff and n or -(bit_not(n) + 1)
  12. end
  13.  
  14. local normalize = function(f)
  15. return function(a,b) return tobit(f(tobit(a), tobit(b))) end
  16. end
  17.  
  18. bit_or, bit_and, bit_xor = normalize(bit.bor), normalize(bit.band), normalize(bit.bxor)
  19. bit_rshift, bit_lshift = normalize(bit.rshift), normalize(bit.lshift)
  20. end
  21.  
  22. -- convert little-endian 32-bit int to a 4-char string
  23. local function lei2str(i)
  24. local f=function (s) return char( bit_and( bit_rshift(i, s), 255)) end
  25. return f(0)..f(8)..f(16)..f(24)
  26. end
  27.  
  28. -- convert raw string to big-endian int
  29. local function str2bei(s)
  30. local v=0
  31. for i=1, #s do
  32. v = v * 256 + byte(s, i)
  33. end
  34. return v
  35. end
  36.  
  37. -- convert raw string to little-endian int
  38. local function str2lei(s)
  39. local v=0
  40. for i = #s,1,-1 do
  41. v = v*256 + byte(s, i)
  42. end
  43. return v
  44. end
  45.  
  46. -- cut up a string in little-endian ints of given size
  47. local function cut_le_str(s,...)
  48. local o, r = 1, {}
  49. local args = {...}
  50. for i=1, #args do
  51. table.insert(r, str2lei(sub(s, o, o + args[i] - 1)))
  52. o = o + args[i]
  53. end
  54. return r
  55. end
  56.  
  57. local swap = function (w) return str2bei(lei2str(w)) end
  58.  
  59. -- An MD5 mplementation in Lua, requires bitlib (hacked to use LuaBit from above, ugh)
  60. -- 10/02/2001 jcw@equi4.com
  61.  
  62. local CONSTS = {
  63. 0xd76aa478, 0xe8c7b756, 0x242070db, 0xc1bdceee,
  64. 0xf57c0faf, 0x4787c62a, 0xa8304613, 0xfd469501,
  65. 0x698098d8, 0x8b44f7af, 0xffff5bb1, 0x895cd7be,
  66. 0x6b901122, 0xfd987193, 0xa679438e, 0x49b40821,
  67. 0xf61e2562, 0xc040b340, 0x265e5a51, 0xe9b6c7aa,
  68. 0xd62f105d, 0x02441453, 0xd8a1e681, 0xe7d3fbc8,
  69. 0x21e1cde6, 0xc33707d6, 0xf4d50d87, 0x455a14ed,
  70. 0xa9e3e905, 0xfcefa3f8, 0x676f02d9, 0x8d2a4c8a,
  71. 0xfffa3942, 0x8771f681, 0x6d9d6122, 0xfde5380c,
  72. 0xa4beea44, 0x4bdecfa9, 0xf6bb4b60, 0xbebfbc70,
  73. 0x289b7ec6, 0xeaa127fa, 0xd4ef3085, 0x04881d05,
  74. 0xd9d4d039, 0xe6db99e5, 0x1fa27cf8, 0xc4ac5665,
  75. 0xf4292244, 0x432aff97, 0xab9423a7, 0xfc93a039,
  76. 0x655b59c3, 0x8f0ccc92, 0xffeff47d, 0x85845dd1,
  77. 0x6fa87e4f, 0xfe2ce6e0, 0xa3014314, 0x4e0811a1,
  78. 0xf7537e82, 0xbd3af235, 0x2ad7d2bb, 0xeb86d391,
  79. 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476
  80. }
  81.  
  82. local f=function (x,y,z) return bit_or(bit_and(x,y),bit_and(-x-1,z)) end
  83. local g=function (x,y,z) return bit_or(bit_and(x,z),bit_and(y,-z-1)) end
  84. local h=function (x,y,z) return bit_xor(x,bit_xor(y,z)) end
  85. local i=function (x,y,z) return bit_xor(y,bit_or(x,-z-1)) end
  86. local z=function (ff,a,b,c,d,x,s,ac)
  87. a=bit_and(a+ff(b,c,d)+x+ac,0xFFFFFFFF)
  88. -- be *very* careful that left shift does not cause rounding!
  89. return bit_or(bit_lshift(bit_and(a,bit_rshift(0xFFFFFFFF,s)),s),bit_rshift(a,32-s))+b
  90. end
  91.  
  92. local function transform(A,B,C,D,X)
  93. local a,b,c,d=A,B,C,D
  94. local t=CONSTS
  95.  
  96. a=z(f,a,b,c,d,X[ 0], 7,t[ 1])
  97. d=z(f,d,a,b,c,X[ 1],12,t[ 2])
  98. c=z(f,c,d,a,b,X[ 2],17,t[ 3])
  99. b=z(f,b,c,d,a,X[ 3],22,t[ 4])
  100. a=z(f,a,b,c,d,X[ 4], 7,t[ 5])
  101. d=z(f,d,a,b,c,X[ 5],12,t[ 6])
  102. c=z(f,c,d,a,b,X[ 6],17,t[ 7])
  103. b=z(f,b,c,d,a,X[ 7],22,t[ 8])
  104. a=z(f,a,b,c,d,X[ 8], 7,t[ 9])
  105. d=z(f,d,a,b,c,X[ 9],12,t[10])
  106. c=z(f,c,d,a,b,X[10],17,t[11])
  107. b=z(f,b,c,d,a,X[11],22,t[12])
  108. a=z(f,a,b,c,d,X[12], 7,t[13])
  109. d=z(f,d,a,b,c,X[13],12,t[14])
  110. c=z(f,c,d,a,b,X[14],17,t[15])
  111. b=z(f,b,c,d,a,X[15],22,t[16])
  112.  
  113. a=z(g,a,b,c,d,X[ 1], 5,t[17])
  114. d=z(g,d,a,b,c,X[ 6], 9,t[18])
  115. c=z(g,c,d,a,b,X[11],14,t[19])
  116. b=z(g,b,c,d,a,X[ 0],20,t[20])
  117. a=z(g,a,b,c,d,X[ 5], 5,t[21])
  118. d=z(g,d,a,b,c,X[10], 9,t[22])
  119. c=z(g,c,d,a,b,X[15],14,t[23])
  120. b=z(g,b,c,d,a,X[ 4],20,t[24])
  121. a=z(g,a,b,c,d,X[ 9], 5,t[25])
  122. d=z(g,d,a,b,c,X[14], 9,t[26])
  123. c=z(g,c,d,a,b,X[ 3],14,t[27])
  124. b=z(g,b,c,d,a,X[ 8],20,t[28])
  125. a=z(g,a,b,c,d,X[13], 5,t[29])
  126. d=z(g,d,a,b,c,X[ 2], 9,t[30])
  127. c=z(g,c,d,a,b,X[ 7],14,t[31])
  128. b=z(g,b,c,d,a,X[12],20,t[32])
  129.  
  130. a=z(h,a,b,c,d,X[ 5], 4,t[33])
  131. d=z(h,d,a,b,c,X[ 8],11,t[34])
  132. c=z(h,c,d,a,b,X[11],16,t[35])
  133. b=z(h,b,c,d,a,X[14],23,t[36])
  134. a=z(h,a,b,c,d,X[ 1], 4,t[37])
  135. d=z(h,d,a,b,c,X[ 4],11,t[38])
  136. c=z(h,c,d,a,b,X[ 7],16,t[39])
  137. b=z(h,b,c,d,a,X[10],23,t[40])
  138. a=z(h,a,b,c,d,X[13], 4,t[41])
  139. d=z(h,d,a,b,c,X[ 0],11,t[42])
  140. c=z(h,c,d,a,b,X[ 3],16,t[43])
  141. b=z(h,b,c,d,a,X[ 6],23,t[44])
  142. a=z(h,a,b,c,d,X[ 9], 4,t[45])
  143. d=z(h,d,a,b,c,X[12],11,t[46])
  144. c=z(h,c,d,a,b,X[15],16,t[47])
  145. b=z(h,b,c,d,a,X[ 2],23,t[48])
  146.  
  147. a=z(i,a,b,c,d,X[ 0], 6,t[49])
  148. d=z(i,d,a,b,c,X[ 7],10,t[50])
  149. c=z(i,c,d,a,b,X[14],15,t[51])
  150. b=z(i,b,c,d,a,X[ 5],21,t[52])
  151. a=z(i,a,b,c,d,X[12], 6,t[53])
  152. d=z(i,d,a,b,c,X[ 3],10,t[54])
  153. c=z(i,c,d,a,b,X[10],15,t[55])
  154. b=z(i,b,c,d,a,X[ 1],21,t[56])
  155. a=z(i,a,b,c,d,X[ 8], 6,t[57])
  156. d=z(i,d,a,b,c,X[15],10,t[58])
  157. c=z(i,c,d,a,b,X[ 6],15,t[59])
  158. b=z(i,b,c,d,a,X[13],21,t[60])
  159. a=z(i,a,b,c,d,X[ 4], 6,t[61])
  160. d=z(i,d,a,b,c,X[11],10,t[62])
  161. c=z(i,c,d,a,b,X[ 2],15,t[63])
  162. b=z(i,b,c,d,a,X[ 9],21,t[64])
  163.  
  164. return bit_and(A+a,0xFFFFFFFF),bit_and(B+b,0xFFFFFFFF),
  165. bit_and(C+c,0xFFFFFFFF),bit_and(D+d,0xFFFFFFFF)
  166. end
  167.  
  168. ----------------------------------------------------------------
  169.  
  170. local function md5_update(self, s)
  171. self.pos = self.pos + #s
  172. s = self.buf .. s
  173. for ii = 1, #s - 63, 64 do
  174. local X = cut_le_str(sub(s,ii,ii+63),4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4)
  175. assert(#X == 16)
  176. X[0] = table.remove(X,1) -- zero based!
  177. self.a,self.b,self.c,self.d = transform(self.a,self.b,self.c,self.d,X)
  178. end
  179. self.buf = sub(s, math.floor(#s/64)*64 + 1, #s)
  180. return self
  181. end
  182.  
  183. local function md5_finish(self)
  184. local msgLen = self.pos
  185. local padLen = 56 - msgLen % 64
  186.  
  187. if msgLen % 64 > 56 then padLen = padLen + 64 end
  188.  
  189. if padLen == 0 then padLen = 64 end
  190.  
  191. local s = char(128) .. rep(char(0),padLen-1) .. lei2str(bit_and(8*msgLen, 0xFFFFFFFF)) .. lei2str(math.floor(msgLen/0x20000000))
  192. md5_update(self, s)
  193.  
  194. assert(self.pos % 64 == 0)
  195. return lei2str(self.a) .. lei2str(self.b) .. lei2str(self.c) .. lei2str(self.d)
  196. end
  197.  
  198. ----------------------------------------------------------------
  199.  
  200. function md5.new()
  201. return { a = CONSTS[65], b = CONSTS[66], c = CONSTS[67], d = CONSTS[68],
  202. pos = 0,
  203. buf = '',
  204. update = md5_update,
  205. finish = md5_finish }
  206. end
  207.  
  208. function md5.tohex(s)
  209. return format("%08x%08x%08x%08x", str2bei(sub(s, 1, 4)), str2bei(sub(s, 5, 8)), str2bei(sub(s, 9, 12)), str2bei(sub(s, 13, 16)))
  210. end
  211.  
  212. function md5.sum(s)
  213. return md5.new():update(s):finish()
  214. end
  215.  
  216. function md5.sumhexa(s)
  217. return md5.tohex(md5.sum(s))
  218. end
Add Comment
Please, Sign In to add comment