Spring Cloud集成Security OAuth 2.0权限鉴权验证示例
一、背景说明
目前市场上微服务之间涉及到相互调用的问题,在这个过程中为了验证安全性,需要采用鉴权方式进行管理。目前主流的鉴权方式有Apache Shiro和Spring Security,在这里暂且不讨论Apache Shiro和Spring Security孰优孰劣。本文只讲解Spring Security的集成方式。同时,采用了OAuth 2.0的管理方式,主要基于Token来实现鉴权过程。
Spring Cloud提供了对Spring Security的管理以及OAuth 2.0的集成,方便了我们进行整合使用。
二、项目结构
核心组件:
![Spring Cloud集成Security OAuth 2.0权限鉴权验证示例](http://p2.ttnews.xyz/loading.gif)
Api调用管理,主启动类:
![Spring Cloud集成Security OAuth 2.0权限鉴权验证示例](http://p2.ttnews.xyz/loading.gif)
依赖的jar包,父工程:
核心工程:
引入spring-security-oauth2-autoconfigure
Spring Security OAuth 2.0验证工具:
Spring Boot与Spring Security的集成
Spring Cloud管理Spring Security工具:
Spring Cloud管理OAuth 2.0:
集成Redis及JDBC:
Spring Social工具包:
JWT工具:
API工程:引入核心工程
Spring Boot启动工具及AOP:
引入Spring Boot缓存工具:
三、配置资源服务和认证服务
资源服务是用来配置用户名密码及手机号验证码等相关的用户认证方式的资源过滤路径,以及静态资源路径和相关请求地址设置认证等功能。
认证服务是用来设置认证使用的方式,Redis/JWT等工具,以及客户端id(clientId)和客户端密钥(clientSecret),只有验证通过的clientId和clientSecret才能获取Token。
我们使用继承AuthorizationServerConfigurerAdapter的SsbAuthorizationServerConfig认证服务类:
设置认证方式:
过滤的静态资源文件:
设置登录页:/form/token地址
设置手机认证及静态资源放开权限:
四、通过用户名密码登录获取Token
我们可以正式使用Spring Security OAuth配置用户名和密码登录,也就是表单登录,Spring Security默认有Form登录和Basic登录,我们已经在SsbResourceServerConfig类的configure方法上通过http.formLogin()设置了表单登录
也就是用户名密码登录。其中Spring Security已经实现了表单登录的封装了,我们只需要设置登录成功之后返回的Token就行。我们创建一个继承SavedRequestAwareAuthenticationSuccessHandler的SsbAuthenticationSuccessHandler实现类:
设置OAuth Token:
加密工具:
这样就可以成功的返回Token给前端,因此我们必须放开/form/token请求地址,我们已经在SsbResourceServerConfig类的configure放开了,已经设置了处理成功的ssbAuthenticationSuccessHandler方法,失败处理的ssbAuthenticationFailureHandler处理过程:
我们接下来创建基于UserDetailsService的ApiUserDetailsService类,本来应该在这个类中查询从数据库中的认证信息,在这里没有从数据库查询,代码如下:
给与了admin、ROLE_USER权限
打开PostMan测试
Authorization选择Basic Auth
填写密钥:
密钥为
中设置的密钥
添加至Header
在Body中添加登录用户名、密码
发送请求,返回:
表示认证成功
五、通过手机验证码登录获取Token
首先配置Redis:
打开Redis:
创建四个使用的类:
(1)基于AbstractAuthenticationToken的SmsCodeAuthenticationToken
(2)基于AbstractAuthenticationProcessingFilter的SmsCodeAuthenticationFilter
(3)基于AuthenticationProvider的SmsCodeAuthenticationProvider
(4)基于SecurityConfigurerAdapter的SmsCodeAuthenticationSecurityConfig
通过在资源管理器里面SsbResourceServerConfig添加
手机验证码接入
SmsCodeAuthenticationToken类的代码如下:
SmsCodeAuthenticationFilter的代码如下:
添加认证逻辑
SmsCodeAuthenticationProvider的代码如下:
SmsCodeAuthenticationSecurityConfig的代码如下:
接下来在PostMan里面
其Authorization:
添加进Header:
其Body里面:
发起请求,控制台:
PostMan里面:
验证成功
六、将Token保存到Redis里面
改造一下SsbAuthorizationServerConfig类,添加Redis保存Token:
将RedisTokenStoreConfig新建一下:
在application.properties添加:
我们测试下:
Redis控制台:
已存储至Redis
七、使用JWT生成Token
改造一下SsbAuthorizationServerConfig
接着创建JwtTokenStoreConfig
并且需要创建一个基于Token Handler,添加Token用户信息:
设置一下application.properties:
测试一下
八、本文总结
本文已经使用了Spring Security封装用户表单登录,我们需要使用手机号验证码登录只需要在此基础上集成编写即可
主要工作在SsbResourceServerConfig里面实现了
完成鉴权验证
閱讀更多 李越Java 的文章
關鍵字: 美好,一直在身边 BASIC语言 2019科技之光