返回顶部
首页 > 资讯 > 服务器 >java构建OAuth2授权服务器
  • 140
分享到

java构建OAuth2授权服务器

2024-04-02 19:04:59 140人浏览 独家记忆
摘要

目录构建 OAuth2 授权服务器设置客户端和用户认证信息设置客户端信息设置用户认证信息生成 Token构建 OAuth2 授权服务器 从表现形式上看,OAuth2 授权服务器也是

构建 OAuth2 授权服务器

从表现形式上看,OAuth2 授权服务器也是一个独立的微服务,因此构建授权服务器的方法也是创建一个 SpringBoot 应用程序,我们需要引入对应的 Maven 依赖,如下所示:


<dependency>
    <groupId>org.springframework.security.oauth</groupId>
    <artifactId>spring-security-oauth2</artifactId>
</dependency>

这里的 spring-security-oauth2 就是来自 Spring Security 中的 OAuth2 库。现在 Maven 依赖已经添加完毕,下一步就是构建 Bootstrap 类作为访问的入口:


@SpringBootApplication
@EnableAuthorizationServer
public class AuthServer {
    public static void main(String[] args) {
        SpringApplication.run(AuthServer.class, args);
    }
}

请注意,这里出现了一个新的注解 @EnableAuthorizationServer,这个注解的作用在于为微服务运行环境提供一个基于 OAuth2 协议的授权服务,该授权服务会暴露一系列基于 RESTful 风格的端点(例如 /oauth/authorize 和 /oauth/token)供 OAuth2 授权流程使用。

构建 OAuth2 授权服务只是集成 OAuth2 协议的第一步,授权服务器是一种集中式系统,管理着所有与安全性流程相关的客户端和用户信息。因此,接下来我们需要在授权服务器中对这些基础信息进行初始化,而 Spring Security 为我们提供了各种配置类来实现这一目标。

设置客户端和用户认证信息

OAuth2.0 有几个授权模式:授权码模式、简化模式、密码模式、客户端凭证模式。其中,密码模式以其简单性得到了广泛的应用。在接下来的内容中,我们就以密码模式为例展开讲解。

在密码模式下,用户向客户端提供用户名和密码,并将用户名和密码发给授权服务器从而请求 Token。授权服务器首先会对密码凭证信息进行认证,确认无误后,向客户端发放 Token。整个流程如下图所示:

请注意,授权服务器在这里执行认证操作的目的是验证传入的用户名和密码是否正确。在密码模式下,这一步是必需的,如果采用其他授权模式,不一定会有用户认证这一环节。

确定采用密码模式后,我们来看为了实现这一授权模式,需要对授权服务器做哪些开发工作。首先我们需要设置一些基础数据,包括客户端信息和用户信息。

设置客户端信息

我们先来看如何设置客户端信息。设置客户端时,用到的配置类是 ClientDetailsServiceConfigurer,该配置类用来配置客户端详情服务 ClientDetailsService。用于描述客户端详情的 ClientDetails 接口则包含了与安全性控制相关的多个重要方法,该接口中的部分方法定义如下:


public interface ClientDetails extends Serializable {
     //客户端唯一性 Id
     String getClientId();
     //客户端安全码
     String getClientSecret();
     //客户端的访问范围
     Set<String> getScope();
     //客户端可以使用的授权模式

     Set<String> getAuthorizedGrantTypes();
     …
}

首先 ClientId 是一个必备属性,用来唯一标识客户的 Id,而 ClientSecret 代表客户端安全码。这里的 Scope 用来限制客户端的访问范围,如果这个属性为空,客户端就拥有全部的访问范围。常见的设置方式可以是 WEBclient 或 mobileclient,分别代表 Web 端和移动端。

最后,authorizedGrantTypes 代表客户端可以使用的授权模式,可选的范围包括代表授权码模式的 authorization_code、代表隐式授权模式 implicit、代表密码模式的 passWord 以及代表客户端凭据模式的 client_credentials。这个属性在设置上也可以添加 refresh_token,通过刷新操作获取以上授权模式下产生的新 Token。

和实现认证过程类似,Spring Security 也提供了 AuthorizationServerConfigurerAdapter 这个配置适配器类来简化配置类的使用方式。我们可以通过继承该类并覆写其中的 configure(ClientDetailsServiceConfigurer clients) 方法进行配置。使用 AuthorizationServerConfigurerAdapter 进行客户端信息配置的基本代码结构如下:


@Configuration

