婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > thinkPHP框架RBAC實現原理分析

thinkPHP框架RBAC實現原理分析

熱門標簽:山東電銷卡外呼系統原理是什么 蘇州外呼系統有效果嗎 400 電話 辦理 智能電銷語音機器人資訊 亳州企業外呼系統 打開百度地圖標注 兼職做地圖標注好賺錢嗎 海南外呼系統方案 地圖標注怎么做商戶驗證

本文實例講述了thinkPHP框架RBAC實現原理。分享給大家供大家參考,具體如下:

RBAC就是:Role Based Access Controller,基于角色(role)的權限(Access)管理,這里簡單介紹一下他的原理與實現方式之一。

Part 1 數據庫設計

首先最基本的組成有:用戶(admin),角色(role),具體權限(auth),這三者之間的關系是這樣的:一個用戶只擁有一種角色,一種角色下擁有多個權限,一個權限也會同時被多個角色擁有,也就是說admin表和role表是一對一關系,role和auth表是多對多關系,本來符合范式設計要求的情況應該是需要一張關聯表的,但是這里為了簡單,就只把role擁有的auth寫成一個字段auth_id_lst。所以具體的表設計就是:

admin

  • admin_id
  • admin_name
  • role_id (foreign_key)

role

  • role_id
  • role_name
  • auth_id_lst

auth

  • auth_id
  • auth_name
  • auth_pid

為了更直接的理解,這里放幾個每張表的具體記錄:

auth

auth_id auth_name auth_pid
1 供應商管理 0
2 供應商添加 1
3 供應商修改 1
4 商品管理 0
5 商品下架 4
6 顧客管理 0

role

role_id role_name auth_id_lst
1 物流部門經理 1,2,3
2 銷售部門經理 4,5
3 公關部門經理 6

admin

admin_id admin_name role_id
1 張三 1
2 李四 2
3 王五 3

這樣就可以保存住具體的用戶所擁有的具體權限了,而其中為了能更好的管理具體auth,同時也為了更好的理解,所以加入了role表進行補充,如果做一個類似的話,更像下面的形式:

  • admin:具體人員
  • role:部門
  • auth:具體所需要的權限

同一個部門的人,所需要的權限基本是相同的,所以可以使用一個role進行統一管理。

Part 2 代碼實現

上面只是簡單做一個介紹,這一部分開始將介紹具體的實施方案,來自于一個帶我的大哥。看懂下面的部分你需要具備的知識點有:

  • thinkphp的基礎知識
  • session的用法

這個使用的場景是一個后臺管理系統,針對不同role開放不同的Controller(控制器)和Action(方法),所以auth表具體結構如下:

admin

  • auth_id
  • auth_name
  • auth_c 保存控制器名
  • auth_a 保存方法名
  • auth_pid 權限之間存在分類情況,使用該字段進行保存

接下來就是具體的操作步驟了:

1.1 新建Controller類

在thinkphp中每個Controller都會繼承一個thinkphp下的Think\Controller,這個時候可以新建一個Controller,之后讓所有的Controller都繼承這個新建的類,這樣所有進行的操作都要先經過這個新建控制器的篩選。

下面是這個新建類的部分內容:

?php
namespace Admin\Controller;
use Think\Controller;
class FatherController extends Controller{
  // 構造函數
  public function __construct(){
    // 實例化父類構造函數
    parent::__construct();
    // session('admin_id')會在后面的驗證成功后被保存
    // session()中的?表示判斷
    fi(!session('?admin_id')){
      $this->error('必須登錄后才可以執行操作',U('Back/login'));
    }
    // 后面還有內容,這里先到這里
  }
}
?>

1.2 跳轉到登錄頁面

1.1中跳轉到一個登錄的頁面,在這個登錄頁面中輸入用戶名、密碼、驗證碼之后,就可以調用專門Model類來進行驗證了。這里就細講了,這里講解一下具體步驟:

  • 在BackController的login方法中實例化AdminModel類
  • 在AdminModel類中設置自動驗證和自動完成,保證用戶名和密碼都經過驗證
  • 如果用戶名和密碼都正確,則將admin_id保存在session中,并從role表中讀取該用戶的role,與auth_id_lst,同樣保存在session中。這里做一下總結:

