------------恢复内容开始------------
Spring Security简介
Spring Security是spring家族中的一个安全框架,相比与另外一个安全框架Shiro,它提供了更丰富的功能,社区资源也比Shiro丰富
一般来说中大型的项目都是使用spring security来做安全框架,小项目有Shiro的比较多,因为相比与Spring Security,Shiro的上手更加的简单
一般Web应用的需要进行认证和授权
认证:验证当前访问系统的是不是本系统用户,并且要确认具体是哪个用户
授权:经过认证后判断当前用户是否有权限进行某个操作
而认证和授权也是Spring Security作安全框架的核心功能,
快速入门
1.引入Spring Security
在springboot项目中使用Spring Security我们只需要引入依赖即可实现入门案列
引入依赖后我们去访问之前的接口就会自动跳转到Spring Security的默认登录页面,默认用户名user,密码会输出在控制台,必须登录之后才能访问
认证:
登录校验流程
Spring Security完整流程
Spring Security的原理其实就是一个过滤器链,内部包含了提供各种功能的过滤器
图中只展示了核心过滤器,其他的非核心过滤器并没有在图中展示
UsernamePasswordAuthenticationFilter:负责处理我们在登陆页面填写了用户名密码后的登陆请求,入门案例的认证工作主要有它负责(认证)
ExceptionTranslationFilter:处理过滤器链中抛出的任何异常
FilterSecuritylnterceptor:负责权限校验的过滤器(授权)
认证流程
Authentication接口: 它的实现类,表示当前访问系统的用户,封装了用户相关信息
AuthenticationManager接口:定义了认证Authentication的方法
UserDetailsService接口:加载用户特定数据的核心接口。里面定义了一个根据用户名查询用户信息的方法
UserDetails接口:提供核心用户信息。通过UserDetailsService根据用户名获取处理的用户信息要封装成UserDetails对象返回。然后将这些信息封装到Authentication对象中
UsernamePasswordAuthenticationFilter实现类:实现了我们最常用的基于用户名和密码的认证逻辑,封装Authentication对象
DaoAuthenticationProvider实现类:是AuthenticationManager中管理的其中一个Provider,因为是要访问数据库,所以叫Dao
标签:用户名,简介,用户,认证,Spring,过滤器,Security,SpringSecurity From: https://www.cnblogs.com/qihaokuan/p/17370372.html