public class SpringAuthorizationServerConfigurer extends AuthorizationServerConfigurerAdapter {
    @Override
    public void configure(ClientDetailsServiceConfigurer clients) throws Exception {
    clients.inMemory()
        .withClient("spring")
        .secret("{noop}spring_secret")
        .authorizedGrantTypes("refresh_token", "password", "client_credentials")
        .scopes("webclient", "mobileclient");
    }
}

可以看到,我们创建了一个 SpringAuthorizationServerConfigurer 类来继承 AuthorizationServerConfigurerAdapter,并通过 ClientDetailsServiceConfigurer 配置类设置了授权模式为密码模式。在授权服务器中存储客户端信息有两种方式,一种就是如上述代码所示的基于内存级别的存储,另一种则是通过 JDBC 在数据库中存储详情信息。为了简单起见,这里使用了内存级别的存储方式。

同时我们注意到,在设置客户端安全码时使用了"{noop}spring_secret"这种格式。这是因为在 Spring Security 5 中统一使用 PasswordEncoder 对密码进行编码,在设置密码时要求格式为“{id}password”。而这里的前缀“{noop}”就是代表具体 PasswordEncoder 的 id,表示我们使用的是 NoOpPasswordEncoder。

@EnableAuthorizationServer 注解会暴露一系列的端点,而授权过程是使用 AuthorizationEndpoint 这个端点进行控制的。要想对该端点的行为进行配置,你可以使用 AuthorizationServerEndpointsConfigurer 这个配置类。和 ClientDetailsServiceConfigurer 配置类一样,我们也通过使用 AuthorizationServerConfigurerAdapter 配置适配器类进行配置。

因为我们指定了授权模式为密码模式,而密码模式包含认证环节。所以针对 AuthorizationServerEndpointsConfigurer 配置类需要指定一个认证管理器 AuthenticationManager,用于对用户名和密码进行认证。同样因为我们指定了基于密码的授权模式,所以需要指定一个自定义的 UserDetailsService 来替换全局的实现,可以通过如下代码来配置 AuthorizationServerEndpointsConfigurer:


@Configuration

public class SpringAuthorizationServerConfigurer extends AuthorizationServerConfigurerAdapter {

 @Autowired
 private AuthenticationManager authenticationManager;

 @Autowired
 private UserDetailsService userDetailsService;

 @Override

 public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception {   endpoints.authenticationManager(authenticationManager).userDetailsService(userDetailsService);
 } 
}

至此,客户端设置工作全部完成,我们所做的事情就是实现了一个自定义的 SpringAuthorizationServerConfigurer 配置类并覆写了对应的配置方法。

设置用户认证信息

设置用户认证信息所依赖的配置类是 WebSecurityConfigurer 类,Spring Security 同样提供了 WebSecurityConfigurerAdapter 类来简化该配置类的使用方式,我们可以继承 WebSecurityConfigurerAdapter 类并且覆写其中的 configure() 的方法来完成配置工作。

关于 WebSecurityConfigurer 配置类,我们首先需要明确配置的内容。实际上,设置用户信息非常简单,只需要指定用户名(User)、密码(Password)和角色(Role)这三项数据即可,如下所示:


@Configuration

public class SpringWebSecurityConfigurer extends WebSecurityConfigurerAdapter {

 @Override
 @Bean
 public AuthenticationManager authenticationManagerBean() throws Exception {
            return super.authenticationManagerBean();
 }

 @Override
 @Bean
 public UserDetailsService userDetailsServiceBean() throws Exception {
            return super.userDetailsServiceBean();
 }

 @Override
 protected void configure(AuthenticationManagerBuilder builder) throws Exception {
 builder
            .inMemoryAuthentication()
            .withUser("user1")
            .password("{noop}password1")
            .roles("USER")
            .and()
            .withUser("admin")
            .password("{noop}password2")
            .roles("USER", "ADMIN");
 }
}

结合上面的代码,我们看到构建了具有不同角色和密码的两个用户,请注意"user1"代表的角色是一个普通用户,"admin"则具有管理员角色。我们在设置密码时,同样需要添加前缀“{noop}”。同时,我们还看到 authenticationManagerBean()和 userDetailsServiceBean() 方法分别返回了父类的默认实现,而这里返回的 UserDetailsService 和 AuthenticationManager 在前面设置客户端时会用到。

生成 Token

现在,OAuth2 授权服务器已经构建完毕,启动这个授权服务器,我们就可以获取 Token。我们在构建 OAuth2 服务器时已经提到授权服务器中会暴露一批端点供 Http 请求进行访问,而获取 Token 的端点就是http://localhost:2000/oauth/token。在使用该端点时,我们需要提供前面配置的客户端信息和用户信息。