session('admin_id') 登錄者的id

session('user_name') 登錄者注冊名

session('auth') 登錄者所擁有的role中的auth_id_lst中對應auth表的具體值,格式為 Controller/Action
session('menu') 登錄者所能操作的具體的權限信息

1.3 回到最初新建的Controller類

?php
namespace Admin\Controller;
use Think\Controller;
class FatherController extends Controller{
  // 構造函數
  public function __construct(){
    // 實例化父類構造函數
    parent::__construct();
    // session('admin_id')會在后面的驗證成功后被保存
    // session()中的?表示判斷
    fi(!session('?admin_id')){
      $this->error('必須登錄后才可以執行操作',U('Back/login'));
    }
    // 這里是后面新建的內容
    // CONTROLLER_NAME 當前調用的控制器名,think的變量
    // ACTION_NAME 與CONTROLLER_NAME一樣,表示當前調用的控制器下的方法
    $currentMethod=CONTROLLER_NAME.'/'.ACTION_NAME;
    // 上面其實是thinkphp一般的pathinfo模式的url格式
    // Index隨便調用,其實就是主頁,在主頁有其他設置,用于展現其所擁有的權限,這個后面再看
    if(CONTROLLER_NAME=='Index'){
      return true;
    }
    // 讀取用戶所擁有的所有權限,已經將字符串解析成數組形式了
    $allowMethod=session('auth_id_lst');
    // *表示超級用戶,擁有所有權限,如果用戶請求超越自己權限的操作,則會顯示錯誤提示頁面
    if($allowMethod!='*'  !in_array($currentMethod, $allowMethod)){
      $this->error('越權操作',U('Index/index'));
    }
  }
}
?>

1.4 主頁顯示內容

主頁是使用thinkphp的內置標簽自動生成的,所以只要把握好輸出的內容,就可以限制住給于用戶的操作權限,上面說過,其中賦予用戶的操作權限都是保存在session('menu')中,所以只要在內置標簽中調用這個值進行顯示就可以了,具體內容就是這樣。

講的很爛我知道,畢竟只花了半個小時看其中的具體內容,之后可能會嘗試自己寫寫看吧,那時候再說吧。

更多關于thinkPHP相關內容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結》、《ThinkPHP常用方法總結》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術總結》。

希望本文所述對大家基于ThinkPHP框架的PHP程序設計有所幫助。

您可能感興趣的文章:
  • ThinkPHP中RBAC類的四種用法分析
  • ThinkPHP的RBAC(基于角色權限控制)深入解析
  • ThinkPHP權限認證Auth實例詳解
  • thinkPHP5 ACL用戶權限模塊用法詳解
  • thinkPHP5框架auth權限控制類與用法示例
  • thinkphp自定義權限管理之名稱判斷方法
  • thinkphp關于簡單的權限判定方法

標簽:萊蕪 溫州 呼倫貝爾 金華 清遠 紹興 綏化 安康

巨人網絡通訊聲明:本文標題《thinkPHP框架RBAC實現原理分析》,本文關鍵詞  thinkPHP,框架,RBAC,實現,原理,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《thinkPHP框架RBAC實現原理分析》相關的同類信息!
  • 本頁收集關于thinkPHP框架RBAC實現原理分析的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 水城县| 高碑店市| 漳州市| 突泉县| 应城市| 友谊县| 镇赉县| 龙山县| 博湖县| 仪陇县| 大理市| 顺昌县| 唐山市| 新宁县| 尚志市| 万年县| 抚宁县| 安吉县| 固始县| 什邡市| 华亭县| 观塘区| 锡林郭勒盟| 广汉市| 安阳县| 电白县| 新昌县| 万全县| 东乡| 新巴尔虎左旗| 札达县| 陆良县| 本溪| 冀州市| 华宁县| 富民县| 左云县| 玛沁县| 乌鲁木齐县| 任丘市| 沽源县|