news 2026/4/23 18:51:50

SpringSecurity核心源码剖析+jwt+OAuth(一):SpringSecurity的初次邂逅(概念、认证、授权)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SpringSecurity核心源码剖析+jwt+OAuth(一):SpringSecurity的初次邂逅(概念、认证、授权)

SpringSecurity 核心概念

SpringSecurity 是一个功能强大且高度可定制的身份验证和访问控制框架,专注于为 Java 应用程序提供安全性。其核心功能围绕身份验证(Authentication)和授权(Authorization)展开。

身份验证是确认用户身份的过程,通常通过用户名密码、OAuth2、JWT 等方式实现。授权是确定已验证用户拥有哪些权限,例如访问特定资源或执行某些操作。

认证流程剖析

SpringSecurity 的认证流程主要由一系列过滤器链组成。核心过滤器包括UsernamePasswordAuthenticationFilter(处理表单登录)、BasicAuthenticationFilter(处理 HTTP Basic 认证)等。认证过程最终由AuthenticationManager协调,委托给ProviderManager和具体的AuthenticationProvider实现。

认证成功后,会生成Authentication对象并存入SecurityContextHolder,供后续授权流程使用。默认使用ThreadLocal存储安全上下文,确保线程安全。

授权机制解析

授权通过AccessDecisionManager实现,核心策略包括:

  • 基于投票的AffirmativeBased(一票通过即可)
  • 一致性通过的UnanimousBased(全部投票通过)
  • 多数通过的ConsensusBased

权限判断通常使用hasRole()hasAuthority()等表达式,或通过注解如@PreAuthorize实现方法级安全控制。配置示例:

http.authorizeRequests() .antMatchers("/admin/**").hasRole("ADMIN") .antMatchers("/user/**").hasAnyRole("USER", "ADMIN") .anyRequest().authenticated();

JWT 集成实践

JWT(JSON Web Token)是一种无状态的认证方案,适合分布式系统。集成步骤:

创建 JWT 工具类处理令牌生成/验证:

public class JwtTokenUtil { private String secret = "your-secret-key"; public String generateToken(UserDetails userDetails) { return Jwts.builder() .setSubject(userDetails.getUsername()) .setIssuedAt(new Date()) .setExpiration(new Date(System.currentTimeMillis() + 3600*1000)) .signWith(SignatureAlgorithm.HS512, secret) .compact(); } public Boolean validateToken(String token, UserDetails userDetails) { final String username = extractUsername(token); return (username.equals(userDetails.getUsername()) && !isTokenExpired(token)); } }

配置 JWT 过滤器:

public class JwtRequestFilter extends OncePerRequestFilter { @Override protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain chain) { String token = extractToken(request); if (token != null && jwtUtil.validateToken(token, userDetails)) { UsernamePasswordAuthenticationToken auth = new UsernamePasswordAuthenticationToken( userDetails, null, userDetails.getAuthorities()); SecurityContextHolder.getContext().setAuthentication(auth); } chain.doFilter(request, response); } }

OAuth2 集成方案

SpringSecurity 提供完整的 OAuth2 支持,包括客户端和资源服务器配置:

资源服务器配置示例:

@EnableResourceServer @Configuration public class OAuth2ResourceServerConfig extends ResourceServerConfigurerAdapter { @Override public void configure(HttpSecurity http) throws Exception { http.authorizeRequests() .antMatchers("/api/**").authenticated(); } @Override public void configure(ResourceServerSecurityConfigurer resources) { resources.tokenServices(tokenServices()); } @Bean public TokenStore tokenStore() { return new JwtTokenStore(accessTokenConverter()); } @Bean public JwtAccessTokenConverter accessTokenConverter() { JwtAccessTokenConverter converter = new JwtAccessTokenConverter(); converter.setSigningKey("shared-secret"); return converter; } }

客户端配置示例:

@EnableOAuth2Client @Configuration public class OAuth2ClientConfig { @Bean public OAuth2RestTemplate oauth2RestTemplate( OAuth2ClientContext oauth2ClientContext, OAuth2ProtectedResourceDetails details) { return new OAuth2RestTemplate(details, oauth2ClientContext); } }

安全配置最佳实践

生产环境建议配置:

  • 启用 CSRF 防护(对于有状态的 web 应用)
  • 配置 CORS 策略
  • 强制 HTTPS
  • 设置严格的内容安全策略
  • 使用安全密码编码器:
@Bean public PasswordEncoder passwordEncoder() { return new BCryptPasswordEncoder(); }

典型安全配置示例:

@EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http .csrf().ignoringAntMatchers("/api/**") .and() .sessionManagement() .sessionCreationPolicy(SessionCreationPolicy.STATELESS) .and() .addFilterBefore(jwtFilter(), UsernamePasswordAuthenticationFilter.class) .authorizeRequests() .antMatchers("/auth/**").permitAll() .anyRequest().authenticated(); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 5:21:55

零代码部署ChatGLM3-6B:Streamlit重构版体验

零代码部署ChatGLM3-6B:Streamlit重构版体验 1. 为什么这次部署真的“零代码”? 你有没有试过部署一个大模型,结果卡在环境冲突上整整两天?pip install 报错、torch版本打架、transformers tokenizer突然不认字……这些不是段子…

作者头像 李华
网站建设 2026/4/23 10:05:10

YOLOv10导出ONNX全流程,支持简化与优化

YOLOv10导出ONNX全流程,支持简化与优化 在目标检测工程落地过程中,模型部署常面临一个现实困境:训练效果再好,若无法高效、稳定地集成进生产系统,就只是实验室里的“纸上谈兵”。YOLOv10作为首个真正实现端到端无NMS设…

作者头像 李华
网站建设 2026/4/15 15:51:49

智能抢票神器:如何让你在10秒内锁定演唱会门票?

智能抢票神器:如何让你在10秒内锁定演唱会门票? 【免费下载链接】DamaiHelper 大麦网演唱会演出抢票脚本。 项目地址: https://gitcode.com/gh_mirrors/dama/DamaiHelper 还在为抢不到热门演唱会门票而彻夜难眠吗?当你对着电脑屏幕疯狂…

作者头像 李华
网站建设 2026/4/22 0:18:04

HY-Motion 1.0快速上手:5分钟完成文生3D动作本地部署

HY-Motion 1.0快速上手:5分钟完成文生3D动作本地部署 你有没有试过,只用一句话就让一个3D角色“活”起来?比如输入“一个人单膝跪地,缓缓举起右手敬礼”,几秒钟后,一段自然流畅的骨骼动画就生成了——不是…

作者头像 李华
网站建设 2026/4/18 19:12:20

实测OpenAI新开源模型,网页推理流畅度超出预期

实测OpenAI新开源模型,网页推理流畅度超出预期 最近在CSDN星图镜像广场上看到一个新上架的AI镜像——gpt-oss-20b-WEBUI,标着“vllm网页推理,OpenAI开源”。说实话,第一眼看到时我有点怀疑:OpenAI真开源了&#xff1f…

作者头像 李华
网站建设 2026/4/19 18:27:15

DCT-Net人像卡通化镜像可持续性:模型权重增量更新与版本管理

DCT-Net人像卡通化镜像可持续性:模型权重增量更新与版本管理 1. 为什么需要关注卡通化镜像的“可持续性” 很多人第一次用DCT-Net人像卡通化镜像时,只关心一件事:上传照片,点一下,出图——快不快?像不像&…

作者头像 李华