Encrypt.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <?php
  2. /**
  3. * 可逆加密解密类
  4. *
  5. * @author Coeus <r.anerg@gmail.com>
  6. */
  7. namespace huolib\tool;
  8. class Encrypt {
  9. /**
  10. * 获取加密key
  11. * @return mixed
  12. */
  13. private static function getKey() {
  14. return config('database.authcode');
  15. }
  16. /**
  17. * 加密字符串
  18. *
  19. * @param mixed $data
  20. * @param integer $expire 有效期(秒)
  21. * @param string $key 加密key
  22. *
  23. * @return string
  24. */
  25. public static function encrypt($data, $expire = 0, $key = '') {
  26. if (is_array($data)) {
  27. $data = json_encode($data, JSON_NUMERIC_CHECK | JSON_UNESCAPED_UNICODE);
  28. }
  29. $expire = sprintf('%010d', $expire ? $expire + time() : 0);
  30. if (!$key) {
  31. $key = self::getKey();
  32. }
  33. $key = md5($key);
  34. $data = base64_encode($expire.$data);
  35. $x = 0;
  36. $len = strlen($data);
  37. $l = strlen($key);
  38. $char = $str = '';
  39. for ($i = 0; $i < $len; $i++) {
  40. if ($x == $l) {
  41. $x = 0;
  42. }
  43. $char .= substr($key, $x, 1);
  44. $x++;
  45. }
  46. for ($i = 0; $i < $len; $i++) {
  47. $str .= chr(ord(substr($data, $i, 1)) + (ord(substr($char, $i, 1))) % 256);
  48. }
  49. return str_replace(array('+', '/', '='), array('-', '_', ''), base64_encode($str));
  50. }
  51. /**
  52. * 解密字符串
  53. *
  54. * @param mixed $data 数据
  55. * @param string $key 加密key
  56. *
  57. * @return string
  58. */
  59. public static function decrypt($data, $key = '') {
  60. if (!$data) {
  61. return '';
  62. }
  63. if (!$key) {
  64. $key = self::getKey();
  65. }
  66. $key = md5($key);
  67. $data = str_replace(array('-', '_'), array('+', '/'), $data);
  68. $mod4 = strlen($data) % 4;
  69. if ($mod4) {
  70. $data .= substr('====', $mod4);
  71. }
  72. $data = base64_decode($data);
  73. $x = 0;
  74. $len = strlen($data);
  75. $l = strlen($key);
  76. $char = $str = '';
  77. for ($i = 0; $i < $len; $i++) {
  78. if ($x == $l) {
  79. $x = 0;
  80. }
  81. $char .= substr($key, $x, 1);
  82. $x++;
  83. }
  84. for ($i = 0; $i < $len; $i++) {
  85. if (ord(substr($data, $i, 1)) < ord(substr($char, $i, 1))) {
  86. $str .= chr((ord(substr($data, $i, 1)) + 256) - ord(substr($char, $i, 1)));
  87. } else {
  88. $str .= chr(ord(substr($data, $i, 1)) - ord(substr($char, $i, 1)));
  89. }
  90. }
  91. $data = base64_decode($str);
  92. $expire = substr($data, 0, 10);
  93. if ($expire > 0 && $expire < time()) {
  94. return '';
  95. }
  96. $data = substr($data, 10);
  97. $json = json_decode($data, true);
  98. return json_last_error() === JSON_ERROR_NONE ? $json : $data;
  99. }
  100. }