Base.php 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  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. //$text = '您好,您的验证码为' . $code->mcode . ',十分钟之内有效。';
  74. $text = str_replace('{code}', $code->mcode, Dever::config('base', 'project')->mobileCode['msg']);
  75. # 启动发送
  76. $this->send($mobile, $text, $id);
  77. $this->save->add(self::MCODE, $mobile . '_' . $code->mcode, 600);
  78. return $code->mcode;
  79. }
  80. private function send($mobile, $content, $id)
  81. {
  82. $url = Dever::config('base', 'project')->mobileCode['url'];
  83. if (!$url) {
  84. return;
  85. }
  86. if (Dever::config('base', 'project')->mobileCode['signType'] == 1) {
  87. $content = Dever::config('base', 'project')->mobileCode['sign'] . $content;
  88. } else {
  89. $content .= Dever::config('base', 'project')->mobileCode['sign'];
  90. }
  91. $param['phone'] = $mobile;
  92. $param['message'] = $content;
  93. $param['seqid'] = $id + 1000;
  94. $param['smspriority'] = 1;
  95. $url .= http_build_query($param);
  96. Dever::curl($url);
  97. }
  98. protected function refer($state = false)
  99. {
  100. $refer = Dever::input('refer');
  101. $project = 'main';
  102. if ($refer) {
  103. $refer = Encrypt::decode($refer);
  104. /*
  105. $url = parse_url(Encrypt::decode($refer));
  106. $url['path'] = preg_replace('/^\//', '', $url['path']);
  107. if (!isset($url['query'])) {
  108. $url['query'] = '';
  109. }
  110. if (Uri::$type == '?') {
  111. $refer = Dever::url(str_replace($url['path'] . Uri::$type, '', $url['query']), $project);
  112. } else {
  113. $refer = Dever::url($url['path'] . '?' . $url['query'], $project);
  114. }
  115. */
  116. } else {
  117. $refer = Dever::url('home', $project);
  118. }
  119. $param = Dever::input('param');
  120. if ($param) {
  121. $refer .= '&' . $param;
  122. }
  123. if ($state) {
  124. return $refer;
  125. }
  126. Dever::out($refer);
  127. }
  128. protected function save($user)
  129. {
  130. if (is_numeric($user)) {
  131. $user = Dever::load('passport/user-one', $user);
  132. }
  133. if ($user && is_array($user)) {
  134. if (Dever::mobile()) {
  135. $time = 30;
  136. } else {
  137. $time = 7;
  138. }
  139. $this->save->add(self::NAME, $user, 3600 * 24 * $time);
  140. $user['signature'] = Dever::login($user['id']);
  141. if (Dever::config('base', 'project')->regAction) {
  142. Dever::load(Dever::config('base', 'project')->regAction, $user);
  143. }
  144. return $user;
  145. }
  146. }
  147. public function createRefer()
  148. {
  149. return 'refer=' . Encrypt::encode(Dever::url(false, 'main'));
  150. }
  151. protected function saveAvatar($value)
  152. {
  153. $value = Dever::pic($value);
  154. $base = Dever::data();
  155. $date = explode('-', date("Y-m-d"));
  156. if (is_array($value)) {
  157. $user = $value[1];
  158. $value = $value[0];
  159. if (is_array($value)) {
  160. $name = md5($value['tmp_name'] . rand(0, 100) . microtime());
  161. $path = 'avatar/' . $date[0] . '/' . $date[1] . '/' . $date[2] . '/';
  162. $ext = '.jpg';
  163. $temp = Dever::path($base, $path . $name . $ext);
  164. move_uploaded_file($value['tmp_name'], $temp);
  165. $value = $temp;
  166. }
  167. }
  168. //$result = Dever::$global['host']['img'] . 'chead.jpg';
  169. if ($value) {
  170. # 裁图
  171. $handle = new Img();
  172. $size = '200_200_2';
  173. $user = isset($user) && $user ? $user : $this->init();
  174. if ($user && isset($user['id']) && $user['id']) {
  175. $name = md5($user['id']);
  176. } else {
  177. $name = md5($value . rand(0, 100) . microtime());
  178. }
  179. $path = 'avatar/' . $date[0] . '/' . $date[1] . '/' . $date[2] . '/';
  180. $ext = '.jpg';
  181. $file = Dever::path($base, $path . $name . $ext);
  182. $temp = $file . '.temp.jpg';
  183. //$value = Dever::curl($value);
  184. //file_put_contents($temp, file_get_contents($value));
  185. $file = $handle->thumb($value, $size, true, $file);
  186. if ($file) {
  187. $result = str_replace('/upload/', '/', Dever::config('host')->uploadRes . $path . $name . $ext);
  188. } else {
  189. $result = $value;
  190. }
  191. }
  192. return $result;
  193. }
  194. }