Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >支持Nacos 2.1.0!这套Spring Cloud Gateway+Oauth2终极权限解决方案升级了!

支持Nacos 2.1.0!这套Spring Cloud Gateway+Oauth2终极权限解决方案升级了!

作者头像
macrozheng
发布于 2022-07-24 09:01:03
发布于 2022-07-24 09:01:03
1.5K00
代码可运行
举报
文章被收录于专栏:mall学习教程mall学习教程
运行总次数:0
代码可运行

最近经常有小伙伴问我关于在微服务中使用Oauth2的问题,其实之前已经写过一篇相关文章了。这次抽空把之前文章中的Demo给升级了,支持了最新版的Spring Cloud和Nacos。今天再来介绍下这套微服务权限终极解决方案,希望对大家有所帮助!

实现思路

首先还是来聊聊这套解决方案的实现思路,我们理想的解决方案应该是这样的,认证服务负责统一认证,网关服务负责校验认证和鉴权,其他API服务则负责处理自己的业务逻辑。安全相关的逻辑只存在于认证服务和网关服务中,其他服务只是单纯地提供服务而没有任何安全相关逻辑。

这套解决方案中相关服务的划分如下:

  • micro-oauth2-gateway:网关服务,负责请求转发和鉴权功能,整合Spring Security+Oauth2;
  • micro-oauth2-auth:认证服务,负责对登录用户进行认证,整合Spring Security+Oauth2;
  • micro-oauth2-api:API服务,受网关服务的保护,用户鉴权通过后可以访问该服务,不整合Spring Security+Oauth2。

升级注意点

  • 这里项目的依赖版本都升级了,支持SpringBoot 2.7.0和最新版的Spring Cloud;
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<properties>
    <spring-boot.version>2.7.0</spring-boot.version>
    <spring-cloud.version>2021.0.3</spring-cloud.version>
    <spring-cloud-alibaba.version>2021.0.1.0</spring-cloud-alibaba.version>
</properties>
  • 这里不得不吐槽下Spring Cloud的版本号,之前名字采用了伦敦地铁站的名字,根据字母表的顺序来对应版本时间顺序,后来又改成了年份,现在又添加了之前废弃的地铁站名字作为别名,真是让人迷惑;
  • SpringBoot 2.7.0版本中使用Maven插件需要添加版本号;
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
    <version>${spring-boot.version}</version>
</plugin>
  • 最新版本的Spring Cloud已经放弃使用Ribbon来做负载均衡了,转而使用LoadBalancer,所以网关服务micro-oauth2-gateway中还需添加LoadBalancer依赖;
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>
  • 如果不添加LoadBalancer依赖,从网关调用任意服务会返回Service Unavailable错误信息;
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{
    "timestamp": "2022-06-28T02:36:31.680+00:00",
    "path": "/auth/oauth/token",
    "status": 503,
    "error": "Service Unavailable",
    "requestId": "c480cefa-1"
}
  • micro-oauth2-auth认证服务需要升级版本,注意使用的JWT库也要同步升级;
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-oauth2</artifactId>
        <version>2.2.5.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>com.nimbusds</groupId>
        <artifactId>nimbus-jose-jwt</artifactId>
        <version>9.23</version>
    </dependency>
</dependencies>
  • 下载Nacos 2.1.0版本,下载地址:https://github.com/alibaba/nacos/releases
  • 下载完成后解压到指定目录即可,使用如下命令启动Nacos;
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
startup.cmd -m standalone
  • 访问Nacos控制台,使用账号密码nacos:nacos进行登录,访问地址:http://localhost:8848/nacos/

使用

本文仅作为微服务权限终极解决方案,Spring Cloud Gateway + Oauth2 实现统一认证和鉴权! 升级版本的补充,具体代码实现可以参考该文,下面演示下该解决方案中的统一认证和鉴权功能。

  • 首先需要启动Nacos和Redis服务,然后依次启动micro-oauth2-authmicro-oauth2-gatewaymicro-oauth2-api服务,启动完成后Nacos服务列表显示如下;
  • 使用密码模式获取JWT令牌,访问地址:http://localhost:9201/auth/oauth/token
  • 不带JWT令牌访问受保护的API接口,访问地址:http://localhost:9201/api/hello
  • 带JWT令牌访问受保护的API接口,注意请求头Authorization添加Bearer前缀,可以正常访问;
  • 使用获取到的JWT令牌访问获取当前登录用户信息的接口,访问地址:http://localhost:9201/api/user/currentUser
  • 当JWT令牌过期时,使用接口返回的refreshToken获取新的JWT令牌,访问地址:http://localhost:9201/auth/oauth/token
  • 使用没有访问权限的andy:123456账号登录,访问接口时会返回如下信息,访问地址:http://localhost:9201/api/hello

