国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

Laravel用戶授權(quán)系統(tǒng)的使用方法示例

2024-05-05 00:05:23
字體:
供稿:網(wǎng)友

前言

本文主要給大家介紹的是關(guān)于Laravel用戶授權(quán)系統(tǒng)使用的相關(guān)內(nèi)容

首先兩個概念分清楚:

用戶身份認(rèn)證 Authentication - 處理用戶登錄, 退出, 注冊, 找回密碼, 重置密碼, 用戶郵箱認(rèn)證 etc..

權(quán)限管理 Authorization - 負(fù)責(zé) 用戶 與 權(quán)限, 用戶組 三者之間的對應(yīng), 以及管理.

下面話不多說了,來一起看看詳細(xì)的介紹吧

基本用法

示例

$this->authorize('update', $post);

第一個參數(shù) $ability,表示具備什么權(quán)限。第二個參數(shù) $post,是一個模型實(shí)例。

不需指定模型的動作,比如 create,不需要指定的模型。第二個參數(shù)傳一個類名。如:

$this->authorize('create', Post::class);

使用的場景有:控制器輔助方法,中間件,Blade模板,User 模型的 can 和 can't 方法。

authorize方法:

public function authorize($ability, $arguments = []){ list($ability, $arguments) = $this->parseAbilityAndArguments($ability, $arguments);  return app(Gate::class)->authorize($ability, $arguments);}

有兩種方式實(shí)現(xiàn)用戶授權(quán)

Gates

編寫 Gates

一般在 app/Providers/AuthServiceProvider 的 boot 方法中定義。

Gate::define('update-post', function ($user, $post) { return $user->id == $post->user_id;});

第一個參數(shù)是權(quán)限的名稱,第二個參數(shù)是滿足權(quán)限的條件,可以是閉包,控制器方法。

授權(quán)動作

allows 和 denies 兩種方法,表示允許和否定。

第一個參數(shù)是權(quán)限的名稱,第二個參數(shù)是模型,可以為空。這里不需要傳入用戶,框架會自動處理。

if (Gate::allows('update-post', $post)) { // 指定用戶可以更新博客...} if (Gate::denies('update-post', $post)) { // 指定用戶不能更新博客...}

如果需要指定特定用戶,可以使用 Gate Facade 中的 forUser 方法:

if (Gate::forUser($user)->allows('update-post', $post)) { // 指定用戶可以更新博客...} if (Gate::forUser($user)->denies('update-post', $post)) { // 指定用戶不能更新博客...}

策略

生成策略

artisan 命令:

php artisan make:policy PostPolicy

也可以指定 model,生成包含 CURD 的策略方法。

注冊策略

在 AuthServiceProvider 的 policies 屬性,可以將模型和策略對應(yīng)起來。如:

protected $policies = [ Post::class => PostPolicy::class,];

策略方法

public function update(User $user, Post $post){ return $user->id === $post->user_id;}

策略方法,就是權(quán)限名稱,$this->authorize(‘update', $post) 的第一個參數(shù)就對應(yīng)同名的策略方法,第二個參數(shù) $post 代表它是一個 Post 模型,框架會根據(jù)參數(shù)判斷采用 Post::class => PostPolicy::class 這個策略。

當(dāng) authorize 方法調(diào)用的時候,實(shí)際上會自動注入 User 和 Post 類型的兩個參數(shù),也因此使用授權(quán)系統(tǒng)必須是用戶登錄的情況下。

使用策略也不一定要和模型綁定,比如這樣也可以:

protected $policies = [ Travel::class => TravelPolicy::class, 'aaa'=>TravelPolicy::class,];

這個 aaa 字符串對應(yīng)策略類為 TravelPolicy::class,在控制器使用 authorize 判斷授權(quán):

$this->authorize('update','aaa');

此時也是可行的,第二個參數(shù)這個時候就必須是字符串 aaa 了,然后 authorize 方法只會自動注入 User 參數(shù)。

官方文檔

Laravel 5.5 文檔

https://laravel-china.org/docs/laravel/5.5/authorization/1310

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網(wǎng)的支持。


注:相關(guān)教程知識閱讀請移步到PHP教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 乐业县| 县级市| 大石桥市| 泰顺县| 喀什市| 岳阳县| 建湖县| 买车| 巴林右旗| 灵璧县| 广饶县| 永福县| 遂溪县| 周宁县| 丽江市| 达州市| 正蓝旗| 宜君县| 五大连池市| 灵寿县| 浙江省| 邳州市| 枣庄市| 绵竹市| 仪陇县| 瓮安县| 思茅市| 安乡县| 东城区| 子长县| 新邵县| 永泰县| 定州市| 沈丘县| 顺昌县| 屯门区| 民和| 义马市| 岳阳市| 文山县| 白沙|