一、背景
随着我们的微服务越来越多,如果每个微服务都要自己去实现一套鉴权操作,那么这么操作比较冗余,因此我们可以把鉴权操作统一放到网关去做,如果微服务自己有额外的鉴权处理,可以在自己的微服务中处理。
二、需求
1、在网关层完成url层面的鉴权操作。
- 所有的
OPTION
请求都放行。 - 所有不存在请求,直接都拒绝访问。
user-provider
服务的findAllUsers
需要user.userInfo
权限才可以访问。
2、将解析后的jwt token当做请求头传递到下游服务中。
3、整合Spring Security Oauth2 Resource Server
三、前置条件
1、搭建一个可用的认证服务器,可以参考之前的文章.
2、知道Spring Security Oauth2 Resource Server资源服务器如何使用,可以参考之前的文章.
四、项目结构
五、网关层代码的编写
1、引入jar包
1 | xml复制代码<dependency> |
2、自定义授权管理器
自定义授权管理器,判断用户是否有权限访问
此处我们简单判断
1、放行所有的 OPTION 请求。
2、判断某个请求(url)用户是否有权限访问。
3、所有不存在的请求(url)直接无权限访问。
1 | java复制代码package com.huan.study.gateway.config; |
3、token认证失败、或超时的处理
1 | java复制代码package com.huan.study.gateway.config; |
4、用户没有权限的处理
1 | java复制代码package com.huan.study.gateway.config; |
5、将token信息传递到下游服务器中
1 | java复制代码package com.huan.study.gateway.config; |
6、网关层面的配置
1 | java复制代码package com.huan.study.gateway.config; |
7、网关yaml配置文件
1 | yaml复制代码spring: |
六、演示
1、客户端
gateway 在认证服务器拥有的权限为 user.userInfo
2、user-provider
服务提供了一个api findAllUsers
,它会返回 系统中存在的用户(假的数据) 和 解码后的token信息。
3、在网关层面,findAllUsers 需要的权限为 user.userInfo
,正好 gateway
这个客户端有这个权限,所以可以访问。
演示GIF
七、代码路径
本文转载自: 掘金