这里使用 Postman 来模拟 HTTP 请求,客户端信息设置方式如下图所示:

我们在“Authorization”请求头中指定认证类型为“Basic Auth”,然后设置客户端名称和客户端安全码分别为“spring”和“spring_secret”。

接下来我们指定针对授权模式的专用配置信息。首先是用于指定授权模式的 grant_type 属性,以及用于指定客户端访问范围的 scope 属性,这里分别设置为 “password”和“webclient”。既然设置了密码模式,所以也需要指定用户名和密码用于识别用户身份,这里,我们以“spring_user”这个用户为例进行设置,如下图所示:

在 Postman 中执行这个请求,会得到如下所示的返回结果:


{
    "access_token":"d2066f68-665b-4038-9dbe-5dd1035e75a0",
    "token_type":"bearer",
    "refresh_token":"44009836-731c-4e6a-9cc3-274ce3af8c6b",
    "expires_in":3599,
    "scope":"all"
}

可以看到,除了作为请求参数的 scope,这个返回结果中还包含了 access_token、token_type、refresh_token 和 expires_in 等属性。这些属性都很重要。当然,因为每次请求生成的 Token 都是唯一的,所以你在尝试时获取的结果可能与我的不同。

到此这篇关于java构建OAuth2授权服务器的文章就介绍到这了,更多相关java构建OAuth2授权服务器内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: java构建OAuth2授权服务器

