Bouncer:一个用于角色和权限授权的 Laravel 包

发布日期:作者:

Bouncer: a Laravel Package for Role and Ability Authorization image

Bouncer 是由 Joseph Silber 开发的授权包,它允许在 Laravel 的 授权门 中进行角色和权限检查。该包的描述如下

Bouncer 提供了一种机制来处理 Laravel ACL 中的角色和权限。它具有简洁的语法,尽可能不干预你的代码:在你需要时使用它,不需要时忽略它。

Bouncer 使得使用流畅的 API 快速创建角色和权限变得轻而易举,这些 API 会自动创建它们。

Bouncer::allow('admin')->to('ban-users');

您可以选择在 User 模型中添加 HasRolesAndAbilities 特性。这个特性允许你分配角色和权限,并在模型中进行检查。

use Silber\Bouncer\Database\HasRolesAndAbilities;
 
class User extends Authenticatable
{
use Notifiable,
HasRolesAndAbilities;
}

当你分配一个尚未创建的角色时,Bouncer 会自动创建它。

$user->assign('admin');

作为一个简单的例子,想象一个 数据库种子器,它使用 Bouncer 创建一些角色,并使用 HasRolesAndAbilities 特性将用户分配到一个角色。

public function run()
{
\Bouncer::allow('admin')->toManage(Post::class);
\Bouncer::allow('editor')->to('update', \App\Post::class);
 
$admin = factory(App\User::class)->create([
'email' => '[email protected]'
]);
 
$admin->assign('admin');
 
$editor = factory(App\User::class)->create([
'email' => '[email protected]'
]);
 
$editor->assign('editor');
 
factory(App\User::class)->create([
'email' => '[email protected]'
]);
}

这个数据库种子器方便地创建了两个角色:管理员和编辑。管理员将拥有在 App\Post 模型上所有帖子权限。编辑角色只拥有 update 权限。

有了上面的角色、权限和用户,我们可以定义一个路由,并使用 Laravel 的 Authorize 中间件来保护更新 Post 的操作。

Route::get('/posts/{post}', 'PostsController@show')
->name('post.update')
->middleware('can:update,post');

经过身份验证的管理员和编辑都将能够看到帖子,未登录的用户将被重定向到登录页面,而没有 update 权限的已登录用户将收到 403 Forbidden 响应。

在视图中,您可以使用 Laravel 的 @can 指令来检查权限,Bouncer 将拦截检查并授权,如果用户已被授予权限。

@can ('update', $post)
<a href="{{ route('post.update', $post) }}">Edit Post</a>
@endcan

不仅可以通过角色授予用户权限,还可以直接将权限分配给用户。

$post = \App\Post::first();
$normalUser = \App\User::find('email', '[email protected]')->first();
 
// Only update a specific post, perhaps one this user submitted.
$normalUser->allow('update', $post)
 
// Ability to update all posts directly on a user
$normalUser->allow('update', \App\Post::class);

Bouncer 提供了用于 检查用户角色 的方法,但 Bouncer 文档警告不要直接检查角色

一般来说,您不应该需要直接检查角色。最好是允许角色拥有某些权限,然后检查这些权限。如果您的需求非常通用,可以创建非常广泛的权限。例如,access-dashboard 权限总是比直接检查 admineditor 角色更好。

最后,如果您想获取用户的权限,请调用 $user->getAbilities(),它将返回一个数据库集合

查看该包的 自述文件 了解如何安装和使用 Bouncer。该包的 速查表 可以帮助您快速了解该包的 API 和功能。

Paul Redmond photo

Laravel 新闻的撰稿人。全栈 Web 开发人员和作者。

Cube

Laravel 新闻通讯

加入 40,000 多名其他开发者,不错过任何新的技巧、教程等。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动完成和即时反馈在本地和生产环境中进行调试。

Tinkerwell
No Compromises logo

不妥协

Joel 和 Aaron,来自 No Compromises 播客的两名经验丰富的开发人员,现在可以为您雇佣进行 Laravel 项目。 ⬧ 每月固定价格 7500 美元。 ⬧ 没有冗长的销售流程。 ⬧ 没有合同。 ⬧ 100% 退款保证。

不妥协
Kirschbaum logo

Kirschbaum

提供创新和稳定性,以确保您的 Web 应用程序取得成功。

Kirschbaum
Shift logo

Shift

运行旧版本的 Laravel?即时、自动的 Laravel 升级和代码现代化,让您的应用程序保持新鲜。

Shift
Bacancy logo

Bacancy

每月只需 2500 美元,即可让经验丰富的 Laravel 开发人员(拥有 4-6 年经验)为您的项目增光添彩。获得 160 小时的专业知识,并享受 15 天的无风险试用。立即预约通话!

Bacancy
Lucky Media logo

Lucky Media

立即获得幸运 - Laravel 开发的理想选择,拥有超过十年的经验!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar:Laravel 电子商务

Laravel 的电子商务。一个开源包,将现代无头电子商务功能的强大功能带到 Laravel。

Lunar:Laravel 电子商务
LaraJobs logo

LaraJobs

官方 Laravel 工作板

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit:Laravel SaaS 启动工具包

SaaSykit 是一个 Laravel SaaS 启动工具包,包含运行现代 SaaS 所需的所有功能。支付、漂亮的结账流程、管理面板、用户仪表盘、身份验证、现成的组件、统计数据、博客、文档等等。

SaaSykit:Laravel SaaS 启动工具包
Rector logo

Rector

您无缝升级 Laravel 的合作伙伴,降低成本,加速创新,助力企业成功

Rector
MongoDB logo

MongoDB

通过 MongoDB 和 Laravel 的强大集成增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务、搜索、分析和移动使用场景,同时使用熟悉的 Eloquent API。了解灵活、现代的 MongoDB 数据库如何改变您的 Laravel 应用程序。

MongoDB
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一个简单的无依赖项输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

在 Laravel 应用程序中添加 Swagger UI

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel Prompts 构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的网站搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 包在 Laravel 应用程序中添加评论

阅读文章