Base.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. <?php
  2. namespace Passport\Src\Lib;
  3. use Dever;
  4. use Upload\Src\Lib\Img;
  5. use Dever\Routing\Uri;
  6. use Dever\Session\Oper as Save;
  7. use Dever\String\Encrypt;
  8. class Base
  9. {
  10. const NAME = 'dever';
  11. const CODE = 'dever_code';
  12. const MCODE = 'dever_mcode';
  13. protected $save;
  14. public function __construct()
  15. {
  16. $this->save = new Save(false, 'cookie');
  17. }
  18. public function getToken($request = array())
  19. {
  20. return http_build_query(Dever::token($request));
  21. }
  22. public function getUrl($method, $request = array())
  23. {
  24. return Dever::proxy($method, $this->getToken($request));
  25. }
  26. protected function info()
  27. {
  28. $data = $this->save->get(self::NAME);
  29. return $data;
  30. }
  31. protected function code($code = false)
  32. {
  33. if ($code) {
  34. $save = $this->save->get(self::CODE);
  35. return $code == $save;
  36. }
  37. $code = new Code();
  38. $code->create();
  39. $this->save->add(self::CODE, $code->code, 600);
  40. }
  41. protected function mcode($mobile, $code = false)
  42. {
  43. if ($code) {
  44. $save = $this->save->get(self::MCODE);
  45. return $mobile . '_' . $code == $save;
  46. }
  47. $day = date('Ymd', time());
  48. # 检测当前手机号最新一次发送时间,不允许一分钟之内发送
  49. $param['option_day'] = $day;
  50. $param['option_mobile'] = $mobile;
  51. # 检测当前手机号今天已经发送多少验证码了
  52. $info = Dever::load('passport/code-total', $param);
  53. if ($info >= 1) {
  54. $check = Dever::load('passport/code-one', $param);
  55. if ($check) {
  56. if (time() - $check['cdate'] < Dever::config('base', 'project')->mobileCode['time']) {
  57. Dever::alert('请不要在一分钟之内申请多次验证码,请您稍后再试');
  58. }
  59. }
  60. }
  61. $total = Dever::config('base', 'project')->mobileCode['total'];
  62. if ($info >= $total) {
  63. Dever::alert('很抱歉,您已经申请获取验证码超过' . $total . '次,今天您已经无法获取验证码了,请您明天再来');
  64. }
  65. $code = new Code();
  66. $code->createM();
  67. # 记录当前的验证码
  68. $insert['add_mobile'] = $mobile;
  69. $insert['add_day'] = $day;
  70. $insert['add_code'] = $code->mcode;
  71. $id = Dever::load('passport/code-insert', $insert);
  72. # 启动发送
  73. $this->send($mobile, $insert['add_code'], $id);
  74. $this->save->add(self::MCODE, $mobile . '_' . $code->mcode, Dever::config('base', 'project')->mobileCode['timeout']);
  75. return $code->mcode;
  76. }
  77. protected function send($mobile, $code, $id = false)
  78. {
  79. $url = Dever::config('base', 'project')->mobileCode['url'];
  80. if (!$url) {
  81. return;
  82. }
  83. $content = Dever::config('base', 'project')->mobileCode['body'];
  84. $content = $this->replace($content, $mobile, $code);
  85. parse_str($content, $param);
  86. $type = Dever::config('base', 'project')->mobileCode['method'];
  87. $json = Dever::config('base', 'project')->mobileCode['json'];
  88. $header = Dever::config('base', 'project')->mobileCode['header'];
  89. return Dever::curl($url, $param, $type, $json, $header);
  90. }
  91. private function replace($content, $mobile = '', $code = '')
  92. {
  93. $skin = Dever::config('base', 'project')->mobileCode['skin'];
  94. $skin_key = Dever::input('skin', 1);
  95. if (isset($skin[$skin_key])) {
  96. $skin = $skin[$skin_key];
  97. } else {
  98. $skin = array_shift($skin);
  99. }
  100. $config = array('{code}', '{mobile}', '{sign}', '{skin}', '{param}');
  101. $replace = array($code, $mobile, Dever::config('base', 'project')->mobileCode['sign'], $skin);
  102. return str_replace($config, $replace, $content);
  103. }
  104. protected function refer($state = false)
  105. {
  106. $refer = Dever::input('refer');
  107. $project = 'main';
  108. if ($refer) {
  109. $refer = Encrypt::decode($refer);
  110. /*
  111. $url = parse_url(Encrypt::decode($refer));
  112. $url['path'] = preg_replace('/^\//', '', $url['path']);
  113. if (!isset($url['query'])) {
  114. $url['query'] = '';
  115. }
  116. if (Uri::$type == '?') {
  117. $refer = Dever::url(str_replace($url['path'] . Uri::$type, '', $url['query']), $project);
  118. } else {
  119. $refer = Dever::url($url['path'] . '?' . $url['query'], $project);
  120. }
  121. */
  122. } else {
  123. $refer = Dever::url('home', $project);
  124. }
  125. $param = Dever::input('param');
  126. if ($param) {
  127. $refer .= '&' . $param;
  128. }
  129. if ($state) {
  130. return $refer;
  131. }
  132. Dever::out($refer);
  133. }
  134. protected function save($user)
  135. {
  136. if (is_numeric($user)) {
  137. $user = Dever::load('passport/user-one', $user);
  138. }
  139. if ($user && is_array($user)) {
  140. if (Dever::mobile()) {
  141. $time = 30;
  142. } else {
  143. $time = 7;
  144. }
  145. $this->save->add(self::NAME, $user, 3600 * 24 * $time);
  146. $user['signature'] = Dever::login($user['id']);
  147. if (Dever::config('base', 'project')->regAction) {
  148. Dever::load(Dever::config('base', 'project')->regAction, $user);
  149. }
  150. return $user;
  151. }
  152. }
  153. public function createRefer()
  154. {
  155. return 'refer=' . Encrypt::encode(Dever::url(false, 'main'));
  156. }
  157. protected function saveAvatar($value)
  158. {
  159. $value = Dever::pic($value);
  160. $base = Dever::data();
  161. $date = explode('-', date("Y-m-d"));
  162. if (is_array($value)) {
  163. $user = $value[1];
  164. $value = $value[0];
  165. if (is_array($value)) {
  166. $name = md5($value['tmp_name'] . rand(0, 100) . microtime());
  167. $path = 'avatar/' . $date[0] . '/' . $date[1] . '/' . $date[2] . '/';
  168. $ext = '.jpg';
  169. $temp = Dever::path($base, $path . $name . $ext);
  170. move_uploaded_file($value['tmp_name'], $temp);
  171. $value = $temp;
  172. }
  173. }
  174. //$result = Dever::$global['host']['img'] . 'chead.jpg';
  175. if ($value) {
  176. # 裁图
  177. $handle = new Img();
  178. $size = '200_200_2';
  179. $user = isset($user) && $user ? $user : $this->init();
  180. if ($user && isset($user['id']) && $user['id']) {
  181. $name = md5($user['id']);
  182. } else {
  183. $name = md5($value . rand(0, 100) . microtime());
  184. }
  185. $path = 'avatar/' . $date[0] . '/' . $date[1] . '/' . $date[2] . '/';
  186. $ext = '.jpg';
  187. $file = Dever::path($base, $path . $name . $ext);
  188. $temp = $file . '.temp.jpg';
  189. //$value = Dever::curl($value);
  190. //file_put_contents($temp, file_get_contents($value));
  191. $file = $handle->thumb($value, $size, true, $file);
  192. if ($file) {
  193. $result = str_replace('/upload/', '/', Dever::config('host')->uploadRes . $path . $name . $ext);
  194. } else {
  195. $result = $value;
  196. }
  197. }
  198. return $result;
  199. }
  200. }