本文链接: https://lsjlt.com/news/130321.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • java构建OAuth2授权服务器
    目录构建 OAuth2 授权服务器设置客户端和用户认证信息设置客户端信息设置用户认证信息生成 Token构建 OAuth2 授权服务器 从表现形式上看,OAuth2 授权服务器也是...
    99+
    2024-04-02
  • java中怎么构建一个OAuth2授权服务器
    今天就跟大家聊聊有关java中怎么构建一个OAuth2授权服务器,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。构建 OAuth3 授权服务器从表现形式上看,OAuth3 授权服务器也...
    99+
    2023-06-20
  • Springboot开发OAuth2认证授权与资源服务器操作
    设计并开发一个开放平台。 一、设计: 网关可以 与认证授权服务合在一起,也可以分开。 二、开发与实现: 用Oauth2技术对访问受保护的资源的客户端进行认证与授权。 Oauth2技...
    99+
    2024-04-02
  • Spring Authorization Server 授权服务器
    说明 Spring Authorization Server 遵循Oauth2.1和OpenID Connect 1.0,它建立在Spring Security之上。 最小化项目 创建项目 要求JDK11以上 使用Idea创建一个Maven...
    99+
    2023-09-23
    spring 服务器 spring boot
  • OAuth2.0 实践 Spring Authorization Server 搭建授权服务器 + Resource + Client
    title: OAuth2.0 实践 Spring Authorization Server 搭建授权服务器 + Resource + Client date: 2023-03-27 01:41:26 tags: OAuth2.0Spri...
    99+
    2023-08-18
    spring 服务器 java
  • 2023.10 秋爽版 java 软件授权激活 架构 java代码混淆 按日期授权 不联网
    什么是代码混淆? 代码混淆是一种技术,用于在不改变代码功能的情况下,通过改变代码的结构和逻辑,使之变得更难理解和分析,从而增加反向工程的难度。 为什么要进行代码混淆? 在Java应用程序中,代码是以明文形式存在的。如果黑客轻易地分析出加密算...
    99+
    2023-10-11
    安全 java加密 java混淆 java授权
  • Node.JS, Mongoose和Jade怎样搭建OAuth2服务器
    今天就跟大家聊聊有关Node.JS, Mongoose和Jade怎样搭建OAuth2服务器,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。今天我们来看...
    99+
    2024-04-02
  • 亚马逊网络授权服务器
    在使用亚马逊网络授权服务器时,用户需要提供设备的IP地址和用户名,以及AWS账户信息和其他必要的身份验证信息,以便AWS验证他们的设备和用户的身份,并授予他们访问和管理AWS资源和用户账户的权限。此外,用户还需要购买使用AWS网络授权服务器...
    99+
    2023-10-27
    亚马逊 服务器 网络
  • 亚马逊账号授权服务器
    使用亚马逊账号授权服务器,用户可以使用亚马逊AWS账号和密码访问云服务器上的数据和服务。这可以帮助用户更轻松地管理和保护他们的云服务,并且可以在多个位置存储和访问数据。此外,授权服务器还可以提高用户的安全性,防止未经授权的访问和数据泄露。 ...
    99+
    2023-10-27
    亚马逊 账号 服务器
  • 亚马逊云服务器预授权
    预授权会在客户购买云服务器时自动开通,并在客户支付预付费之后生效。客户需要在开通后按照指示进行设置和配置,并等待服务器开通。一旦服务器开通,客户就可以使用云服务器提供的各种功能和服务。 预授权通常涉及到的费用包括预付费和服务费用,客户需要...
    99+
    2023-10-27
    亚马逊 服务器
  • 亚马逊授权服务器怎么设置权限
    登录AWS控制台:首先,在AWS控制台中登录,进入AWS设置页面,选择“控制台”选项卡,并在“控制台概览”中查找“授权”或“授权服务器”选项。 创建实例:在控制台实例下,选择“create instance”,然后单击“create”,在...
    99+
    2023-10-27
    亚马逊 权限 服务器
  • 亚马逊服务器预授权完成
    预授权完成后,用户就可以使用预授权提供的资源,无需支付任何费用。预授权的使用方式取决于您选择的服务和付款方式,但它可以帮助您避免资金损失,因为您可以在预授权期间内获得资源。 在使用亚马逊云服务器时,如果您已经有预授权,可以使用它来完成服务...
    99+
    2023-10-27
    亚马逊 服务器
  • 阿里云服务器授权代理商
    1. 什么是阿里云服务器授权代理商? 阿里云服务器授权代理商是指阿里云官方授权的代理商,可以代理销售阿里云服务器产品,并提供相应的技术支持和服务。代理商可以通过阿里云官方渠道获取产品和服务的最新信息,以及享受阿里云官方提供的技术支持和培训...
    99+
    2023-10-27
    阿里 代理商 服务器
  • 亚马逊授权服务器是什么
    亚马逊授权服务器是一种用于验证和授权亚马逊 Web 服务 (AWS) 客户端请求的服务器。它使用 OAuth 2.0 协议来验证客户端身份并授权其访问 AWS 资源。OAuth 2.0 是一种开放标准,用于授权第三方应用程序访问用户资源,而...
    99+
    2023-10-27
    亚马逊 服务器
  • 腾讯云服务器备案授权码
    下面,我们将介绍几种可以获取腾讯云服务器备案授权码的方式。 第三方代备案服务 许多网站为了方便,都会选择将网站备案托管在第三方代备案服务公司,比如深圳腾讯云备案、北京天擎科技等。这些公司通常会提供专业的备案和托管服务,帮助网站轻松完成...
    99+
    2023-10-27
    腾讯 服务器
  • 阿里云服务器备案授权码
    在申请阿里云服务器备案授权码之前,企业需要先准备好相关的资料,包括企业的营业执照、组织机构代码证、法人身份证等。这些资料需要按照要求进行提交,并通过相关机构的审核。审核通过后,企业才能成功申请到备案授权码。 在申请阿里云服务器备案授权码时...
    99+
    2023-10-28
    阿里 服务器
  • Spring Security 自定义授权服务器实践
    相关文章: OAuth2的定义和运行流程Spring Security OAuth实现Gitee快捷登录Spring Security OAuth实现GitHub快捷登录Spring Secur...
    99+
    2023-09-01
    java 微服务 spring security
  • 取消亚马逊服务器授权流程
    检查账户:首先确保您的账户信息和权限都正确无误,包括注册邮箱、密码、支付方式等。 检查授权:在登录到亚马逊后台之后,仔细检查账户的授权情况,确保已经授权了您需要取消的权限。如果有需要取消的权限,可以直接联系亚马逊客服人员。 取消授权:一旦...
    99+
    2023-10-27
    亚马逊 流程 服务器
  • 亚马逊云服务器erp授权流程
    准备必要的资料:在进行ERP授权之前,您需要准备以下资料: 公司信息:包括公司名称、注册地址、联系人、联系方式等。 产品信息:包括产品名称、型号、规格、价格等。 订单信息:包括订单编号、订单日期、发货地址等。 授权类型:授权类型包括...
    99+
    2023-10-27
    亚马逊 流程 服务器
  • 亚马逊服务器预授权的简介
    1. 什么是亚马逊服务器预授权? 亚马逊服务器预授权(Amazon EC2 Instance Pre-Authorization)是一种允许其他亚马逊 Web 服务(AWS)账户使用您的 EC2 实例的功能。通过预授权,您可以授予其他 A...
    99+
    2023-10-27
    亚马逊 服务器 简介
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作