testhash.dpr 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. program testhash;
  2. {$IFNDEF FPC}
  3. {$APPTYPE CONSOLE}
  4. {$ELSE}
  5. {$MODE DELPHI}
  6. {$ENDIF}
  7. uses
  8. IdGlobal,
  9. IdGlobalProtocols,
  10. IdHash,
  11. IdHashCRC,
  12. IdHashMessageDigest,
  13. IdHashSHA,
  14. {$IFNDEF CIL}
  15. IdSSLOpenSSLHeaders,
  16. {$ENDIF}
  17. SysUtils;
  18. function Test(var VTime : Cardinal; var VRes : String; AHash : TIdHash; const AVal, AExpected : String): Boolean;
  19. var LBegin, LEnd : Cardinal;
  20. begin
  21. LBegin := IdGlobal.Ticks;
  22. try
  23. VRes := AHash.HashStringAsHex(AVal)
  24. finally
  25. LEnd := IdGlobal.Ticks;
  26. VTime := IdGlobal.GetTickDiff(LBegin,Lend);
  27. VRes := LowerCase(VRes);
  28. end;
  29. if AExpected = '' then
  30. begin
  31. Result := True;
  32. end
  33. else
  34. begin
  35. Result := UpperCase(VRes) = UpperCase(AExpected);
  36. end;
  37. end;
  38. function DevideString(const A : String; const AAlign : Integer) : String;
  39. var i, j, lLen : Integer;
  40. begin
  41. Result := '';
  42. LLen := Length(a);
  43. for I := 1 to (Length(A) div AAlign) do
  44. begin
  45. Result := Result + ' ';
  46. for j := 0 to (AAlign - 1) do
  47. begin
  48. if (i+j) <= LLen then
  49. begin
  50. Result := Result + A[I+j];
  51. end;
  52. end;
  53. end;
  54. Result := Trim(Result);
  55. end;
  56. procedure DoTest(AHash: TIdHash; const ATestVal, AExpected: String;
  57. const ATimes: LongWord);
  58. var
  59. LRes : String;
  60. LVTime : Cardinal;
  61. LTestStr : String;
  62. i : Integer;
  63. begin
  64. if ATimes >1 then
  65. begin
  66. LTestStr := '';
  67. for i := 0 to ATimes - 1 do
  68. begin
  69. LTestStr := LTestStr + ATestVal;
  70. end;
  71. end
  72. else
  73. begin
  74. LTestStr := ATestVal;
  75. end;
  76. if ATimes >1 then
  77. begin
  78. //use FormatFloat to output numbers so it's printed with commas
  79. WriteLn('Test String: "'+ATestVal+'" (multiplied by ' +FormatFloat('#,###',ATimes) + ')');
  80. end
  81. else
  82. begin
  83. WriteLn('Test String: "'+ATestVal+'"');
  84. end;
  85. if Test(LVTime,LRes,AHash,LTestStr,AExpected) then
  86. begin
  87. WriteLn('Test result: Passed');
  88. WriteLn('Time: '+FormatFloat('#,##0',LVTime));
  89. end
  90. else
  91. begin
  92. WriteLn('Test result: !!!FAILED!!!');
  93. end;
  94. WriteLn('Result: '+DevideString(LRes,4));
  95. WriteLn('Expected: '+DevideString(AExpected,4));
  96. WriteLn('');
  97. end;
  98. procedure TestItCRC16(const ATestVal, AExpected:String; const ATimes : LongWord = 1);
  99. var LH : TIdHash;
  100. begin
  101. LH := TIdHashCRC16.Create;
  102. try
  103. DoTest(LH,ATestVal,AExpected,ATimes);
  104. finally
  105. FreeAndNil(LH);
  106. end;
  107. end;
  108. procedure TestItCRC32(const ATestVal, AExpected:String; const ATimes : LongWord = 1);
  109. var LH : TIdHash;
  110. begin
  111. LH := TIdHashCRC32.Create;
  112. try
  113. DoTest(LH,ATestVal,AExpected,ATimes);
  114. finally
  115. FreeAndNil(LH);
  116. end;
  117. end;
  118. procedure TestItMD2(const ATestVal, AExpected:String; const ATimes : LongWord = 1);
  119. var LH : TIdHash;
  120. begin
  121. LH := TIdHashMessageDigest2.Create;
  122. try
  123. DoTest(LH,ATestVal,AExpected,ATimes);
  124. finally
  125. FreeAndNil(LH);
  126. end;
  127. end;
  128. procedure TestItMD4(const ATestVal, AExpected:String; const ATimes : LongWord = 1);
  129. var LH : TIdHash;
  130. begin
  131. LH := TIdHashMessageDigest4.Create;
  132. try
  133. DoTest(LH,ATestVal,AExpected,ATimes);
  134. finally
  135. FreeAndNil(LH);
  136. end;
  137. end;
  138. procedure TestItMD5(const ATestVal, AExpected:String; const ATimes : LongWord = 1);
  139. var LH : TIdHash;
  140. begin
  141. LH := TIdHashMessageDigest5.Create;
  142. try
  143. DoTest(LH,ATestVal,AExpected,ATimes);
  144. finally
  145. FreeAndNil(LH);
  146. end;
  147. end;
  148. procedure TestItSHA1(const ATestVal, AExpected:String; const ATimes : LongWord = 1);
  149. var LH : TIdHash;
  150. begin
  151. LH := TIdHashSHA1.Create;
  152. try
  153. DoTest(LH,ATestVal,AExpected,ATimes);
  154. finally
  155. FreeAndNil(LH);
  156. end;
  157. end;
  158. begin
  159. try
  160. { TODO -oUser -cConsole Main : Insert code here }
  161. {$IFNDEF CIL}
  162. IdSSLOpenSSLHeaders.Load;
  163. {$ENDIF}
  164. WriteLn('===');
  165. WriteLn('CRC16 test cases - from http://users.physik.tu-muenchen.de/gammel/matpack/demos/Cryptography/MpCRC-demo.cpp - reflect_in+reflect_out');
  166. WriteLn('===');
  167. WriteLn('');
  168. TestItCRC16('','0000'); // reflect_in+reflect_out
  169. TestItCRC16('A',LowerCase('30C0')); // reflect_in+reflect_out
  170. TestItCRC16('123456789',LowerCase('BB3D')); // reflect_in+reflect_out
  171. WriteLn('===');
  172. WriteLn('CRC32 test cases - from http://users.physik.tu-muenchen.de/gammel/matpack/demos/Cryptography/MpCRC-demo.cpp - reflect_in+reflect_out');
  173. WriteLn('===');
  174. WriteLn('');
  175. TestItCRC32('','00000000'); // reflect_in+reflect_out
  176. TestItCRC32('A','D3D99E8B'); // reflect_in+reflect_out
  177. TestItCRC32('123456789','CBF43926');// reflect_in+reflect_out
  178. WriteLn('===');
  179. WriteLn('RFC 1319 - The MD2 Message-Digest Algorithm');
  180. WriteLn('===');
  181. WriteLn('');
  182. TestItMD2('','8350e5a3e24c153df2275c9f80692773');
  183. TestItMD2('a','32ec01ec4a6dac72c0ab96fb34c0b5d1');
  184. TestITMD2('abc','da853b0d3f88d99b30283a69e6ded6bb');
  185. TestItMD2('message digest','ab4f496bfb2a530b219ff33031fe06b0');
  186. TestItMD2('abcdefghijklmnopqrstuvwxyz','4e8ddff3650292ab5a4108c3aa47940b');
  187. TestItMD2('ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789','da33def2a42df13975352846c30338cd');
  188. TestItMD2('12345678901234567890123456789012345678901234567890123456789012345678901234567890','d5976f79d83d3a0dc9806c3c66f3efd8');
  189. WriteLn('===');
  190. WriteLn('RFC 1320 - The MD4 Message-Digest Algorithm');
  191. WriteLn('===');
  192. WriteLn('');
  193. TestItMD4('','31d6cfe0d16ae931b73c59d7e0c089c0');
  194. TestItMD4('a','bde52cb31de33e46245e05fbdbd6fb24');
  195. TestItMD4('abc','a448017aaf21d8525fc10ae87aa6729d');
  196. TestItMD4('message digest','d9130a8164549fe818874806e1c7014b');
  197. TestItMD4('abcdefghijklmnopqrstuvwxyz','d79e1c308aa5bbcdeea8ed63df412da9');
  198. TestItMD4('ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789','043f8582f241db351ce627e153e7f0e4');
  199. TestItMD4('12345678901234567890123456789012345678901234567890123456789012345678901234567890','e33b4ddc9c38f2199c3e7b164fcc0536');
  200. WriteLn('===');
  201. WriteLn('RFC 1321 - The MD5 Message-Digest Algorithm');
  202. WriteLn('===');
  203. WriteLn('');
  204. TestItMD5('','d41d8cd98f00b204e9800998ecf8427e');
  205. TestItMD5('a','0cc175b9c0f1b6a831c399e269772661');
  206. TestItMD5('abc','900150983cd24fb0d6963f7d28e17f72');
  207. TestItMD5('message digest','f96b697d7cb7938d525a2f31aaf161d0');
  208. TestItMD5('ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789','d174ab98d277d9f5a5611c2c9f419d9f');
  209. TestItMD5('12345678901234567890123456789012345678901234567890123456789012345678901234567890','57edf4a22be3c955ac49da2e2107b67a');
  210. WriteLn('');
  211. WriteLn('===');
  212. WriteLn('RFC 3174 - US Secure Hash Algorithm 1 (SHA1)');
  213. WriteLn('===');
  214. WriteLn('');
  215. TestItSHA1('abc',Lowercase('A9993E364706816ABA3E25717850C26C9CD0D89D'));
  216. TestItSHA1('abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq',Lowercase('84983E441C3BD26EBAAE4AA1F95129E5E54670F1'));
  217. TestItSHA1('a',Lowercase('34AA973CD4C4DAA4F61EEB2BDBAD27316534016F'),1000000);
  218. TestItSHA1('0123456701234567012345670123456701234567012345670123456701234567',LowerCase('DEA356A2CDDD90C7A7ECEDC5EBB563934F460452'),10);
  219. WriteLn('===');
  220. WriteLn('Speed hashing using abc"');
  221. WriteLn('===');
  222. WriteLn('MD2');
  223. TestItMD2('abc','',1000000);
  224. WriteLn('MD4');
  225. TestItMD4('abc','',1000000);
  226. WriteLn('MD5');
  227. TestItMD5('abc','',1000000);
  228. WriteLn('SHA1');
  229. TestItSHA1('abc','',1000000);
  230. except
  231. on E:Exception do
  232. Writeln(E.Classname, ': ', E.Message);
  233. end;
  234. ReadLn;
  235. end.