Spring gateway + Oauth2实现单点登录及详细配置

以下是 “Spring Gateway + Oauth2 实现单点登录及详细配置”的完整攻略。

1. 概述

单点登录(Single Sign-On,简称 SSO)是企业级应用系统中经常用到的功能之一。在现代应用架构中,前后端的分离和微服务架构的流行,使得如何实现 SSO 变得更为复杂。本文将详细介绍如何使用 Spring Gateway 和 Spring Security OAuth2 实现 SSO,以及相关配置详解和示例代码。

2. 实现步骤

2.1 加载依赖

<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-oauth2</artifactId>
</dependency>

2.2 配置 Security 集成 OAuth2

在配置 Spring Security 集成 OAuth2 之前,需要先确定你的认证服务器(即 Authorization Server)的地址和所需的参数。比如,我们已经有一个 OAuth2 服务器的 IP 地址为 127.0.0.1:8080/oauth/authorize,客户端 ID 为 gateway-client,客户端 Secret 为 gateway-secret。

在配置过程中,需要注意以下参数:

  • security.oauth2.client.client-id:客户端 ID。
  • security.oauth2.client.client-secret:客户端 Secret。
  • security.oauth2.client.user-authorization-uri:认证服务器地址。
  • security.oauth2.client.access-token-uri:请求 token 的地址。
  • security.oauth2.client.grant-type:授权方式,一般为 authorization_code
  • security.oauth2.client.scope:请求的权限范围,一般为 readwrite
  • security.oauth2.resource.user-info-uri:获取用户信息的地址。

配置文件示例:

security:
  oauth2:
    client:
      client-id: gateway-client
      client-secret: gateway-secret
      user-authorization-uri: http://127.0.0.1:8080/oauth/authorize
      access-token-uri: http://127.0.0.1:8080/oauth/token
      grant-type: authorization_code
      scope: read,write
    resource:
      user-info-uri: http://127.0.0.1:8080/user

2.3 配置 Gateway

在配置 Gateway 之前,需要确定每一个需要认证的服务的路由规则和需要过滤的路径。在 Gateway 中,可以通过配置 Filter 实现对请求的拦截和处理。可以使用 Spring Security OAuth2 提供的 OAuth2GatewayFilterFactory 实现过滤器的配置。

在配置过程中,需要注意以下参数:

  • issuer-uri:认证服务器地址。
  • token-uri:请求 token 的地址。
  • use-current-uri:是否使用当前请求的 URI。
  • redirect-uri:Redirect URL。一般为 http://localhost:8080/login 或者是认证服务返回的默认 URL。
  • client-id:客户端 ID。
  • client-secret:客户端 Secret。
  • route-id:路由规则 ID。

配置文件示例:

spring:
  cloud:
    gateway:
      routes:
        - id: auth-service
          uri: http://localhost:8081
          predicates:
            - Path=/auth/**
          filters:
            - OAuth2=auth-service
        - id: user-service
          uri: http://localhost:8082
          predicates:
            - Path=/user/**
          filters:
            - OAuth2=user-service

security:
  oauth2:
    client:
      client-id: gateway-client
      client-secret: gateway-secret
      user-authorization-uri: http://127.0.0.1:8080/oauth/authorize
      access-token-uri: http://127.0.0.1:8080/oauth/token
      grant-type: authorization_code
      scope: read,write
    resource:
      user-info-uri: http://127.0.0.1:8080/user

spring:
  security:
    oauth2:
      client:
        registration:
          auth-service:
            client-id: gateway-client
            client-secret: gateway-secret
            client-name: auth-service
            scope: read, write
            provider: oauth2-provider
            redirect-uri-template: "{baseUrl}/login/oauth2/code/{registrationId}"
            authorization-grant-type: authorization_code
            client-authentication-method: POST
          user-service:
            client-id: gateway-client
            client-secret: gateway-secret
            client-name: user-service
            scope: read, write
            provider: oauth2-provider
            redirect-uri-template: "{baseUrl}/login/oauth2/code/{registrationId}"
            authorization-grant-type: authorization_code
            client-authentication-method: POST

      provider:
        oauth2-provider:
          authorization-uri: http://127.0.0.1:8080/oauth/authorize
          token-uri: http://127.0.0.1:8080/oauth/token
          user-info-uri: http://127.0.0.1:8080/user
          user-name-attribute: name

3. 示例

3.1 示例一(Spring Security OAuth2)

  1. 启动 OAuth2 服务器,使用默认端口 8080。
  2. 启动用户服务,使用端口 8082。
  3. 启动网关,使用端口 8080。
  4. 在浏览器中访问 http://localhost:8080/user/1,输入用户名和密码,并成功认证之后,会重定向到原始请求地址 http://localhost:8080/user/1。

3.2 示例二(Keycloak)

  1. 在服务器上安装 Keycloak,并进行简单的配置。
  2. 在 Keycloak 中添加一个 OpenID 连接器,描述了你的认证服务器应该如何与 Spring Gateway 集成。
  3. 修改 Gateway 的配置文件,以使用上述连接器和 Keycloak 进行认证。
  4. 启动网关和用户服务,测试是否可以进行 SSO 认证。

参考资料:

[1] https://www.baeldung.com/sso-spring-security-oauth2

[2] https://www.baeldung.com/spring-security-oauth2-keycloak

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Spring gateway + Oauth2实现单点登录及详细配置 - Python技术站

(0)
上一篇 2023年5月20日
下一篇 2023年5月20日

相关文章

  • 分析讲解SpringMVC注解配置如何实现

    下面是分析讲解SpringMVC注解配置如何实现的完整攻略: 一、SpringMVC注解配置的基本原理 SpringMVC注解配置是指使用注解的方式对SpringMVC进行配置。通过注解的方式,我们可以更加方便、简洁地进行配置,同时也可以大大降低代码量。SpringMVC注解配置的基本原理如下: 1.在SpringMVC的配置文件中,添加注解驱动配置: &l…

    Java 2023年5月16日
    00
  • java当中的定时器的4种使用方式

    首先我们来介绍一下Java中的定时器。在Java中,我们通常使用定时器来执行定时任务,例如在定时轮询某个任务、定时刷新界面等等。Java中的定时器主要有以下4种使用方式: 1. Timer Timer是Java中内置的定时器,可以用于执行定时任务。通过Timer对象,我们可以设置需要定时执行的任务并设定执行时间,例如在5秒后执行任务、每隔10秒执行一次任务等…

    Java 2023年5月20日
    00
  • Mybatis 插入和删除批处理操作

    对于“Mybatis插入和删除批处理操作”的完整攻略,可以分为以下几个步骤: 1.配置Mybatis的批处理模式2.编写插入和删除的SQL语句3.使用SqlSession进行批量操作 下面对每一步进行详细的讲解。 1.配置Mybatis的批处理模式 在Mybatis配置文件中,添加以下属性来开启批处理模式。 <configuration> &lt…

    Java 2023年5月19日
    00
  • 基于Java的Spring框架来操作FreeMarker模板的示例

    基于Java的Spring框架来操作 FreeMarker 模板是一种灵活高效的模板引擎模式。下面是详细的攻略: 1. 安装配置FreeMarker依赖 首先需要在项目中添加 FreeMarker 的 maven 依赖: <dependency> <groupId>org.freemarker</groupId> <…

    Java 2023年6月15日
    00
  • Spring Security 中细化权限粒度的方法

    那么接下来我将详细讲解Spring Security中细化权限粒度的方法的完整攻略。 什么是Spring Security? Spring Security是一个基于Spring框架的安全性解决方案,旨在为企业Java应用程序提供权威的身份验证和授权支持。 Spring Security中如何细化权限粒度? 1. 使用注解来限制访问 在Spring Secu…

    Java 2023年5月20日
    00
  • SpringSecurity添加图形验证码认证实现

    下面我来为你讲解SpringSecurity添加图形验证码认证实现的完整攻略。 1. 引入依赖 在pom.xml文件中添加以下依赖: <!–验证码依赖–> <dependency> <groupId>com.github.axolo</groupId> <artifactId>image-ver…

    Java 2023年5月20日
    00
  • HTML实现title 属性换行小技巧

    当我们在HTML标记中使用title属性时,有时候需要在倒数第二个单词之后添加一个换行符。这个时候我们可以用一些小技巧来完成。 方法一:使用实体字符 HTML中有几个实体字符可以用于在title属性中添加换行: &#13; 或 &#x0D; 表示回车 &#10; 或 &#x0A; 表示换行 代码示例: <a href=&…

    Java 2023年6月15日
    00
  • idea hibernate jpa 生成实体类的实现

    一、背景 在Java开发中,使用Hibernate和JPA框架是十分常见的,而手动编写实体类的过程比较繁琐,也容易出现错误。因此,我们可以使用IDEA来帮助我们自动生成实体类。 二、环境要求 IDEA集成开发环境 Hibernate框架和JPA的支持 三、具体步骤 添加Hibernate和JPA的支持 在新建项目或者已有项目的配置文件中,打开“Externa…

    Java 2023年5月20日
    00
合作推广
合作推广
分享本页
返回顶部