SpringBoot.鉴权

简介: 本文介绍如何在Spring Boot项目中结合JWT与Spring Security实现安全鉴权。涵盖Token生成与验证、自定义认证流程、角色权限控制(RBAC),并通过过滤器实现登录拦截与请求认证,保障接口安全。

.鉴权
1.客户端Token方案
1.1 实现思路
简单客户端token校验.vsdx
(57 KB)
1.2 实现细节
参考:https://www.cnblogs.com/dalaoyang/p/11783225.html
2.JWT + Security
RFC7519
JWT
JWT很大程度上还是个新技术,通过使用HMAC(Hash-based Message Authentication Code)计算信息摘要,也可以用RSA公私钥中的私钥进行签名。这个根据业务场景进行选择。
2.1 pom依赖
在/login进行登录并获得Token。剩余接口做token验签,这里我们需要将spring-boot-starter-security加入pom.xml。加入后,我们的Spring Boot项目将需要提供身份验证,相关的pom.xml如下:
至此我们剩余所有的路由都需要身份验证。我们将引入一个安全设置类WebSecurityConfig,这个类需要从WebSecurityConfigurerAdapter类继承。
2.2 安全设置类WebSecurityConfig
先放两个基本类,一个负责存储用户名密码,另一个是一个权限类型,负责存储权限和角色。
2.3 权限类型及角色类
2.4 用户名密码类
在上面的安全设置类中,我们设置所有人都能访问/和POST方式访问/login,其他的任何路由都需要进行认证。然后将所有访问/login的请求,都交给JWTLoginFilter过滤器来处理。稍后我们会创建这个过滤器和其他这里需要的JWTAuthenticationFilter和CustomAuthenticationProvider两个类。
2.5 JWT生成及验签类
这个类就两个static方法,一个负责生成JWT,一个负责认证JWT最后生成验证令牌。注释已经写得很清楚了,这里不多说了。
下面来看自定义验证组件,这里简单写了,这个类就是提供密码验证功能,在实际使用时换成自己相应的验证逻辑,从数据库中取出、比对、赋予用户相应权限。
2.6 自定义验证组件类
2.7 接口类
下面实现JWTLoginFilter 这个Filter比较简单,除了构造函数需要重写三个方法。
attemptAuthentication - 登录时需要验证时候调用
successfulAuthentication - 验证成功后调用
unsuccessfulAuthentication - 验证失败后调用,这里直接灌入500错误返回,由于同一JSON返回,HTTP就都返回200了
2.8 JWTLoginFilter
再完成最后一个类JWTAuthenticationFilter,这也是个拦截器,它拦截所有需要JWT的请求,然后调用TokenAuthenticationService类的静态方法去做JWT验证。
2.9 拦截器JWTAuthenticationFilter
现在代码就写完了,整个Spring Security结合JWT基本就差不多了,下面我们来测试下,并说下整体流程。
开始测试,先运行整个项目,这里介绍下过程:
先程序启动 - main函数
注册验证组件 - WebSecurityConfig 类 configure(AuthenticationManagerBuilder auth)方法,这里我们注册了自定义验证组件
设置验证规则 - WebSecurityConfig 类 configure(HttpSecurity http)方法,这里设置了各种路由访问规则
初始化过滤组件 - JWTLoginFilter 和 JWTAuthenticationFilter 类会初始化
首先测试获取Token,这里使用CURL命令行工具来测试。
2.10 验证
结果:
这里我们得到了相关的JWT,反Base64之后,就是下面的内容,标准JWT。
JSON
复制代码
1
2
{"alg":"HS512"}{"authorities":"ROLE_ADMIN,AUTH_WRITE","sub":"admin","exp":1493782240}ͽ]BS`pS6~hCVH%
ܬ)֝ଖoE5р
整个过程如下:
拿到传入JSON,解析用户名密码 - JWTLoginFilter 类 attemptAuthentication 方法
自定义身份认证验证组件,进行身份认证 - CustomAuthenticationProvider 类 authenticate 方法
盐城成功 - JWTLoginFilter 类 successfulAuthentication 方法
生成JWT - TokenAuthenticationService 类 addAuthentication方法
再测试一个访问资源的:
Shell
运行代码
复制代码
1
curl -H "Content-Type: application/json" -H "Authorization: Bearer eyJhbGciOiJIUzUxMiJ9.eyJhdXRob3JpdGllcyI6IlJPTEVfQURNSU4sQVVUSF9XUklURSIsInN1YiI6ImFkbWluIiwiZXhwIjoxNDkzNzgyMjQwfQ.HNfV1CU2CdAnBTH682C5-KOfr2P71xr9PYLaLpDVhOw8KWWSJ0lBo0BCq4LoNwsKY3-W3avgbJb0jW9FNYDRQ"http://127.0.0.1:8080/users
结果:
JSON
复制代码
1
2
3
4
5
{
"result":["freewolf","tom","jerry"],
"message":"",
"status":0
}
说明我们的Token生效可以正常访问。其他的结果您可以自己去测试。再回到处理流程:
接到请求进行拦截 - JWTAuthenticationFilter 中的方法
验证JWT - TokenAuthenticationService 类 getAuthentication 方法
访问Controller
这样本文的主要流程就结束了,本文主要介绍了,如何用Spring Security结合JWT保护你的Spring Boot应用。如何使用Role和Authority,这里多说一句其实在Spring Security中,对于GrantedAuthority接口实现类来说是不区分是Role还是Authority,二者区别就是如果是hasAuthority判断,就是判断整个字符串,判断hasRole时,系统自动加上ROLE
到判断的Role字符串上,也就是说hasRole("CREATE")和hasAuthority('ROLE_CREATE')是相同的。利用这些可以搭建完整的RBAC体系。本文到此,你已经会用了本文介绍的知识点。

相关文章
|
1月前
|
SQL 人工智能 自然语言处理
业务人员也能用的 AI 数据分析工具?Aloudata Agent “开箱即用”体验报告
不仅提升了个人工作效率,更推动了企业数据民主化进程,让数据真正成为驱动业务增长的核心引擎
|
1月前
|
存储 弹性计算 人工智能
阿里云 8 核 16G 云服务器 ECS 租赁价格收费标准及 CPU 型号详解参考
阿里云 8 核 16G 云服务器 ECS 的租赁价格受实例规格、CPU 型号、购买时长等因素影响,不同配置的官方参考价与优惠后价格存在差异,以下是详细的收费标准及相关说明。阿里云 8 核 16G 云服务器 ECS 凭借丰富的实例规格,搭配不同高性能处理器与优化架构,在计算、存储、网络等核心性能维度表现出色,且适配多种业务场景,同时兼具稳定性与弹性优势,具体性能可从以下几方面结合主流实例规格详细分析:
|
1天前
|
存储 弹性计算 关系型数据库
阿里云服务器及其他云产品免费试用活动解析:160多款产品支持试用,先试后用
阿里云推出涵盖160多款云产品的免费试用活动,覆盖计算、数据库、存储、网络与安全、大数据与AI等全场景。活动包含个人/企业版云服务器ECS(最高8核16G配置)、轻量应用服务器(预装宝塔面板等镜像)、RDS数据库(MySQL/PostgreSQL版)、对象存储OSS等核心产品,提供300元-660元试用金、流量包及企业级规格试用。
61 12
|
1天前
|
人工智能 弹性计算 关系型数据库
2026年阿里云服务器热门配置最新活动价格及优惠购买指南
本文聚焦2026年阿里云服务器热门配置的性价比方案与购买策略。2核2G轻量服务器38元起,适配个人博客及初级开发;2核4G云服务器199元/年,满足初创企业官网及电商基础需求;4核8G、8核16G配置分别以898.20元、5958.52元起,适配中小型企业复杂应用及高并发场景。文章还梳理了新用户优惠、优惠券领取、组合套餐购买、续费策略等省钱技巧,助力用户通过合理规划,以最优性价比获取所需云资源,降低上云成本。
|
2天前
|
存储 弹性计算 人工智能
2026年阿里云学生300元优惠券领取活动详解:获取及使用指南
2026年阿里云针对高校学生群体推出专属300元无门槛优惠券活动,核心用于降低学生上云学习、实践及项目开发的成本,支持抵扣多款公共云产品费用。该优惠券为年度权益,需完成学生身份认证后方可领取,领取后有效期长、使用灵活,但存在明确的身份限制与使用边界。以下结合最新官方规则及实操经验,详细拆解活动核心信息、领取流程、使用方法及避坑要点,帮学生群体精准享受权益。
|
1月前
|
Web App开发 JavaScript 前端开发
SpringBoot.跨域处理
跨域指协议、域名、端口不同时的资源请求限制。本文详解CORS解决方案,包括@CrossOrigin注解、全局配置WebMvcConfigurer及Filter拦截器实现,支持指定域名跨域访问,保障前后端分离架构下安全通信。
66 2
|
1月前
|
JSON Java 数据格式
SpringBoot. 不定参数入参
本文介绍了Java后端接口开发中常见参数接收方式,包括非JSON格式的不定参数、基本类型传参,以及JSON格式的JSONObject解析和封装对象入参。重点讲解了@RequestBody、@RequestParam等注解的使用场景,并结合@Valid实现参数校验,提升接口安全性与稳定性。
59 2
|
1月前
|
XML Java 数据格式
SpringBoot. 打包
将项目打包为单一JAR文件,包含配置文件,通过`mvn clean package`命令构建。运行时可前台或后台启动:`java -jar **.jar` 或 `nohup java -jar **.jar`;停止服务需查找进程PID并执行`kill -9 pid`。也可分离JAR、依赖与配置文件以方便管理。
46 0
|
5月前
|
JSON 监控 API
抖音视频详情API秘籍!轻松获取视频详情数据
抖音视频详情API是抖音开放平台的核心接口,通过视频ID可获取包括标题、播放量、点赞数、评论等50多个字段,适用于内容分析、竞品监控和广告评估等场景。接口支持HTTP GET请求,返回JSON格式数据,便于解析处理。文中还提供了使用Python调用该接口的示例代码,包含请求发送、认证、响应处理等功能,帮助开发者快速获取视频数据。
1170 5