SpringSecurity安全框架简介

这篇具有很好参考价值的文章主要介绍了SpringSecurity安全框架简介。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

框架介绍

Spring Security是Spring全家桶的成员,官方对它的介绍是:

Spring Security 是一个功能强大且高度可定制的身份验证和访问控制框架。
它是保护基于 Spring 的应用程序的事实标准。
Spring Security 是一个专注于为 Java 应用程序提供身份验证和授权的框架。
与所有 Spring 项目一样,Spring Security 的真正强大之处在于它可以轻松扩展以满足自定义需求。

从介绍里可以看出,Spring Security是一个可定制扩展的框架,它主要提供了身份验证和访问控制功能。而这两个功能也是基于框架的扩展机制开发的,下面让我们一起了解一下Spring Security的基本概念和扩展机制的实现原理。

基本概念

要了解Spring Security内部的运行机制,要先了解它包含的基本概念,以及对应的功能。下面是Spring Security主要的概念:

  • 安全过滤器:Spring Security通过向Servlet注册一个Filter来拦截请求,所以Spring Security要提供自己的过滤器。
  • 安全过滤器配置类:为安全过滤器提供统一的配置管理,配置类是WebSecurity
  • 过滤器链:过滤器链是为了支持应用在不同业务场景有不同的安全规则需求。一个应用可以注册多个过滤器链,一个过滤器链包含多个过滤器,一个请求会经过所有的过滤器链。
  • 过滤器链配置类:为过滤器链提供统一的配置管理,并支持DSL的方式来描述配置,配置类是HttpSecurity
  • 业务过滤器:业务过滤器会注册到过滤器链,实现功能的插拔。
  • 业务过滤器配置类:用来初始化和注册业务过滤器,也可直接注册业务过滤器。
  • 认证:是指验证用户的身份是否合法。Spring Security 提供了多种认证方式,如基于用户名和密码的认证、基于证书的认证、LDAP 认证、OpenID 认证等。
  • 授权:是指根据用户的身份和角色,决定其是否有权访问应用程序的资源。Spring Security 支持基于角色的授权、基于表达式的授权等多种授权方式。

扩展原理

Spring Security的功能是基于Filter来实现,当一个请求进来,会通过全局的安全过滤器判断,当前请求Spring Security是否需要拦截。如果需要拦截,那么请求会流入过滤器链,交给过滤链的过滤器来处理。

业务过滤器可以选择跳过请求、执行操作、结束请求、将请求交给下一个过滤器。不同的过滤器就实现了不同的功能,我们以认证功能为例,简单介绍它们的实现原理。

Spring Security默认提供了基于用户名和密码的认证的功能,实现这个功能的Filter是UsernamePasswordAuthenticationFilter,从名字就可以看出它的功能。Spring Security会判断当前请求是不是登录的请求,是的话UsernamePasswordAuthenticationFilter会在请求体里拿到用户名和密码,走一遍校验的流程,得到一个Authentication 对象来记录用户名和认证结果,并且会把信息存到安全上下文里。

后面访问其它接口时,校验权限的Filter里判断当前Authentication 对象能否访问资源。如果没有权限,就会抛出AccessDeniedException 异常。异常处理的Filter会处理Spring Security抛出的异常,给用户合适的反馈。

所以,Spring Security的认证功能是通过认证(AuthenticationFilter)、授权(AuthorizationFilter)、异常处理(ExceptionTranslationFilter)三个Filter配合实现。通过组合不同的Filter,还能实现session管理、CSRF拦截等功能。

框架包含的功能

Spring Security框架默认提供了一些Filter,来实现对应用程序的安全保护。下面简单介绍一下各个Filter的功能:

  • DisableEncodeUrlFilter:禁止对URL进行编码,为了禁止在URL里包含session id。在某些无法使用cookie的情况,会将session id放在URL里。
  • WebAsyncManagerIntegrationFilter:提供异步请求的支持。
  • SecurityContextHolderFilter:获取安全上下文。
  • HeaderWriterFilter:在响应头上加些安全的头标识。
  • CsrfFilter:提供CSRF保护。
  • LogoutFilter:提供认证登出逻辑。
  • UsernamePasswordAuthenticationFilter:提供基于用户名和密码的认证方式。
  • DefaultLoginPageGeneratingFilter:生成默认登录页。
  • DefaultLogoutPageGeneratingFilter:生成默认登出页。
  • BasicAuthenticationFilter:提供基于Basic的认证方式。
  • RequestCacheAwareFilter:提供请求缓存功能,用户请求出发登录认证,在认证成功之后,继续处理之前的请求,所以要保存之前请求的数据。
  • SecurityContextHolderAwareRequestFilter:通过Spring Security实现HttpServletRequest里Servlet3.0新增的authenticate()、login()、logout()这些方法。
  • AnonymousAuthenticationFilter:提供匿名请求的处理逻辑。
  • ExceptionTranslationFilter:提供异常处理逻辑。
  • AuthorizationFilter:提供授权相关的逻辑。

安全配置

Spring Security允许用户为框架提供配置信息,来定制安全策略。一般情况,我们只需关注两个配置对象:

  • WebSecurity
  • HttpSecurity

Spring Security6.0版本在配置方式上做了很大改动,支持用户通过提供Bean来设置配置,删除了基于WebSecurityConfigurerAdapter的配置方式。

WebSecurity

WebSecurity用来配置安全过滤器,配置对所有请求都生效。Spring Security6.0推荐的配置方式是注册一个WebSecurityCustomizer的Bean。

@Configuration
public class SecurityConfiguration {

    @Bean
    public WebSecurityCustomizer webSecurityCustomizer() {
        return (web) -> web.ignoring().antMatchers("/ignore1", "/ignore2");
    }

}

