zoukankan      html  css  js  c++  java
  • Laravel Authorization:支持 ACL、RBAC、ABAC 等模型的授权库

    Laravel Authorization 基于 Casbin ,是一个支持访问多种访问控制模型(如ACL,RBAC,ABAC等)的授权库。
    在这之前,你需要先了解 Casbin

    安装

    使用 Composer 安装:

    composer require casbin/laravel-authz
    

    LauthzLauthzServiceProviderauto-discovered 的,并且默认情况下已注册,但是如果您想自己注册,可以在 config/app.php 中添加 ServiceProvider:

    'providers' => [
        /*
         * Package Service Providers...
         */
        LauthzLauthzServiceProvider::class,
    ]
    

    Enforcer facade 也是 auto-discovered,但是如果您想手动添加它,在 config/app.php添加:

    'aliases' => [
        // ...
        'Enforcer' => LauthzFacadesEnforcer::class,
    ]
    

    要发布配置,请运行 vendor:publish 命令:

    php artisan vendor:publish
    

    这就自动创建 Model 配置文件 config/lauthz-rbac-model.conf 和 一个新的 Lauthz 配置文件 config/lauthz.php

    要迁移迁移,请运行migrate命令:

    php artisan migrate
    

    这将创建一个 rules 数据表。

    用法

    快速开始

    安装后,您可以执行以下操作:

    
    use 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 的各种操作:

    获取所有角色:

    Enforcer::getAllRoles(); // ['writer', 'reader']
    

    获取所有的角色的授权规则:

    Enforcer::getPolicy();
    

    获取某个用户的所有角色:

    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

    使用中间件

    该扩展包带有 EnforcerMiddlewareRequestMiddleware 中间件。 您可以将它们添加到您的app/Http/Kernel.php文件中:

    protected $routeMiddleware = [
        // ...
        // a basic Enforcer Middleware
        'enforcer' => LauthzMiddlewaresEnforcerMiddleware::class,
        // an HTTP Request Middleware
        'http_request' => LauthzMiddlewaresRequestMiddleware::class,
    ];
    

    基本 Enforcer 中间件

    然后就可以使用它们来保护路由了:

    Route::group(['middleware' => ['enforcer:articles,read']], function () {
        // pass
    });
    

    HTTP 请求中间件 ( 支持RESTful )

    如果需要授权一个请求,则需要首先在 config/lauthz-rbac-model.conf 中定义模型配置:

    [request_definition]
    r = sub, obj, act
    
    [policy_definition]
    p = sub, obj, act
    
    [role_definition]
    g = _, _
    
    [policy_effect]
    e = some(where (p.eft == allow))
    
    [matchers]
    m = g(r.sub, p.sub) && keyMatch2(r.obj, p.obj) && regexMatch(r.act, p.act)
    

    然后,使用中间件规则:

    Route::group(['middleware' => ['http_request']], function () {
        Route::resource('photo', 'PhotoController');
    });
    

    多个决策器

    如果您的项目中需要多个权限控制,则可以配置多个 决策器

    lauthz 配置文件中, 应该这样配置:

    return [
        'default' => 'basic',
    
        'basic' => [
            'model' => [
                // ...
            ],
    
            'adapter' => LauthzAdaptersDatabaseAdapter::class,
            // ...
        ],
    
        'second' => [
            'model' => [
                // ...
            ],
    
            'adapter' => LauthzAdaptersDatabaseAdapter::class,
            // ...
        ],
    ];
    
    

    然后选择使用哪一个决策器:

    Enforcer::guard('second')->enforce("eve", "articles", "edit");
    

    Artisan 命令行

    你可以在 控制台 使用 artisan 命令创建策略:

    给用户添加策略:

    php artisan policy:add eve,articles,read
    

    给角色添加策略:

    php artisan policy:add writer,articles,edit
    

    给用户赋予角色:

    php artisan role:assign eve writer
    

    缓存

    缓存 授权 规则可以提升性能,默认是关闭的。

    在 Laravel 的 config/lauthz.php 中设置自己的缓存配置:

    'cache' => [
        // changes whether Lauthz will cache the rules.
        'enabled' => false,
    
        // cache store
        'store' => 'default',
    
        // cache Key
        'key' => 'rules',
    
        // ttl DateTimeInterface|DateInterval|int|null
        'ttl' => 24 * 60,
    ],
    

    最后

    Casbin 项目地址:https://github.com/php-casbin/php-casbin

    Laravel Authorization 项目地址:https://github.com/php-casbin/laravel-authz

    你可以查看 Casbin 的完整文档 Casbin Docs.

  • 相关阅读:
    《梦幻西游》打响反盗号战役:为2亿玩家提供360安全武器 狼人:
    瑞星发表官方声明:记者王学武系恶意诽谤 狼人:
    中美联合挫败Conficker蠕虫大攻击 狼人:
    安全机构建议奥巴马政府谨慎使用开源软件 狼人:
    大量计算机遭“灰鸽子”病毒攻击 狼人:
    警惕IE7新漏洞导致的木马病毒暴增 狼人:
    IE7漏洞被瞄准 新型攻击将爆发 狼人:
    Windows 7成为Pwn2own黑客挑战赛目标 狼人:
    黑客入侵唱片业协会网站 为“海盗湾”助威 狼人:
    “猫癣”“犇牛”木马病毒肆虐 专家提醒补漏洞 狼人:
  • 原文地址:https://www.cnblogs.com/techone/p/11772075.html
Copyright © 2011-2022 走看看