在用户没有登录的情况下,如果访问后台的某一个页面要禁止访问,并且告知未登录,请先登录。
让需要展示页面控制器,继承Base即可
<?php namespace app\test\controller; use think\Controller; use think\Request; class Base extends Controller { public function __construct(Request $request = null) { parent::__construct($request); if (!session('userNode')) { $this->error('您还没有登录,请先登录', 'http://www.day.com/test/login/create'); } } public function logout() { session(null); $this->error('正在退出登录,请稍后', 'http://www.day.com/test/login/create'); } }
登录简易页面:无非空
<?php namespace app\test\controller; use app\test\model\LoginModel; use think\Controller; use think\Request; class Login extends Controller { /** * 显示资源列表 * * @return \think\Response */ public function index() { // } /** * 显示创建资源表单页. * * @return \think\Response */ public function create() { // return view(); } /** * 保存新建的资源 * * @param \think\Request $request * @return \think\Response */ public function save(Request $request) { //接受前端登录参数 $data=$request->param(); $data['password']=md5($data['password']); // 验证参数 *****略 $res=LoginModel::getUserInfo($data); // 进行对比 if ($res['username']!=$data['name']){ $this->error('账号错误','http://www.day.com/test/login/create'); } if ($res['userpassword']!=$data['password']){ $this->error('密码错误','http://www.day.com/test/login/create'); } // 获取用户的id,去进行关联表进行权限设置 $id=$res['id']; $userNode=LoginModel::getUserNode($id); session('userNode',$userNode); $this->success('登录成 功','http://www.day.com/test/node/index'); } }