spring security概述

本文介绍了Spring Security中的过滤器机制,包括各个内置过滤器的作用及执行顺序。从ChannelProcessingFilter到FilterSecurityInterceptor,详细阐述了如何通过这些过滤器实现认证与授权。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

     spring security由一堆的filter组成,每个filter之间的实现是独立的。而且你可以修改里面的filter,或者写自己的filter。当然了,你修改得越多,也就越失去了使用它的意义。

 

 

内置的filter列表及执行顺序:

  • ChannelProcessingFilter, 用于选择channel,也就是httphttps的选择。

  • SecurityContextPersistenceFilter, 用于将用户相关的信息保存到上下文中,以及session中。比如用户名,权限列表等。这个是必须的,如果没有这个filter,登陆之后的下一次请求,spring security无法获知请求者是谁,拥有什么权限。

  • ConcurrentSessionFilter, 常用于限制用户只能在一个地方登陆。

  • AuthenticationFilter,用于认证,spring提供了很多的登陆filter,可根据项目情况自己选择一种,对于大多数web项目, UsernamePasswordAuthenticationFilter是最适合的。因为大多数认证都是根据用户名、密码进行认证的,而用户名、密码又是存储在数据库中。UsernamePasswordAuthenticationFilter跟数据库结合非常方便,只要自己实现一个userDetailService就可以。

  • SecurityContextHolderAwareRequestFilter

  • JaasApiIntegrationFilter

  • RememberMeAuthenticationFilter, filter用于记住用户名、密码,下次不用再次登陆。但是它要跟UsernamePasswordAuthenticationFilter配合才行,如果AuthenticationFilter用的不是UsernamePasswordAuthenticationFilter,那么它就发挥不了作用。

  • AnonymousAuthenticationFilter如果存在可以匿名访问的资源,就需要配置这个拦截器。

  • ExceptionTranslationFilter捕获认证失败或验权失败的异常。并导航到相应的页面

  • FilterSecurityInterceptor对于web项目,这个是最重要的Filter,用于验权。

  1.  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值