md5_sample.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. /*
  2. * Copyright (c) 2006-2019, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2019-03-22 MurphyZhao the first version
  9. */
  10. #include <rtthread.h>
  11. #include <tiny_md5.h>
  12. static const unsigned char md5_test_buf[7][81] =
  13. {
  14. { "" },
  15. { "a" },
  16. { "abc" },
  17. { "message digest" },
  18. { "abcdefghijklmnopqrstuvwxyz" },
  19. { "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789" },
  20. { "12345678901234567890123456789012345678901234567890123456789012"
  21. "345678901234567890" }
  22. };
  23. static const size_t md5_test_buflen[7] =
  24. {
  25. 0, 1, 3, 14, 26, 62, 80
  26. };
  27. static const unsigned char md5_test_sum[7][16] =
  28. {
  29. { 0xD4, 0x1D, 0x8C, 0xD9, 0x8F, 0x00, 0xB2, 0x04,
  30. 0xE9, 0x80, 0x09, 0x98, 0xEC, 0xF8, 0x42, 0x7E },
  31. { 0x0C, 0xC1, 0x75, 0xB9, 0xC0, 0xF1, 0xB6, 0xA8,
  32. 0x31, 0xC3, 0x99, 0xE2, 0x69, 0x77, 0x26, 0x61 },
  33. { 0x90, 0x01, 0x50, 0x98, 0x3C, 0xD2, 0x4F, 0xB0,
  34. 0xD6, 0x96, 0x3F, 0x7D, 0x28, 0xE1, 0x7F, 0x72 },
  35. { 0xF9, 0x6B, 0x69, 0x7D, 0x7C, 0xB7, 0x93, 0x8D,
  36. 0x52, 0x5A, 0x2F, 0x31, 0xAA, 0xF1, 0x61, 0xD0 },
  37. { 0xC3, 0xFC, 0xD3, 0xD7, 0x61, 0x92, 0xE4, 0x00,
  38. 0x7D, 0xFB, 0x49, 0x6C, 0xCA, 0x67, 0xE1, 0x3B },
  39. { 0xD1, 0x74, 0xAB, 0x98, 0xD2, 0x77, 0xD9, 0xF5,
  40. 0xA5, 0x61, 0x1C, 0x2C, 0x9F, 0x41, 0x9D, 0x9F },
  41. { 0x57, 0xED, 0xF4, 0xA2, 0x2B, 0xE3, 0xC9, 0x55,
  42. 0xAC, 0x49, 0xDA, 0x2E, 0x21, 0x07, 0xB6, 0x7A }
  43. };
  44. static rt_err_t test_tiny_md5(void)
  45. {
  46. int i, ret = 0;
  47. unsigned char md5sum[16];
  48. for (i = 0; i < 7; i++)
  49. {
  50. rt_kprintf(" MD5 test #%d: ", i + 1);
  51. tiny_md5(md5_test_buf[i], md5_test_buflen[i], md5sum);
  52. if (rt_memcmp(md5sum, md5_test_sum[i], 16) != 0)
  53. {
  54. ret = 1;
  55. goto fail;
  56. }
  57. rt_kprintf("passed\r\n");
  58. }
  59. rt_kprintf("\r\n");
  60. return (0);
  61. fail:
  62. rt_kprintf("failed\r\n");
  63. return (ret);
  64. }
  65. #ifdef FINSH_USING_MSH
  66. MSH_CMD_EXPORT_ALIAS(test_tiny_md5, tiny_md5_sample, type tiny_md5_sample cmd to run);
  67. #endif /* FINSH_USING_MSH */