我的编程空间,编程开发者的网络收藏夹
学习永远不晚

java构建OAuth2授权服务器

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

java构建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授权服务器内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

java构建OAuth2授权服务器

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

java中怎么构建一个OAuth2授权服务器

今天就跟大家聊聊有关java中怎么构建一个OAuth2授权服务器,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。构建 OAuth3 授权服务器从表现形式上看,OAuth3 授权服务器也
2023-06-20

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
2023-08-18

亚马逊账号授权服务器

使用亚马逊账号授权服务器,用户可以使用亚马逊AWS账号和密码访问云服务器上的数据和服务。这可以帮助用户更轻松地管理和保护他们的云服务,并且可以在多个位置存储和访问数据。此外,授权服务器还可以提高用户的安全性,防止未经授权的访问和数据泄露。
2023-10-27

亚马逊网络授权服务器

在使用亚马逊网络授权服务器时,用户需要提供设备的IP地址和用户名,以及AWS账户信息和其他必要的身份验证信息,以便AWS验证他们的设备和用户的身份,并授予他们访问和管理AWS资源和用户账户的权限。此外,用户还需要购买使用AWS网络授权服务器的许可证,以便在需要时获得AWS的访问权限。需要注意的是,使用亚马逊网络授权服务器可能会导致安全风险,因此建议用户遵守相关的安全建议和准则,并始终保持警惕。
2023-10-27

亚马逊云服务器预授权

预授权会在客户购买云服务器时自动开通,并在客户支付预付费之后生效。客户需要在开通后按照指示进行设置和配置,并等待服务器开通。一旦服务器开通,客户就可以使用云服务器提供的各种功能和服务。预授权通常涉及到的费用包括预付费和服务费用,客户需要在开通前了解相关的费用和收费标准。如果客户发现开通预授权后需要支付额外的费用,可以通过与亚马逊客服联系,了解是否有其他可用的付款方式和退款政策。
2023-10-27

亚马逊授权服务器怎么设置权限

登录AWS控制台:首先,在AWS控制台中登录,进入AWS设置页面,选择“控制台”选项卡,并在“控制台概览”中查找“授权”或“授权服务器”选项。创建实例:在控制台实例下,选择“createinstance”,然后单击“create”,在“创建实例”对话框中填写实例的名称、AWSID和实例所属的组等信息。单击“确定”按钮
2023-10-27

阿里云服务器授权代理商

1.什么是阿里云服务器授权代理商?阿里云服务器授权代理商是指阿里云官方授权的代理商,可以代理销售阿里云服务器产品,并提供相应的技术支持和服务。代理商可以通过阿里云官方渠道获取产品和服务的最新信息,以及享受阿里云官方提供的技术支持和培训。2.阿里云服务器授权代理商的优势作为阿里云服务器授权代理商,您可以享受以下优势:2.1产品和服务的最新信息阿里云官方会定期向代理商提供产品和服务的最新信息,包括产品的功能、...
2023-10-27

亚马逊服务器预授权完成

预授权完成后,用户就可以使用预授权提供的资源,无需支付任何费用。预授权的使用方式取决于您选择的服务和付款方式,但它可以帮助您避免资金损失,因为您可以在预授权期间内获得资源。在使用亚马逊云服务器时,如果您已经有预授权,可以使用它来完成服务器配置和测试。如果您还没有预授权,可以在完成服务器配置和测试后前往亚马逊官方网站注册并创建预授权。
2023-10-27

阿里云服务器备案授权码

在申请阿里云服务器备案授权码之前,企业需要先准备好相关的资料,包括企业的营业执照、组织机构代码证、法人身份证等。这些资料需要按照要求进行提交,并通过相关机构的审核。审核通过后,企业才能成功申请到备案授权码。在申请阿里云服务器备案授权码时,企业需要提供真实有效的资料,这些资料需要真实、准确、完整,并且需要符合阿里云服务器
阿里云服务器备案授权码
2023-10-28

腾讯云服务器备案授权码

下面,我们将介绍几种可以获取腾讯云服务器备案授权码的方式。第三方代备案服务许多网站为了方便,都会选择将网站备案托管在第三方代备案服务公司,比如深圳腾讯云备案、北京天擎科技等。这些公司通常会提供专业的备案和托管服务,帮助网站轻松完成备案和托管服务。获取腾讯云服务器备案授权码的第一步是前往腾讯云官网进行备案申请。在网站主页
2023-10-27

亚马逊授权服务器是什么

亚马逊授权服务器是一种用于验证和授权亚马逊Web服务(AWS)客户端请求的服务器。它使用OAuth2.0协议来验证客户端身份并授权其访问AWS资源。OAuth2.0是一种开放标准,用于授权第三方应用程序访问用户资源,而无需共享用户凭据。在AWS中,授权服务器用于生成访问令牌,这些令牌用于访问AWS资源,例如AmazonS3存储桶或AmazonEC2实例。授权服务器使用AWSIdentityandAccessManagement(IAM)来管理用户和角...
2023-10-27

亚马逊账号授权服务器错误

权限不足:如果您没有正确配置授权文件,那么您的账号将无法访问受限资源。账号过期:如果您的账号过期了,您需要重新授权才能访问受限资源。账号不存在:如果您的账号不存在,那么您需要先创建一个新账号才能访问受限资源。为了解决这个问题,您可以按照以下步骤操作:确认您的账号是否已经配置授权文件。您可以在亚马逊控制台中查看该账号的相关配置信息。检查您的账号是否已经过期。如果您的账号已经过期,那么您需要重新授权才...
2023-10-27

阿里云服务器授权远程连接

#本文将介绍如何在阿里云服务器上实现授权远程连接,帮助用户更加安全地管理服务器和远程操作。通过了解授权远程连接的概念、原理以及阿里云提供的相关功能,用户可以更好地保护服务器安全,提升工作效率。1.授权远程连接概念与原理授权远程连接是指在服务器上设置访问控制,只有被授权的用户或IP地址才能进行远程连接和操作。这样做
阿里云服务器授权远程连接
2024-01-21

亚马逊云服务器erp授权流程

准备必要的资料:在进行ERP授权之前,您需要准备以下资料:公司信息:包括公司名称、注册地址、联系人、联系方式等。产品信息:包括产品名称、型号、规格、价格等。订单信息:包括订单编号、订单日期、发货地址等。授权类型:授权类型包括:普通授权、限制授权、永久授权等。授权费用:根据您的实际情况,需要了解授权费用以及您的支付方式。在亚马逊云服务器上创建授权:在您的本地服务器上,打开“AmazonKeyManager”,然后...
2023-10-27

取消亚马逊服务器授权流程

检查账户:首先确保您的账户信息和权限都正确无误,包括注册邮箱、密码、支付方式等。检查授权:在登录到亚马逊后台之后,仔细检查账户的授权情况,确保已经授权了您需要取消的权限。如果有需要取消的权限,可以直接联系亚马逊客服人员。取消授权:一旦确认所有授权都已经取消,就可以联系亚马逊客服人员取消授权。如果您是因为其他原因需要取消授权,可以联系亚马逊客服人员说明情况,客服人员会为您提供取消授权的方法。需要注意...
2023-10-27

编程热搜

目录