在用户没有登录的情况下,如果访问后台的某一个页面要禁止访问,并且告知未登录,请先登录。

让需要展示页面控制器,继承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');
    }


}

 

posted @ 2021-09-19 16:46  王越666  阅读(370)  评论(0编辑  收藏  举报