在现代 Web 应用程序中,控制谁可以访问或修改资源至关重要。例如,在博客应用程序中,您可能希望确保只有帖子的所有者才能编辑或删除它。 Laravel 提供了两种优雅的方式来处理授权:Gates 和 Policy Classes。本指南将引导您完成这两种方法,向您展示如何保护您的资源并确保应用程序的安全。
Gate 提供了一种快速而直接的方法来使用闭包处理授权。它们非常适合简单的授权检查,并在 AuthServiceProvider 中定义。
让我们定义一个门来确保只有帖子所有者才能更新或删除帖子:
定义 Gate:打开 AuthServiceProvider 并添加您的 Gate 定义:
// app/Providers/AuthServiceProvider.php use Illuminate\Support\Facades\Gate; use App\Models\Post; public function boot() { $this->registerPolicies(); Gate::define('update-post', function ($user, Post $post) { return $user->id === $post->user_id; }); Gate::define('delete-post', function ($user, Post $post) { return $user->id === $post->user_id; }); }
应用门:在控制器方法中使用门来强制执行授权逻辑:
// app/Http/Controllers/PostController.php use Illuminate\Http\Request; use Illuminate\Support\Facades\Gate; use App\Models\Post; public function update(Request $request, Post $post) { if (Gate::denies('update-post', $post)) { abort(403, 'You do not own this post. ?'); } // Proceed with updating the post } public function destroy(Post $post) { if (Gate::denies('delete-post', $post)) { abort(403, 'You do not own this post. ?'); } // Proceed with deleting the post }
优点:
缺点:
最佳用例:需要快速授权检查的小型应用程序或简单用例。 ?
策略类提供了一种更加结构化和可扩展的方法来处理授权。它们提供了一种清晰的方法来管理复杂的授权规则并保持代码井井有条。当使用包含标准 CRUD 操作的资源控制器时,策略特别有用:index、create、edit、update 和 摧毁。
生成策略:使用 Artisan 创建策略类:
php artisan make:policy PostPolicy
定义策略方法:打开生成的策略类并添加方法来处理每个操作的授权:
// app/Policies/PostPolicy.php namespace App\Policies; use App\Models\User; use App\Models\Post; class PostPolicy { /** * Determine if the user can view the list of posts. * * @param User $user * @return bool */ public function viewAny(User $user) { // Example logic to allow viewing posts for authenticated users return true; } /** * Determine if the user can create a post. * * @param User $user * @return bool */ public function create(User $user) { return true; } /** * Determine if the user can update the post. * * @param User $user * @param Post $post * @return bool */ public function update(User $user, Post $post) { return $user->id === $post->user_id; } /** * Determine if the user can delete the post. * * @param User $user * @param Post $post * @return bool */ public function delete(User $user, Post $post) { return $user->id === $post->user_id; } }
使用策略:在控制器操作中应用策略方法:
// app/Http/Controllers/PostController.php use Illuminate\Http\Request; use App\Models\Post; public function update(Request $request, Post $post) { $this->authorize('update', $post); // Proceed with updating the post } public function destroy(Post $post) { $this->authorize('delete', $post); // Proceed with deleting the post }
优点:
缺点:
最佳案例场景:非常适合具有复杂授权要求的应用程序或目标是干净、可维护的代码。 ?
Laravel 中的 Gates 和 Policy 类都提供了处理授权的强大方法。门非常适合快速、简单的检查,而策略类提供了管理复杂场景的结构化方法,特别是在具有 index、create、edit、更新和销毁。选择最适合您的应用程序需求的方法,并享受安全、组织良好的代码库! ??
以上是Laravel 中的授权 - 初学者指南的详细内容。更多信息请关注PHP中文网其他相关文章!