Think.class.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | ThinkPHP [ WE CAN DO IT JUST THINK IT ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2009 http://thinkphp.cn All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
  8. // +----------------------------------------------------------------------
  9. // | Author: liu21st <liu21st@gmail.com>
  10. // +----------------------------------------------------------------------
  11. namespace Think\Crypt\Driver;
  12. /**
  13. * Base64 加密实现类
  14. */
  15. class Think
  16. {
  17. /**
  18. * 加密字符串
  19. * @param string $str 字符串
  20. * @param string $key 加密key
  21. * @param integer $expire 有效期(秒)
  22. * @return string
  23. */
  24. public static function encrypt($data, $key, $expire = 0)
  25. {
  26. $expire = sprintf('%010d', $expire ? $expire + time() : 0);
  27. $key = md5($key);
  28. $data = base64_encode($expire . $data);
  29. $x = 0;
  30. $len = strlen($data);
  31. $l = strlen($key);
  32. $char = $str = '';
  33. for ($i = 0; $i < $len; $i++) {
  34. if ($x == $l) {
  35. $x = 0;
  36. }
  37. $char .= substr($key, $x, 1);
  38. $x++;
  39. }
  40. for ($i = 0; $i < $len; $i++) {
  41. $str .= chr(ord(substr($data, $i, 1)) + (ord(substr($char, $i, 1))) % 256);
  42. }
  43. return str_replace(array('+', '/', '='), array('-', '_', ''), base64_encode($str));
  44. }
  45. /**
  46. * 解密字符串
  47. * @param string $str 字符串
  48. * @param string $key 加密key
  49. * @return string
  50. */
  51. public static function decrypt($data, $key)
  52. {
  53. $key = md5($key);
  54. $data = str_replace(array('-', '_'), array('+', '/'), $data);
  55. $mod4 = strlen($data) % 4;
  56. if ($mod4) {
  57. $data .= substr('====', $mod4);
  58. }
  59. $data = base64_decode($data);
  60. $x = 0;
  61. $len = strlen($data);
  62. $l = strlen($key);
  63. $char = $str = '';
  64. for ($i = 0; $i < $len; $i++) {
  65. if ($x == $l) {
  66. $x = 0;
  67. }
  68. $char .= substr($key, $x, 1);
  69. $x++;
  70. }
  71. for ($i = 0; $i < $len; $i++) {
  72. if (ord(substr($data, $i, 1)) < ord(substr($char, $i, 1))) {
  73. $str .= chr((ord(substr($data, $i, 1)) + 256) - ord(substr($char, $i, 1)));
  74. } else {
  75. $str .= chr(ord(substr($data, $i, 1)) - ord(substr($char, $i, 1)));
  76. }
  77. }
  78. $data = base64_decode($str);
  79. $expire = substr($data, 0, 10);
  80. if ($expire > 0 && $expire < time()) {
  81. return '';
  82. }
  83. $data = substr($data, 10);
  84. return $data;
  85. }
  86. }