221900329俞润鼎 2022-06-06 19:51 采纳率: 60%
浏览 55
已结题

gateway如何优雅鉴权

问题遇到的现象和发生背景

今天在学习springcloud gateway 的时候,想要搭建一个统一的鉴权中心,但是原来的代码使用springsecurity的注解进行鉴权,现在需要提取鉴权代码,但是没找到合适的方式解决。

问题相关代码,请勿粘贴截图

下面是原项目(非微服务)的权限验证代码,这里使用了自定义的方法进行鉴权

    @PreAuthorize("hasAuthority('login_data')")
    public JsonResult getUserBaseData()

    @PutMapping("/{account}/common")
    @PreAuthorize("@sose.hasOtherDataAuthority(#account,'modify_user_all_data',#user.getStatus())")
    public JsonResult modifyCommonData(@RequestBody @Validated({Update.class}) User user,
                                       @PathVariable String account)
我的解答思路和尝试过的方法

找到一种方案是:
在数据库存方法和路由(例:POST_/user)
用户访问时比较方法与路由是否满足权限要求。
但是,如果遇到下面的情况(pathvarible),似乎就变得难以处理了
例如:

  • /user
  • /user/1
  • /source/5/collection(假如只有用户‘5’可以访问资源 ‘5’)
我想要达到的结果

有什么办法能够使用类似 @PreAuthorize 注解的方式在鉴权中心(微服务)进行鉴权。

  • 写回答

1条回答 默认 最新

  • 卡布奇诺-海晨 Java领域优质创作者 2022-06-06 21:00
    关注

    在网关鉴权,就不可能包含注解鉴权,因为使用注解鉴权已经是穿过网关这一层了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 6月16日
  • 已采纳回答 6月8日
  • 修改了问题 6月6日
  • 修改了问题 6月6日
  • 展开全部

悬赏问题

  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