# 基于角色的權限認證-AUTH
> 在ThinkPHP早基的版本(TP3.2)中,自帶了AUTH權限認證,但是TP5.0沒有內置。所以在TP5.0如果要使用的話,可以在TP3.2的基礎上,將AUTH類進行修改使用支持TP5即可。不過大家在使用時一般不需要自行修改,因為有網友已經修改好后,分享了出來,大家可以通過`Composer`進行擴展。具體的擴展方式和插件擴展一樣。
## 安裝think-auth擴展
> 打開[Composer軟件倉庫(https://packagist.org/)](https://packagist.org/),搜索`think-auth`,在這里會看到有限多的網友分享,大家可以找一個下載量比較高的使用。
~~~
composer require 5ini99/think-auth
~~~
> 如果安裝過程中出現了異常,要確認一下當前使用的`源`是否可用。
## 認識think-auth
安裝后,在`vendor`目錄下會多出一個擴展

大家可以打開`README.md`,該文件中有該擴展的詳細的介紹以及使用方法。
> 該擴展的的核心只有一個文件,就是`Auth.php`。
## auth的原理
Auth權限認證是按規則進行認證。
在這里需要用到四張表
* 管理員表(系統自帶)
* 規則表(think\_auth\_rule)
* 用戶組表(think\_auth\_group)
* 用戶組明細表(think\_auth\_group\_access)
我們在規則表中定義權限規則, 在用戶組表中定義每個用戶組有哪些權限規則,在用戶組明細表中定義用戶所屬的用戶組。
## 四張表之間的關系

> 明白了四張表的關系后,接下 就是關于四張表數據的錄入。錄入的方式就是對這四張表的增刪改查操作。
> 在這里要注意,`auth_rule`表中少一個`type`字段。
## 權限認證相關表錄入的注意事項
1. 錄入規則表中的`name`字段時,要注意控制器和方以之間的分附符,另外這里還可以帶上模塊名。
2. 在設置管理員角色時,有兩種方案,一種是`一對多`和`多對多`。即一個管理員只屬于一個角以,一上是一個管理員可以屬于多個角色。
3. 在刪除管理和刪除 角色時,要同時刪除中間表中相關的數據。
> 到目前為止,還沒有用到`auth`權限擴展類。
## 權限驗證
### 引 入`auth`擴展類庫
> 在引主時一 定要注意其命名空間,如果不清楚的話,可以打開`Auth.php`查看,也可以打 擴展目錄下的`composer.json`來查看。通過這兩種方式都可以查出去命名空間為:`think\auth`,所以在引入時,要使用如下方式引入:
~~~
<?php
.....
use think\auth\Auth;
.....
~~~
### 權限認證的實現
> 正確引入類庫之后,接下 就是實 例化`auth`類,并調和其`check`來實現權限的認證。另外,驗證代碼要寫在一個公共的控制器和方法中。
> 具體的代 如下:
~~~
$controller = request()->controller();
$action = request()->action();
$auth = new Auth();
if(session('uid')!==10){//初始化管理員不進行驗證
if(!$auth->check($controller . '-' . $action, session('uid'))){
$this->error('你沒有權限訪問','admin/index/index');
}
}
~~~
### 根據用戶id獲取用戶組,返回值為數組
getGroups($uid)
### 獲得權限列表*
getAuthList($uid, $type)
### 獲取權限組對應的權限列表*
getGroupAuthList($gid, $type = 1)
### 獲得用戶資料,根據自己的情況讀取數據庫*/
getUserInfo($uid)
### 角色狀態
> Auth權限類,支持對角色的狀態進行設置。這樣可以臨時關閉某一角色的所有權限。
### 權限狀態
> 可以單獨控制某一權限的狀態。
### 初始化管理員
> 為系統設置一個 始化管理員是十分必要的,它的主要作用為系統 管理員分配權限。
**特點:**
* * *
1. 不需要進行驗上,擁有系統的所有權限
2. 初始化管理不有被刪除(結合實際情況)
### 特殊處理
- 課程介紹
- thinkphp5.0
- 安裝
- 開發規范
- 目錄結構
- 配置參數
- 系統常量
- tp5自帶的函數
- 助手函數
- 擴展類庫
- 基本類庫
- Workerman
- think-queue
- 驗證碼
- 圖片
- 權限認證
- 課前準備
- 數據庫設計
- 模塊設計
- 管理員管理
- 添加
- 編輯
- 刪除和批量刪除
- 列表頁
- 實列
- 權限管理
- 操作日志
- 基于行為的日記錄
- 行為日志的擴展
- 助手類庫
- 自建函數
- 將數組轉成uri字符串
- 獲取當前服務器的IP
- curl-post
- 截取文字中間的字符串
- 檢查中文姓名
- 省市區分別截取
- 抽獎概率問題
- 短信郵箱模板替換
- 生成csv
- PHP 圖片轉base64
- 銀行卡驗證
- json返回接口封裝
- 無限極分類
- 病毒
- xml和數組互轉
- xml轉成數組
- 數組轉xml
- tp控制器相關
- 獲取thinkph5下控制器和方法名
- 后臺查詢的簡單封裝
- 網址信息
- 獲取網站logo
- 判斷url是否存在
- 獲取title
- 判斷遠程文件是否存在
- 獲取頁面所有鏈接
- 過濾
- 截取
- 時間
- 獲取服務器信息
- 根據id生成唯一邀請碼
- 隨機顏色
- 數組字符串互換
- 創建多級目錄
- 懶人查詢
- 時間和時間戳轉換
- 房間id生菜
- 獲取需要的數組元素
- 文件和文件夾
- 文件類庫
- 文件夾
- 七牛云
- 七牛云運用場景
- 七牛云使用實例
- 郵箱
- 郵箱驗證
- 郵箱發送
- 數據庫
- 數據庫在thinkphp中的補充方法
- 備份和安全
- sql執行
- 數據庫備份2
- 時間日歷
- 時間格式化
- 日歷
- 圖片相關
- 自動獲取圖片主題顏色
- 獲取html中的圖片路徑
- 獲取圖片場景
- 獲取圖片實踐
- 圖片處理類
- 圖片處理場景
- 圖片處理實踐
- 數據驗證分析
- 身份證相關
- 新聞
- 自建類庫
- 簡易分類庫
- php 壓縮CSS代碼
- 身份證
- 分詞和抽詞
- 分詞應用場景
- 分詞實踐
- 中文轉拼音
- 中文轉拼音場景
- 中文轉拼音實踐
- 二維碼操作
- 二維碼場景
- 二維碼實踐
- 短地址
- PHPWord
- 插件化
- 插件擴展庫
- 插件列表
- 插件安裝和卸載
- 插件實踐
- 插件的離線安裝
- 計劃任務
- 計劃任務安裝
- 計劃任務實踐
- 定時器
- 注冊登錄
- 普通登錄注冊
- 第三方登錄注冊
- jwt接口登錄注冊
- 短信
- 飛鴿短信
- 阿里短信
- 消息隊列
- 網站地圖
- 全站靜態化
- 緩存
- 文件導出
- PDF生成
- phpword
- PHPExcel
- 其他類庫
- 百度
- 百度語音
- 快遞
- 跨域問題
- 寶塔
- 搜索記錄