”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > Laravel 中的授权 - 初学者指南

Laravel 中的授权 - 初学者指南

发布于2024-11-07
浏览:355

Authorization In Laravel - A Beginner

掌握 Laravel 中的授权:Gates 与策略类 ??

在现代 Web 应用程序中,控制谁可以访问或修改资源至关重要。例如,在博客应用程序中,您可能希望确保只有帖子的所有者才能编辑或删除它。 Laravel 提供了两种优雅的方式来处理授权:GatesPolicy Classes。本指南将引导您完成这两种方法,向您展示如何保护您的资源并确保应用程序的安全。

Laravel 的盖茨?

Gates 提供了一种快速、直接的方法来使用闭包处理授权。它们非常适合简单的授权检查,并在 AuthServiceProvider 中定义。

设置门

让我们定义一个门来确保只有帖子所有者才能更新或删除帖子:

  1. 定义 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;
        });
    }
    
  2. 应用门:在控制器方法中使用门来强制执行授权逻辑:

    // 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
    }
    

盖茨的优点和缺点

优点

  • 简单性:使用最少的代码即可快速设置。 ⚡
  • 简单的理想选择:非常适合单一资源应用程序或简单的场景。 ?

缺点

  • 可扩展性:随着应用程序的增长,可能会变得麻烦且难以管理。 ?
  • 维护:如果组织不好,可能会变得混乱。 ?

最佳用例:需要快速授权检查的小型应用程序或简单用例。 ?

Laravel 中的策略类?️

策略类提供了一种更加结构化和可扩展的方法来处理授权。它们提供了一种清晰的方法来管理复杂的授权规则并保持代码井井有条。在使用包含标准 CRUD 操作的资源控制器时,策略特别有用:indexcreateeditupdate破坏

创建和使用策略

  1. 生成策略:使用 Artisan 创建策略类:

    php artisan make:policy PostPolicy
    
  2. 定义策略方法:打开生成的策略类并添加方法来处理每个操作的授权:

    // 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;
        }
    }
    
  3. 使用策略:在控制器操作中应用策略方法:

    // 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 的内置框架支持来实现一致的授权。 ?

缺点

  • 初始设置:与门相比,设置稍微多一些。 ⚙️
  • 复杂性:对于非常简单的授权场景可能有点过分了。 ?

最佳案例场景:非常适合具有复杂授权要求的应用程序或目标是干净、可维护的代码。 ?


概括

Laravel 中的 Gates 和 Policy Class 都提供了处理授权的强大方法。门非常适合快速、简单的检查,而策略类提供了管理复杂场景的结构化方法,特别是在具有 indexcreateedit更新销毁。选择最适合您的应用程序需求的方法,并享受安全、组织良好的代码库! ??

