123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268 |
- <?php
- namespace app\home\controller;
- use think\facade\View;
- use think\facade\Lang;
- use think\facade\Db;
- /**
- * ============================================================================
- * DSMall多用户商城
- * ============================================================================
- * 版权所有 2014-2028 长沙德尚网络科技有限公司,并保留所有权利。
- * 网站地址: http://www.csdeshang.com
- * ----------------------------------------------------------------------------
- * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
- * 不允许对程序代码以任何形式任何目的的再发布。
- * ============================================================================
- * 控制器
- */
- class Login extends BaseMall {
- public function initialize() {
- parent::initialize();
- Lang::load(base_path() . 'home/lang/' . config('lang.default_lang') . '/login.lang.php');
- }
- /**
- * 用户登录
- * @return
- */
- public function login() {
- $member_model = model('member');
- $inajax = input('param.inajax');
-
- if (!request()->isPost()) {
- //检查登录状态
- $member_model->checkloginMember();
- if ($inajax == 1) {
- return View::fetch($this->template_dir . 'login_inajax');
- } else {
- return View::fetch($this->template_dir . 'login');
- }
- } else {
- if (config('ds_config.captcha_status_login') == 1 && !captcha_check(input('post.captcha_normal'))) {
- ds_json_encode(10001, lang('image_verification_code_error'));
- }
- $data = array(
- 'member_name' => input('post.member_name'),
- 'member_password' => input('post.member_password'),
- );
- $login_validate = ds_validate('member');
- if (!$login_validate->scene('login')->check($data)) {
- ds_json_encode(10001, $login_validate->getError());
- }
- $map = array(
- 'member_name' => $data['member_name'],
- 'member_password' => md5($data['member_password']),
- );
- $member_info = $member_model->getMemberInfo($map);
- if (empty($member_info) && preg_match('/^0?(13|15|17|18|14)[0-9]{9}$/i', $data['member_name'])) {
- //根据会员名没找到时查手机号
- $map = array();
- $map['member_mobile'] = $data['member_name'];
- $map['member_mobilebind'] = 1;
- $map['member_password'] = md5($data['member_password']);
- $member_info = Db::name('member')->where($map)->find();
- }
- if (empty($member_info) && (strpos($data['member_name'], '@') > 0)) {
- //按邮箱和密码查询会员
- $map = array();
- $map['member_email'] = $data['member_name'];
- $map['member_password'] = md5($data['member_password']);
- $member_info = Db::name('member')->where($map)->find();
- }
- if ($member_info) {
- if (!$member_info['member_state']) {
- ds_json_encode(10001, lang('login_index_account_stop'));
- }
- //执行登录,赋值操作
- $member_model->createSession($member_info);
- //是否有卖家账户
- $seller_model = model('seller');
- $seller_info = $seller_model->getSellerInfo(array('member_id' => $member_info['member_id']));
- if($seller_info){
- // 更新卖家登陆时间
- $seller_model->editSeller(array('last_logintime' => TIMESTAMP), array('seller_id' => $seller_info['seller_id']));
- $sellergroup_model = model('sellergroup');
- $seller_group_info = $sellergroup_model->getSellergroupInfo(array('sellergroup_id' => $seller_info['sellergroup_id']));
- $store_model = model('store');
- $store_info = $store_model->getStoreInfoByID($seller_info['store_id']);
- $seller_model->createSellerSession($member_info,$store_info,$seller_info, is_array($seller_group_info)?$seller_group_info:array());
- }
- ds_json_encode(10000, lang('login_index_login_success'), '','',false);
- } else {
- ds_json_encode(10001, lang('login_index_login_fail'));
- }
- }
- }
- public function logout() {
- Cookie('cart_goods_num',null);
- Cookie('msgnewnum'.session('member_id'),null);
- session(null);
- $this->redirect('Index/index');
- }
- /**
- * 会员注册页面
- *
- * @param
- * @return
- */
- /*public function register() {
- if (!request()->isPost()) {
- $member_model = model('member');
- $member_model->checkloginMember();
- if(input('param.inviter_id')){
- $inviter_id = intval(input('param.inviter_id'));
- cookie('inviter_id',$inviter_id);
- }else{
- $inviter_id = intval(cookie('inviter_id'));
- }
-
- $member = Db::name('member')->where('member_id', $inviter_id)->field('member_id,member_name')->find();
- View::assign('member', $member);
- return View::fetch($this->template_dir . 'register');
- } else {
- $register_type = input('post.register_type');
- if ((!config('ds_config.sms_register') || !$register_type) && config('ds_config.captcha_status_register') == 1 && !captcha_check(input('post.captcha_normal'))) {
- ds_json_encode(10001,lang('image_verification_code_error'));
- }
- $member_model = model('member');
- $member_model->checkloginMember();
- $password = input('post.member_password');
- $password_confirm = input('post.member_password_confirm');
- if ($password != $password_confirm) {
- ds_json_encode(10001,lang('login_passwords_not_match'));
- }
- $data = array(
- 'member_name' => trim(input('post.member_name')),
- 'member_password' => $password,
- 'member_password_confirm' => $password_confirm,
- );
- $res=word_filter($data['member_name']);
- if(!$res['code']){
- ds_json_encode(10001,$res['msg']);
- }
- if($res['data']['if_sensitive']){
- ds_json_encode(10001,implode('、',$res['data']['sensitive_msg']));
- }
- if(input('param.inviter_id')){
- $inviter_id = intval(input('param.inviter_id'));
- }else{
- $inviter_id = intval(cookie('inviter_id'));
- }
- cookie('inviter_id',null);
- $data['inviter_id'] = $inviter_id;
- //是否开启验证码
- if (config('ds_config.sms_register') && $register_type) {
- $sms_mobile = trim(input('sms_mobile'));
- $sms_captcha = trim(input('sms_captcha'));
- $logic_connect_api = model('connectapi','logic');
- $state_data = $logic_connect_api->smsRegister($sms_mobile, $sms_captcha, $password, 'pc',$inviter_id);
- if($state_data['state']=='1'){
- $member_info = $state_data['info'];
- }
- }else{
- $login_validate = ds_validate('member');
- if (!$login_validate->scene('register')->check($data)) {
- ds_json_encode(10001,$login_validate->getError());
- }
- $member_info = $member_model->register($data);
- }
-
- if (!isset($member_info['error'])) {
- $member_model->createSession($member_info, true);
- ds_json_encode(10000,lang('login_usersave_regist_success'), '','',false);
- } else {
- ds_json_encode(10001,$member_info['error']);
- }
- }
- }*/
- /**
- * 会员名称检测
- *
- * @param
- * @return
- */
- public function check_member() {
- $member_name = input('param.member_name');
- $member_model = model('member');
- if (empty($member_name)) {
- echo 'false';exit;
- }
- $check_member_name = $member_model->getMemberInfo(array('member_name' => $member_name));
- if (is_array($check_member_name) && count($check_member_name) > 0) {
- echo 'false';exit;
- } else {
- echo 'true';exit;
- }
- }
- /**
- * 电子邮箱检测
- *
- * @param
- * @return
- */
- public function check_email() {
- $member_model = model('member');
- $check_member_email = $member_model->getMemberInfo(array('member_email' => input('param.email')));
- if (is_array($check_member_email) && count($check_member_email) > 0) {
- echo 'false';exit;
- } else {
- echo 'true';exit;
- }
- }
- /**
- * 忘记密码页面
- */
- public function forget_password() {
- View::assign('html_title', config('ds_config.site_name') . ' - ' . lang('login_index_find_password'));
- return View::fetch($this->template_dir . 'find_password');
- }
- /**
- * 邮箱绑定验证
- */
- public function bind_email() {
- $member_model = model('member');
- $uid = @base64_decode(input('param.uid'));
- $uid = ds_decrypt($uid, '');
- list($member_id, $member_email) = explode(' ', $uid);
- if (!is_numeric($member_id)) {
- $this->error(lang('validation_fails'), HOME_SITE_URL);
- }
- $member_info = $member_model->getMemberInfo(array('member_id' => $member_id), 'member_email');
- if ($member_info['member_email'] != $member_email) {
- $this->error(lang('validation_fails'), HOME_SITE_URL);
- }
- $hash = array_keys($_GET);
- $verify_code_model = model('verify_code');
- $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)));
- if (!$verify_code_info || md5($verify_code_info['verify_code']) != $_GET[$hash['1']]) {
- $this->error(lang('validation_fails'), HOME_SITE_URL);
- }
- $update = $member_model->editMember(array('member_id' => $member_id), array('member_emailbind' => 1),$member_id);
- if (!$update) {
- $this->error(lang('system_error'), HOME_SITE_URL);
- }
- $this->success(lang('successful_email_setting'), (string)url('Membersecurity/index'));
- }
- }
- ?>
|