下面由thinkphp框架教學欄位來介紹Thinkphp5中auth權限設定以及實現,希望對需要的朋友有幫助!
1. 將auth類別下載好放置目錄:extend\auth\auth.php
2.將類別中的SQL語句執行,可以在資料庫中建立3張表 auth_group(使用者群組表) auth_rule(權限規則表) auth_group_access(使用者與使用者群組關係表)
#3.極分類) auth_rule(權限規則表) 中添加3個字段 pid(父級id ,0為頂級權限) level(級別) sort(排序),如下圖
<?php namespace app\admin\controller; use think\Controller; use think\Request; use auth\Auth; //引入suth类 class Common extends Controller { public function _initialize(){ //初始化判断用户是否已经登陆 if(!session('uname')){ $this->error('请先登陆系统!','login/index'); } //获得当前页面的控制器 / 方法 $request=Request::instance(); $moudle=$request->module(); //获取当前控制器名称 $con=$request->controller(); //获取当前控制器名称 $action=$request->action(); //获取当前方法名称 $this->assign(array( 'con'=>$con, 'action'=>$action, )); $rules=$con.'/'.$action; //组合 控制器/方法 $auth=new Auth(); //实例化auth类 $notCheck=array('Index/index'); //都可以访问的页面 if(session('uid')!=1){ //不是超级管理员才进行权限判断 if(!in_array($rules,$notCheck)){ // 是否在开放权限里面 if(!$auth->check($rules,session('uid'))){ // 第一个参数 控制/方法 第二个参数:当前登陆会员的id $this->error('没有权限','index/index'); }; } } }
以上是Thinkphp5中auth權限設定以及實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!