V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
tomsun28
V2EX  ›  Java

关于 restful api 的认证鉴权中的 rbac

  •  
  •   tomsun28 ·
    tomsun28 · 2020-08-25 16:10:07 +08:00 · 2105 次点击
    这是一个创建于 1542 天前的主题,其中的信息可能已经有所发展或是发生改变。

    将 restful api 视作一个资源,即 /api/book/foor===get, get 请求 /api/book/foor 整体视为一个资源
    /api/book/foor===post, post 请求 /api/book/foor 整体视为另一个资源
    资源和角色相映射,用户再和角色对应。即角色拥有资源,用户所属对应角色,用户才能访问此 api.

    上面这种方式咋样? 自荐一个开箱即用的高效认证鉴权包,专注于 Restful Api 的动态保护 su.usthe.com

    github: https://github.com/tomsun28/sureness

    <dependency>
        <groupId>com.usthe.sureness</groupId>
        <artifactId>sureness-core</artifactId>
        <version>0.0.2.7</version>
    </dependency>
    
    10 条回复    2020-09-05 08:53:48 +08:00
    ksice
        1
    ksice  
       2020-09-01 15:34:21 +08:00
    这不是按钮级别的权限么,不知道 rbac 到底是个什么程度的权限控制
    tomsun28
        2
    tomsun28  
    OP
       2020-09-01 16:30:21 +08:00
    @ksice 这个没有针对按钮,针对的是一个 restful api 接口的权限保护,如果需要按钮权限可以考虑按钮绑定 api 。rbac 我理解是基于角色的权限控制,比如说: 用户 A 属于角色 B,角色 B 拥有资源 C 的访问权限,那么用户 A 就能访问资源 C 。在上面,我们把 restful api 接口视为资源 C 。
    ksice
        3
    ksice  
       2020-09-01 18:19:34 +08:00
    那这个不就是最简单的五表权限,或者七表权限和九表权限
    tomsun28
        4
    tomsun28  
    OP
       2020-09-02 00:09:28 +08:00
    @ksice 嗯嗯是的,这个项目如果用数据库作为数据源,数据库存储结构会是 5 表权限
    ksice
        5
    ksice  
       2020-09-02 10:06:40 +08:00
    @tomsun28 不用数据库的话还可以用什么做数据源呢,缓存么
    tomsun28
        6
    tomsun28  
    OP
       2020-09-02 18:32:04 +08:00
    @ksice 目前也实现了基于配置文件做数据源
    ksice
        7
    ksice  
       2020-09-03 13:07:23 +08:00
    @tomsun28 基于配置文件是不是没有数据库那么方便灵活和持久化
    tomsun28
        8
    tomsun28  
    OP
       2020-09-03 19:16:29 +08:00
    @ksice 是的 支持文本配置是为了方便用户更快搭建试用效果,或者有简单认证需求的可以使用文本数据源,推荐还是数据库作为源
    ksice
        9
    ksice  
       2020-09-04 10:16:53 +08:00
    @tomsun28 嗯,只是为了测试的话就不用考虑这方面的问题
    tomsun28
        10
    tomsun28  
    OP
       2020-09-05 08:53:48 +08:00
    @ksice 嗯嗯
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1037 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 21:16 · PVG 05:16 · LAX 13:16 · JFK 16:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.