下面这种方式已经失效!下面这种方式已经失效!下面这种方式已经失效!

@Configuration
public class SecurityConfiguration extends WebSecurityConfigurerAdapter {

    @Override
    public void configure(WebSecurity web) {
        web.ignoring().antMatchers("/ignore1", "/ignore2");
    }

}

HttpSecurity

HttpSecurity用来配置过滤链,配置对当前过滤链里的请求生效。Spring Security6.0推荐的配置方式是注册一个SecurityFilterChain的Bean。

@Configuration
public class SecurityConfiguration {

    @Bean
    public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
        http
            .authorizeHttpRequests((authz) -> authz
                .anyRequest().authenticated()
            )
            .httpBasic(withDefaults());
        return http.build();
    }

}

下面这种方式已经失效!下面这种方式已经失效!下面这种方式已经失效!

@Configuration
public class SecurityConfiguration extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http
            .authorizeHttpRequests((authz) -> authz
                .anyRequest().authenticated()
            )
            .httpBasic(withDefaults());
    }

}

总结

我们介绍了Spring Security的基本概念和常见功能,分析了Spring Security扩展机制的实现原理,最后对比了Spring Security6.0的一些改动。可见,使用Spring Security我们通过提供自己的业务过滤器,很容易实现功能的扩展。文章来源地址https://www.toymoban.com/news/detail-720396.html

到了这里,关于SpringSecurity安全框架简介的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • SpringSecurity安全框架 ——认证与授权

    目录  一、简介 1.1 什么是Spring Security 1.2 工作原理 1.3 为什么选择Spring Security 1.4 HttpSecurity 介绍🌟 二、用户认证 2.1 导入依赖与配置 2.2 用户对象UserDetails 2.3 业务对象UserDetailsService 2.4 SecurityConfig配置 2.4.1 BCryptPasswordEncoder密码编码器 2.4.2 RememberMe 记住登录信息 2.4.3 CSR

    2024年02月04日
    浏览(44)
  • SpringSecurity分布式安全框架

    Spring Security是一个基于Spring框架的安全框架,它提供了全面的安全解决方案,包括用户认证和用户授权等Web应用安全性问题。Spring Security可以轻松扩展以满足自定义需求,它的真正强大之处在于它可以轻松扩展以满足自定义要求。 对于分布式系统来说,Spring Security可以结合

    2024年02月08日
    浏览(49)
  • SpringBoot集成 SpringSecurity安全框架

    提示:以下是本篇文章正文内容,Java 系列学习将会持续更新 我们时常会在 QQ 上收到别人发送的钓鱼网站链接,只要你在登录QQ账号的情况下点击链接,那么不出意外,你的号已经在别人手中了。实际上这一类网站都属于 恶意网站 ,专门用于盗取他人信息,执行非法操作,

    2024年02月07日
    浏览(50)
  • SpringSecurity安全框架学习——@PreAuthorize的实现原理

    首先我们打开@PreAuthorize注解的源码,然后按住Ctrl并单击PreAuthorize,可以看到在EnableMethodSecurity注解中有引用 (本文使用IDEA,后续不再复述) 查看EnableMethodSecurity源码,可以到,其引用了MethodSecuritySelector 按照惯例,打开MethodSecuritySelector 可以看到,当prePostEnabled=true时,会注

    2023年04月16日
    浏览(39)
  • 【Java-框架-SpringSecurity】随笔

    项目文件; 【1】 【2】 【3】 【4】 【5】 【6】 【7】

    2024年01月18日
    浏览(43)
  • SpringSecurity框架学习与使用

    引入相关的依赖,SpringBoot的版本是2.7.10; 前端页面编写,home.html、hello.html、login.html hello.html home.html login.html 视图控制,访问对应的url跳转到不同的页面 SpringSecurity配置 结果 登录失败时 登录成功 认证 上面的demo中,我们是把登录密码放在内存中记录着的,除了这种方式外我

    2024年02月02日
    浏览(37)
  • SpringSecurity框架快速搭建(SpringBoot整合Security)

    目录 Common类 Config类 CorsConfig(解决跨域问题) RedisConfig (Redis数据库配置) Spring Security (配置安全功能的类) expression类(Expression 类通常用于权限控制和安全策略的定义) SGExpressionRoot(判断用户是否具有某个权限) Filter类 JwtAuthenticationTokenFilter(解析token看是否放行) Handler类

    2024年02月09日
    浏览(44)
  • SpringSecurity安全授权

    目录 前言 正文 1.基本流程 2.基本用法 3.配置项  4.HttpSecurity 方式和内存认证方式  5.认证流程 6.基于数据库查询的登录验证 7.多种角色权限认证  8.自定义权限认证  总结 安全对于任何系统来说都是非常重要的,权限的分配和管理一直都是开发者需要特别重视的。一旦缺乏基

    2024年02月04日
    浏览(32)
  • Spring Security详细讲解(JWT+SpringSecurity登入案例)

    1.SpringSecurity SpringSecurity 是一个功能强大且高度可定制的身份验证和访问控制框架 。它是保护基于 Spring 的应用程序的事实上的标准。 SpringSecurity 是一个致力于为 Java 应用程序提供身份验证和授权的框架 。像所有 Spring 项目一样,Spring Security 的真正强大之处在于它可以如何轻

    2024年02月02日
    浏览(47)
  • 【 SpringSecurity】第三方认证&方法级别安全

    在登录网页时,时常有用其他账号登录的方式,它们能够让用户避免在Web站点特定的登录页上自己输入凭证信息。这样的Web站点提供了一种通过其他网站(如Facebook)登录的方式,用户可能已经在这些其他的网站登录过了 这种类型的认证是基于OAuth2或OpenID Connect(OIDC)的。OAut

    2024年02月13日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包