版本声明 本文转载于:https://dev.to/mohammed_kareem/authorization-in-laravel-a-beginners-guide-32kf?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 在 JavaScript 中创建对象的方法
    在 JavaScript 中创建对象的方法
    介绍 在 JavaScript 中创建对象的方法有很多种。 对象字面量 Object() 构造函数 Object.create() 构造函数 ES6 类 对象字面量 这可能是在 JavaScript 中创建对象最快、最简单的方法。这也称为对象初始值设定项,是一个由零...
    编程 发布于2024-11-07
  • 如何在 JavaScript 中扩展自定义异常的错误对象?
    如何在 JavaScript 中扩展自定义异常的错误对象?
    扩展 JavaScript 中的错误对象在 JavaScript 中抛出异常时,可能希望扩展内置 Error 对象以创建自定义错误类型。这允许更具体和信息丰富的异常处理。在 JavaScript 中,继承不是通过子类化与 Python 不同,在 Python 中,异常通常是从 Exception 基...
    编程 发布于2024-11-07
  • MySQL如何保证并发操作时数据的完整性?
    MySQL如何保证并发操作时数据的完整性?
    MySQL 并发:确保数据完整性如果您的 MySQL 数据库使用 InnoDB 存储引擎,您可能会担心在执行过程中潜在的并发问题。同时记录更新或插入。本文探讨了 MySQL 如何处理并发以及是否需要在应用程序中加入额外的处理。MySQL 的并发处理MySQL 采用原子性,这意味着单独的 SQL 语句...
    编程 发布于2024-11-07
  • 如何使用 Go 在 SQL 查询中有效连接字符串和值?
    如何使用 Go 在 SQL 查询中有效连接字符串和值?
    在 Go 中有效地制作 SQL 查询在 Go 中将字符串与文本 SQL 查询中的值连接起来可能有点棘手。与 Python 不同,Go 的字符串格式化语法行为不同,导致常见错误,如此处遇到的错误。元组语法错误初始代码片段尝试使用 Python -style 元组,Go 中不支持。这会导致语法错误:qu...
    编程 发布于2024-11-07
  • 为什么 json_encode() 无法使用 Latin1 编码对 MySQL 数据库中的重音字符进行编码?
    为什么 json_encode() 无法使用 Latin1 编码对 MySQL 数据库中的重音字符进行编码?
    MySQL 中 UTF-8 字符的 JSON 编码难题当尝试使用 latin1_swedish_ci 编码从数据库中检索重音字符并使用 json_encode() 将它们编码为 JSON 时,结果可能出乎意料。预期结果(例如“Abord â Plouffe”)会转换为“null”,从而使编码的 JS...
    编程 发布于2024-11-07
  • 如何在 MySQL 中将行转置为列:综合指南
    如何在 MySQL 中将行转置为列:综合指南
    在 MySQL 中将行转换为列在 MySQL 查询中将行转换为列需要在应用程序中执行复杂的查询或手动操作。GROUP_CONCAT 解决方案虽然 GROUP_CONCAT 可以将行转换为单列,但它不提供整个结果集所需的转置。手动查询方法对于更复杂的转置,需要细致的查询,从原始行手动构造每一列。复杂查...
    编程 发布于2024-11-07
  • 如何解决iOS后台模式下未收到GCM通知的问题
    如何解决iOS后台模式下未收到GCM通知的问题
    当应用程序在 iOS 上处于后台模式时未收到 GCM 通知当 iOS 在后台收到通知但不处理时,会出现此问题它们在用户界面中。要解决此问题,请确保您的应用:启用后台推送通知:检查您的应用是否已请求并获得在后台接收推送通知的权限。设置徽章应用程序图标:验证是否在应用程序的“设置”>“通知”部分中选择了...
    编程 发布于2024-11-07
  • 为什么在 Windows 7 中使用 CLASSPATH 时出现 ClassNotFoundException?
    为什么在 Windows 7 中使用 CLASSPATH 时出现 ClassNotFoundException?
    尽管使用 CLASSPATH 环境变量仍解决 java.lang.ClassNotFoundException在 Windows 7 中尝试使用 Java 连接到 MySQL 数据库时,设置 CLASSPATH 环境变量以包含 JDBC 驱动程序 jar 文件的路径似乎无法解决 java.lang....
    编程 发布于2024-11-07
  • 开发人员需要了解免费外汇 API
    开发人员需要了解免费外汇 API
    如果您是一名开发人员,您一定正在寻找可以帮助您更轻松地工作的工具,对吗?免费的外汇 API 就是其中之一!它使您无需支付任何费用即可获取外汇汇率。但是,许多开发人员对这些 API 不太了解。因此,本文旨在解释什么是免费外汇 API、它为何有用以及如何为您的项目选择一个 API。 什么是免费外汇 A...
    编程 发布于2024-11-07
  • 如何使用 JavaScript 将字符串中每个单词的首字母大写?
    如何使用 JavaScript 将字符串中每个单词的首字母大写?
    使用 JavaScript 将字符串中每个单词的首字母大写在 JavaScript 中,将字符串中每个单词的首字母大写可以可以通过多种方法来实现。一种常见的方法是使用将给定字符串转换为标题大小写的函数。让我们探索一个演示此技术的代码示例:function titleCase(str) { var...
    编程 发布于2024-11-07
  • 我们能否在 JavaScript 中实现超越“setTimeout()”的可靠计时器精度?
    我们能否在 JavaScript 中实现超越“setTimeout()”的可靠计时器精度?
    在 Javascript 中实现超越 setTimeout() 的计时器精度Javascript 的 setTimeout() 方法在精度方面经常达不到要求,表现出不可预测的延迟,可能会影响 UI 操作。因此,开发人员可能想知道是否有其他方法可以提供更可靠的计时功能。使用 setTimeout() ...
    编程 发布于2024-11-07
  • 使用 Amazon Q Transformation 将 Java 颂歌转换为 Java
    使用 Amazon Q Transformation 将 Java 颂歌转换为 Java
    近年来,Java 取得了显着的进步,每个新版本都引入了强大的功能和优化。如果您仍在 Java 8 上运行,您就会错过性能、语法和安全性方面的重大改进。从 Java 8 升级到 Java 17 似乎令人畏惧,但 Amazon Q 的转换功能通过自动化一些较繁琐的步骤使升级变得更加容易。在这篇文章中,我...
    编程 发布于2024-11-07
  • 使用 React 构建食谱查找器网站
    使用 React 构建食谱查找器网站
    Introduction In this blog, we'll be building a Recipe Finder Website using React. This app allows users to search for their favorite recipes,...
    编程 发布于2024-11-07
  • Turborepo 与 Nx:哪种 Monorepo 工具适合您?
    Turborepo 与 Nx:哪种 Monorepo 工具适合您?
    随着现代开发变得越来越复杂,monorepos变得越来越流行。它们允许将多个项目或包存储在单个存储库中,从而简化依赖关系管理并促进更好的协作。用于管理 monorepos 的两个顶级工具是 Turborepo 和 Nx。 这两种工具都旨在提高处理单一存储库的效率和可扩展性,但它们具有独特的优势。在本...
    编程 发布于2024-11-07
  • Java 数组简介
    Java 数组简介
    编程通常涉及管理和操作大量数据,对此高效且有效的数据结构至关重要。数组是计算机科学中的基本数据结构,提供了一种存储固定大小的相同类型元素序列的方法。在本博客中,我们将深入了解 Java 中的数组:了解它们是什么、它们的语法、如何对它们进行操作以及它们的内存管理。 为什么我们需要数组?...
    编程 发布于2024-11-07

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3