Login.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. <?php
  2. namespace app\home\controller;
  3. use think\facade\View;
  4. use think\facade\Lang;
  5. use think\facade\Db;
  6. /**
  7. *
  8. *
  9. * ----------------------------------------------------------------------------
  10. *
  11. * 控制器
  12. */
  13. class Login extends BaseMall
  14. {
  15. public function initialize()
  16. {
  17. parent::initialize();
  18. Lang::load(base_path() . 'home/lang/' . config('lang.default_lang') . '/login.lang.php');
  19. }
  20. /**
  21. * 用户登录
  22. * @return
  23. */
  24. public function login()
  25. {
  26. $member_model = model('member');
  27. $inajax = input('param.inajax');
  28. if (!request()->isPost()) {
  29. $ref_url = '';
  30. if (session('ref_url')) {
  31. $ref_url = session('ref_url');
  32. }
  33. View::assign('ref_url', $ref_url);
  34. //检查登录状态
  35. $member_model->checkloginMember();
  36. if ($inajax == 1) {
  37. return View::fetch($this->template_dir . 'login_inajax');
  38. } else {
  39. return View::fetch($this->template_dir . 'login');
  40. }
  41. } else {
  42. if (config('ds_config.captcha_status_login') == 1 && !captcha_check(input('post.captcha_normal'))) {
  43. ds_json_encode(10001, lang('image_verification_code_error'));
  44. }
  45. $data = array(
  46. 'member_name' => input('post.member_name'),
  47. 'member_password' => input('post.member_password'),
  48. );
  49. $login_validate = ds_validate('member');
  50. if (!$login_validate->scene('login')->check($data)) {
  51. ds_json_encode(10001, $login_validate->getError());
  52. }
  53. $map = array(
  54. 'member_name' => $data['member_name'],
  55. 'member_password' => md5($data['member_password']),
  56. );
  57. $member_info = $member_model->getMemberInfo($map);
  58. if (empty($member_info) && preg_match('/^0?(13|15|17|18|14)[0-9]{9}$/i', $data['member_name'])) {
  59. //根据会员名没找到时查手机号
  60. $map = array();
  61. $map['member_mobile'] = $data['member_name'];
  62. $map['member_mobilebind'] = 1;
  63. $map['member_password'] = md5($data['member_password']);
  64. $member_info = Db::name('member')->where($map)->find();
  65. }
  66. if (empty($member_info) && (strpos($data['member_name'], '@') > 0)) {
  67. //按邮箱和密码查询会员
  68. $map = array();
  69. $map['member_email'] = $data['member_name'];
  70. $map['member_password'] = md5($data['member_password']);
  71. $member_info = Db::name('member')->where($map)->find();
  72. }
  73. if ($member_info) {
  74. if (!$member_info['member_state']) {
  75. ds_json_encode(10001, lang('login_index_account_stop'));
  76. }
  77. //执行登录,赋值操作
  78. $member_model->createSession($member_info);
  79. //是否有卖家账户
  80. $seller_model = model('seller');
  81. $seller_info = $seller_model->getSellerInfo(array('member_id' => $member_info['member_id']));
  82. if ($seller_info) {
  83. // 更新卖家登陆时间
  84. $seller_model->editSeller(array('last_logintime' => TIMESTAMP), array('seller_id' => $seller_info['seller_id']));
  85. $sellergroup_model = model('sellergroup');
  86. $seller_group_info = $sellergroup_model->getSellergroupInfo(array('sellergroup_id' => $seller_info['sellergroup_id']));
  87. $store_model = model('store');
  88. $store_info = $store_model->getStoreInfoByID($seller_info['store_id']);
  89. $seller_model->createSellerSession($member_info, $store_info, $seller_info, is_array($seller_group_info) ? $seller_group_info : array());
  90. }
  91. ds_json_encode(10000, lang('login_index_login_success'), '', '', false);
  92. } else {
  93. ds_json_encode(10001, lang('login_index_login_fail'));
  94. }
  95. }
  96. }
  97. public function logout()
  98. {
  99. Cookie('cart_goods_num', null);
  100. Cookie('msgnewnum' . session('member_id'), null);
  101. session(null);
  102. $this->redirect('Index/index');
  103. }
  104. /**
  105. * 会员注册页面
  106. *
  107. * @param
  108. * @return
  109. */
  110. public function register()
  111. {
  112. if (!request()->isPost()) {
  113. $member_model = model('member');
  114. $member_model->checkloginMember();
  115. if (input('param.inviter_id')) {
  116. $inviter_id = intval(input('param.inviter_id'));
  117. cookie('inviter_id', $inviter_id);
  118. } else {
  119. $inviter_id = intval(cookie('inviter_id'));
  120. }
  121. $member = Db::name('member')->where('member_id', $inviter_id)->field('member_id,member_name')->find();
  122. View::assign('member', $member);
  123. return View::fetch($this->template_dir . 'register');
  124. } else {
  125. $check = request()->checkToken('__token__');
  126. if (false === $check) {
  127. ds_json_encode(10001, 'invalid token');
  128. }
  129. $register_type = input('post.register_type');
  130. if ((!config('ds_config.sms_register') || !$register_type) && config('ds_config.captcha_status_register') == 1 && !captcha_check(input('post.captcha_normal'))) {
  131. ds_json_encode(10001, lang('image_verification_code_error'));
  132. }
  133. $member_model = model('member');
  134. $member_model->checkloginMember();
  135. $password = input('post.member_password');
  136. $password_confirm = input('post.member_password_confirm');
  137. if ($password != $password_confirm) {
  138. ds_json_encode(10001, lang('login_passwords_not_match'));
  139. }
  140. $data = array(
  141. 'member_name' => trim(input('post.member_name')),
  142. 'member_password' => $password,
  143. 'member_password_confirm' => $password_confirm,
  144. );
  145. $res = word_filter($data['member_name']);
  146. if (!$res['code']) {
  147. ds_json_encode(10001, $res['msg']);
  148. }
  149. if ($res['data']['if_sensitive']) {
  150. ds_json_encode(10001, implode('、', $res['data']['sensitive_msg']));
  151. }
  152. if (input('param.inviter_id')) {
  153. $inviter_id = intval(input('param.inviter_id'));
  154. } else {
  155. $inviter_id = intval(cookie('inviter_id'));
  156. }
  157. cookie('inviter_id', null);
  158. $data['inviter_id'] = $inviter_id;
  159. //是否开启验证码
  160. if (config('ds_config.sms_register') == 1 && $register_type) {
  161. $sms_mobile = trim(input('sms_mobile'));
  162. $sms_captcha = trim(input('sms_captcha'));
  163. $logic_connect_api = model('connectapi', 'logic');
  164. $state_data = $logic_connect_api->smsRegister($sms_mobile, $sms_captcha, $password, 'pc', $inviter_id);
  165. if ($state_data['state'] == '1') {
  166. $member_info = $state_data['info'];
  167. }
  168. } else if (config('ds_config.member_normal_register') == 1) {
  169. $login_validate = ds_validate('member');
  170. if (!$login_validate->scene('register')->check($data)) {
  171. ds_json_encode(10001, $login_validate->getError());
  172. }
  173. $member_info = $member_model->register($data);
  174. } else {
  175. ds_json_encode(10001, lang('login_register_cancel'));
  176. }
  177. if (!isset($member_info['error'])) {
  178. $member_model->createSession($member_info, true);
  179. ds_json_encode(10000, lang('login_usersave_regist_success'), '', '', false);
  180. } else {
  181. ds_json_encode(10001, $member_info['error']);
  182. }
  183. }
  184. }
  185. /**
  186. * 会员名称检测
  187. *
  188. * @param
  189. * @return
  190. */
  191. public function check_member()
  192. {
  193. $member_name = input('param.member_name');
  194. $member_model = model('member');
  195. if (empty($member_name)) {
  196. echo 'false';
  197. exit;
  198. }
  199. $check_member_name = $member_model->getMemberInfo(array('member_name' => $member_name));
  200. if (is_array($check_member_name) && count($check_member_name) > 0) {
  201. echo 'false';
  202. exit;
  203. } else {
  204. echo 'true';
  205. exit;
  206. }
  207. }
  208. /**
  209. * 电子邮箱检测
  210. *
  211. * @param
  212. * @return
  213. */
  214. public function check_email()
  215. {
  216. $member_model = model('member');
  217. $check_member_email = $member_model->getMemberInfo(array('member_email' => input('param.email')));
  218. if (is_array($check_member_email) && count($check_member_email) > 0) {
  219. echo 'false';
  220. exit;
  221. } else {
  222. echo 'true';
  223. exit;
  224. }
  225. }
  226. /**
  227. * 忘记密码页面
  228. */
  229. public function forget_password()
  230. {
  231. View::assign('html_title', config('ds_config.site_name') . ' - ' . lang('login_index_find_password'));
  232. return View::fetch($this->template_dir . 'find_password');
  233. }
  234. /**
  235. * 邮箱绑定验证
  236. */
  237. public function bind_email()
  238. {
  239. $member_model = model('member');
  240. $uid = @base64_decode(input('param.uid'));
  241. $uid = ds_decrypt($uid, '');
  242. list($member_id, $member_email) = explode(' ', $uid);
  243. if (!is_numeric($member_id)) {
  244. $this->error(lang('validation_fails'), HOME_SITE_URL);
  245. }
  246. $member_info = $member_model->getMemberInfo(array('member_id' => $member_id), 'member_email');
  247. if ($member_info['member_email'] != $member_email) {
  248. $this->error(lang('validation_fails'), HOME_SITE_URL);
  249. }
  250. $hash = array_keys($_GET);
  251. $verify_code_model = model('verify_code');
  252. $verify_code_info = $verify_code_model->getVerifyCodeInfo(array(array('verify_code_type', '=', 5), array('verify_code_user_type', '=', 1), array('verify_code_user_id', '=', $member_id), array('verify_code_add_time', '>', TIMESTAMP - VERIFY_CODE_INVALIDE_MINUTE * 60)));
  253. if (!$verify_code_info || md5($verify_code_info['verify_code']) != $_GET[$hash['1']]) {
  254. $this->error(lang('validation_fails'), HOME_SITE_URL);
  255. }
  256. $update = $member_model->editMember(array('member_id' => $member_id), array('member_emailbind' => 1), $member_id);
  257. if (!$update) {
  258. $this->error(lang('system_error'), HOME_SITE_URL);
  259. }
  260. $this->success(lang('successful_email_setting'), (string)url('Membersecurity/index'));
  261. }
  262. }