首頁 >php框架 >ThinkPHP >關於Thinkphp 6.0認證外掛Think-authz的安裝使用

關於Thinkphp 6.0認證外掛Think-authz的安裝使用

藏色散人
藏色散人轉載
2020-11-10 14:35:383440瀏覽

安裝

此擴充功能需要PHP 7.1 和ThinkPHP 6.0 ,針對TP 5.1 請使用Think-Casbin .

使用

composer
安裝:

composer require casbin/think-authz
註冊服務,在應用程式的全域公用檔案
service.php

中加入:<pre class="brush:php;toolbar:false">return [     // ...     tauthz\TauthzService::class,];</pre>發佈設定檔和資料庫遷移檔案:

php think tauthz:publish

這將自動產生config/tauthz-rbac-model.conf

config/tauthz.php

檔案。

執行遷移工具(確保資料庫配置資訊正確):<pre class="brush:php;toolbar:false">php think migrate:run</pre>這將建立名為

rules

的表。

用法

快速開始#安裝成功後,可以這樣使用:

use tauthz\facade\Enforcer;
// adds permissions to a user
Enforcer::addPermissionForUser('eve', 'articles', 'read');
// adds a role for a user.
Enforcer::addRoleForUser('eve', 'writer');
// adds permissions to a rule
Enforcer::addPolicy('writer', 'articles','edit');

你可以檢查一個使用者是否擁有某個權限:
// to check if a user has permission
if (Enforcer::enforce("eve", "articles", "edit")) {
    // permit eve to edit articles} else {
    // deny the request, show an error}

使用Enforcer Api

它提供了非常豐富的

API

#,以促進對Policy 的各種操作:

取得所有角色:<pre class="brush:php;toolbar:false">Enforcer::getAllRoles(); // ['writer', 'reader']</pre>取得所有的角色的授權規則:<pre class="brush:php;toolbar:false">Enforcer::getPolicy();</pre>取得某個使用者的所有角色:

Enforcer::getRolesForUser('eve'); // ['writer']

取得某個角色的所有使用者:

Enforcer::getUsersForRole('writer'); // ['eve']

決定使用者是否擁有某個角色:

Enforcer::hasRoleForUser('eve', 'writer'); // true or false

為使用者新增角色:

Enforcer::addRoleForUser('eve', 'writer');

賦予權限給某個使用者或角色:

// to user
Enforcer::addPermissionForUser('eve', 'articles', 'read');
// to role
Enforcer::addPermissionForUser('writer', 'articles','edit');

刪除使用者的角色:

Enforcer::deleteRoleForUser('eve', 'writer');

刪除某個使用者的所有角色:

Enforcer::deleteRolesForUser('eve');

刪除單一角色:

Enforcer::deleteRole('writer');

刪除某個權限:

Enforcer::deletePermission('articles', 'read'); 
// returns false if the permission does not exist (aka not affected).

刪除某個使用者或角色的權限:

Enforcer::deletePermissionForUser('eve', 'articles', 'read');

刪除某個使用者或角色的所有權限:

// to user
Enforcer::deletePermissionsForUser('eve');
// to role
Enforcer::deletePermissionsForUser('writer');

取得用戶或角色的所有權限:

Enforcer::getPermissionsForUser('eve'); 
// return array

決定某個使用者是否擁有某個權限

Enforcer::hasPermissionForUser('eve', 'articles', 'read');  
// true or false

更多

API

參考Casbin API (https://casbin.org/ docs/en/management-api)。

使用中間件該擴充包帶有一個

\tauthz\middleware\Basic::class

中間件:
Route::get('news/:id','News/Show')
    ->middleware(\tauthz\middleware\Basic::class, ['news', 'read']);

以上是關於Thinkphp 6.0認證外掛Think-authz的安裝使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:learnku.com。如有侵權,請聯絡admin@php.cn刪除