总结

在微服务系统中实现权限功能时,我们不应该把重复的权限校验功能集成到每个独立的API服务中去,而应该在网关做统一处理,然后通过认证中心去统一认证,这样才是优雅微服务权限解决方案!

项目源码地址

https://github.com/macrozheng/springcloud-learning/tree/master/micro-oauth2

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-07-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 macrozheng 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
微服务权限终极解决方案,Spring Cloud Gateway + Oauth2 实现统一认证和鉴权!
https://github.com/macrozheng/springcloud-learning/tree/master/micro-oauth2
macrozheng
2020/07/14
25.1K1
微服务权限终极解决方案,Spring Cloud Gateway + Oauth2 实现统一认证和鉴权!
SpringCloud Gateway + Jwt + Oauth2 实现网关的鉴权操作
点击上方“芋道源码”,选择“设为星标” 管她前浪,还是后浪? 能浪的浪,才是好浪! 每天 10:33 更新文章,每天掉亿点点头发... 源码精品专栏 原创 | Java 2021 超神之路,很肝~ 中文详细注释的开源项目 RPC 框架 Dubbo 源码解析 网络应用框架 Netty 源码解析 消息中间件 RocketMQ 源码解析 数据库中间件 Sharding-JDBC 和 MyCAT 源码解析 作业调度中间件 Elastic-Job 源码解析 分布式事务中间件 TCC-Transaction
芋道源码
2022/08/29
3.7K0
SpringCloud Gateway + Jwt + Oauth2 实现网关的鉴权操作
开箱即用!看看人家的微服务权限解决方案,那叫一个优雅!
对比之前使用Spring Security的微服务权限解决方案,Sa-Token的解决方案更简单、更优雅。使用Security我们需要定义鉴权管理器、分别处理未认证和未授权的情况、还要自己定义认证和资源服务器配置,使用非常繁琐。而使用Sa-Token,只要在网关上配置过滤器实现认证和授权,然后调用API实现登录及权限分配即可。具体区别可以参考下图。
macrozheng
2021/09/22
2.2K1
开箱即用!看看人家的微服务权限解决方案,那叫一个优雅!
Spring Gateway、Sa-Token、Nacos 认证/鉴权方案,yyds!
之前进行鉴权、授权都要写一大堆代码。如果使用像Spring Security这样的框架,又要花好多时间学习,拿过来一用,好多配置项也不知道是干嘛用的,又不想了解。要是不用Spring Security,token的生成、校验、刷新,权限的验证分配,又全要自己写,想想都头大。
码猿技术专栏
2024/01/23
1.6K1
Spring Gateway、Sa-Token、Nacos 认证/鉴权方案,yyds!
Spring Cloud Gateway整合nacos实战(三)
Spring Cloud GateWay是Spring Cloud的⼀个全新项⽬,⽬标是取代Netflix Zuul,它基于Spring5.0+SpringBoot2.0+WebFlux(基于⾼性能的Reactor模式响应式通信框架Netty,异步⾮阻塞模型)等技术开发,性能⾼于Zuul,官⽅测试,GateWay是Zuul的1.6倍,旨在为微服务架构提供⼀种简单有效的统⼀的API路由管理⽅式。
Java技术债务
2022/08/09
2.1K0
Spring Cloud Gateway整合nacos实战(三)
Nacos + Spring Cloud Gateway动态路由配置
具体的Nacos怎么配置就不介绍了,可以参考阿里巴巴的官方介绍,这里通过windows直接本地启动开启单机模式,登录Nacos Console,创建dev的namespace,在dev下的默认分组下创建gateway-router的dataId
BUG弄潮儿
2021/06/25
7.2K0
Nacos + Spring Cloud Gateway动态路由配置
集成Spring Cloud Security和Spring Cloud Gateway
Spring Cloud Security提供了在分布式系统中使用OAuth2和JWT的支持。而Spring Cloud Gateway是一个基于Spring Framework 5,Spring Boot 2和Project Reactor的网关服务,它为微服务架构提供了一种简单而有效的方式来对外提供API。
堕落飞鸟
2023/04/14
3.7K0
Spring Cloud Security:Oauth2实现单点登录
单点登录(Single Sign On)指的是当有多个系统需要登录时,用户只需登录一个系统,就可以访问其他需要登录的系统而无需登录。
macrozheng
2019/11/15
3.2K0
SpringCloud-基于Oauth2的SSO单点登录原理解析与实现
单点登录(SSO)是一种身份验证过程,允许用户通过一次登录访问多个系统。本文将深入解析单点登录的原理,并详细介绍如何在Spring Cloud环境中实现单点登录。通过具体的架构图和代码示例,我们将展示SSO的工作机制和优势,帮助开发者更好地理解和应用这一技术。
Damon小智
2024/05/28
2.2K1
SpringCloud-基于Oauth2的SSO单点登录原理解析与实现
微服务权限
通过认证服务(oauth2-auth)进行统一认证,然后通过网关(oauth2-gateway)来统一校验认证和鉴权。采用Nacos作为注册中心,Gateway作为网关,使用nimbus-
花落花相惜
2021/12/07
7240
Spring Cloud Alibaba 项目搭建
**分别添加 RedisTokenStoreConfig.class 、OAuthConfig.class
ruochen
2021/11/25
5830
Spring Cloud Gateway微服务网关
网关为微服务架构的系统提供简单、有效且统一的API路由管理,作为系统的统一入口,提供内部服务的路由中转,给客户端提供统一的服务,可以实现一些和业务没有耦合的公用逻辑,主要功能包含认证、鉴权、路由转发、安全策略、防刷、流量控制、监控日志等。
张云飞Vir
2022/10/28
5430
Spring Cloud Gateway:构建强大的API网关
在微服务架构中,随着用户服务、订单服务、支付服务等多个服务的启动和运行,管理这些服务的请求、确保安全性以及在高负载下保持系统的稳定性变得尤为重要。API网关作为微服务架构中的关键组件,能够很好地解决这些问题。
公众号:码到三十五
2024/10/22
2070
Spring Cloud Gateway:构建强大的API网关
Spring Cloud Gateway 服务网关的部署与使用详细教程
点击上方“芋道源码”,选择“设为星标” 管她前浪,还是后浪? 能浪的浪,才是好浪! 每天 10:33 更新文章,每天掉亿点点头发... 源码精品专栏 原创 | Java 2021 超神之路,很肝~ 中文详细注释的开源项目 RPC 框架 Dubbo 源码解析 网络应用框架 Netty 源码解析 消息中间件 RocketMQ 源码解析 数据库中间件 Sharding-JDBC 和 MyCAT 源码解析 作业调度中间件 Elastic-Job 源码解析 分布式事务中间件 TCC-Transaction
芋道源码
2022/10/09
4.6K0
Spring Cloud Gateway 服务网关的部署与使用详细教程
Spring Cloud Security:Oauth2实现单点登录
单点登录(Single Sign On)指的是当有多个系统需要登录时,用户只需登录一个系统,就可以访问其他需要登录的系统而无需登录。
JAVA葵花宝典
2019/11/18
1.6K0
Spring Cloud Security:Oauth2实现单点登录
一个实例,轻松演示Spring Cloud集成Nacos实例
学习一个技术框架,最快速的手段就是将其集成到项目中,体验一下它的功能。在这个过程中,你还踩到很多坑。而排坑的过程,又是一次能力的提升。
程序新视界
2021/12/07
5460
Spring Cloud Alibaba Nacos+Gateway踩坑
Nacos 的使用倒是比较简单,但是由于用的Mac M1芯片的电脑,使用过程中踩坑在上一篇已经写过了 Mac M1芯片Nacos
赵哥窟
2022/05/13
7930
Spring Cloud Alibaba Nacos+Gateway踩坑
【微服务~Nacos】Nacos服务提供者和服务消费者
👀专栏介绍 【微服务~Nacos】 目前主要更新微服务,一起学习一起进步。 👀本期介绍 本期主要介绍微服务~Nacos 文章目录 搭建父项目 服务提供者Provider 搭建服务 创建服务 查看服务 注册异常 服务消费者Consumer 搭建服务 创建服务 查询服务 搭建父项目 项目名:nacos-parent-2.1 添加坐标 <parent> <groupId>org.springframework.cloud</groupId> <artifactId
陶然同学
2023/02/27
3480
【微服务~Nacos】Nacos服务提供者和服务消费者
Spring Security 授权详解
所有的微服务的请求都经过网关,网关从认证中心读取微服务的地址,将请求转发至微服务,注册中心采用Eureka。
ruochen
2021/12/16
2.7K0
Spring OAuth2
《Spring OAuth2 开发指南》是系列文章,详细介绍基于 Spring 生态(包括 Spring Cloud) OAuth2
ruochen
2021/11/23
2.1K0
推荐阅读
相关推荐
微服务权限终极解决方案,Spring Cloud Gateway + Oauth2 实现统一认证和鉴权!
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验