// +---------------------------------------------------------------------- // | 官方网站: https://thinkadmin.top // +---------------------------------------------------------------------- // | 开源协议 ( https://mit-license.org ) // | 免费声明 ( https://thinkadmin.top/disclaimer ) // +---------------------------------------------------------------------- // | gitee 代码仓库:https://gitee.com/zoujingli/think-plugs-admin // +---------------------------------------------------------------------- namespace app\admin\controller; use think\admin\Controller; use think\admin\extend\CodeExtend; use think\admin\model\SystemUser; use think\admin\service\AdminService; use think\admin\service\CaptchaService; use think\admin\service\RuntimeService; use think\admin\service\SystemService; /** * 用户登录管理 * Class Login * @package app\admin\controller */ class Login extends Controller { /** * 后台登录入口 * @return void * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\DbException * @throws \think\db\exception\ModelNotFoundException */ public function index() { if ($this->app->request->isGet()) { if (AdminService::isLogin()) { $this->redirect(sysuri('admin/index/index')); } else { // 当前运行模式 $this->developMode = RuntimeService::check(); // 后台背景处理 $images = str2arr(sysconf('login_image') ?: '', '|'); if (empty($images)) $images = [ SystemService::uri('/static/theme/img/login/bg1.jpg'), SystemService::uri('/static/theme/img/login/bg2.jpg'), ]; $this->loginStyle = sprintf('style="background-image:url(%s)" data-bg-transition="%s"', $images[0], join(',', $images)); // 登录验证令牌 $this->captchaType = 'LoginCaptcha'; $this->captchaToken = CodeExtend::uniqidDate(18); if (!$this->app->session->get('LoginInputSessionError')) { $this->app->session->set($this->captchaType, $this->captchaToken); } // 更新后台域名 if ($this->request->domain(true) !== sysconf('base.site_host')) { sysconf('base.site_host', $this->request->domain(true)); } // 加载登录模板 $this->title = '系统登录'; $this->fetch(); } } else { $data = $this->_vali([ 'username.require' => '登录账号不能为空!', 'username.min:4' => '账号不能少于4位字符!', 'password.require' => '登录密码不能为空!', 'password.min:4' => '密码不能少于4位字符!', 'verify.require' => '图形验证码不能为空!', 'uniqid.require' => '图形验证标识不能为空!', ]); if (!CaptchaService::instance()->check($data['verify'], $data['uniqid'])) { $this->error('图形验证码验证失败,请重新输入!'); } /*! 用户信息验证 */ $map = ['username' => $data['username'], 'is_deleted' => 0]; $user = SystemUser::mk()->where($map)->findOrEmpty(); if ($user->isEmpty()) { $this->app->session->set('LoginInputSessionError', true); $this->error('登录账号或密码错误,请重新输入!'); } if (empty($user['status'])) { $this->app->session->set('LoginInputSessionError', true); $this->error('账号已经被禁用,请联系管理员!'); } if (md5("{$user['password']}{$data['uniqid']}") !== $data['password']) { $this->app->session->set('LoginInputSessionError', true); $this->error('登录账号或密码错误,请重新输入!'); } $user->hidden(['sort', 'status', 'password', 'is_deleted']); $this->app->session->set('user', $user->toArray()); $this->app->session->delete('LoginInputSessionError'); $user->inc('login_num')->update([ 'login_at' => date('Y-m-d H:i:s'), 'login_ip' => $this->app->request->ip(), ]); // 刷新用户权限 AdminService::apply(true); sysoplog('系统用户登录', '登录系统后台成功'); $this->success('登录成功', sysuri('admin/index/index')); } } /** * 生成验证码 * @return void */ public function captcha() { $input = $this->_vali([ 'type.require' => '类型不能为空!', 'token.require' => '标识不能为空!', ]); $image = CaptchaService::instance()->initialize(); $captcha = ['image' => $image->getData(), 'uniqid' => $image->getUniqid()]; if ($this->app->session->get($input['type']) === $input['token']) { $captcha['code'] = $image->getCode(); $this->app->session->delete($input['type']); } $this->success('生成验证码成功', $captcha); } /** * 退出登录 * @return void */ public function out() { $this->app->session->destroy(); $this->success('退出登录成功!', sysuri('admin/login/index')); } }