SM4Test.php 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. <?php
  2. /**
  3. * Define test.php
  4. *
  5. * PHP version 8
  6. *
  7. * @author Endy <endy@evit.net.cn>
  8. * @link https://github.com/Endy-c
  9. * @license MIT License
  10. *
  11. * Copyright (c) 2022 Endy
  12. *
  13. * Permission is hereby granted, free of charge, to any person obtaining a copy
  14. * of this software and associated documentation files (the "Software"), to deal
  15. * in the Software without restriction, including without limitation the rights
  16. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  17. * copies of the Software, and to permit persons to whom the Software is
  18. * furnished to do so, subject to the following conditions:
  19. *
  20. * The above copyright notice and this permission notice shall be included in all
  21. * copies or substantial portions of the Software.
  22. *
  23. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  24. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  25. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  26. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  27. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  28. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  29. * SOFTWARE.
  30. */
  31. require_once __DIR__ . "/../../../../vendor/autoload.php";
  32. use Evit\PhpGmCrypto\Encryption\EvitSM4Encryption;
  33. $config = [
  34. // mode string 'cbc' or 'ecb' is supported, default is 'cbc'.
  35. 'mode' => 'cbc',
  36. // password, will be processed by substr(md5($key), 0, 16)
  37. 'key' => '{replace-your-key-here}',
  38. // the iv used by 'cbc' mode, will be will be processed by substr(md5($iv), 0, 16)
  39. 'iv' => '{replace-your-iv-here}'
  40. ];
  41. $sm4 = new EvitSM4Encryption();
  42. // Encrypt
  43. $start = microtime(true);
  44. $encypted = $sm4->sm4encrypt('{replace-your-plaintext-here}');
  45. $end = microtime(true);
  46. var_dump('Encrypt time elapsed: ' . number_format($end - $start, 8) . ' s');
  47. var_dump("Cipher text: {$encypted}");
  48. // Decrypt
  49. $decStart = microtime(true);
  50. $decrypted = $sm4->sm4decrypt($encypted);
  51. $end = microtime(true);
  52. var_dump('Decrypt time elapsed: ' . number_format($end - $decStart, 8) . ' s');
  53. var_dump("Plain text: {$decrypted}");
  54. // Determine whether openssl library is used
  55. $algorithm = $sm4->isOpenssl() ? 'openssl' : 'php-gm-crypto';
  56. var_dump("Algrithm: {$algorithm}");
  57. var_dump('Total time elapsed: ' . number_format($end - $start, 8) . ' s');