Spring Security的认证检验

Spring Security中,认证的请求和未认证的请求的区别主要体现在请求的方式和用户的访问权限。

认证的请求

认证的请求是指用户已经通过身份验证(例如,用户名,密码)并且拥有一个有效的认证令牌(例如,Authentication对象)。这类请求的特点包括:

有一个有效的Authentication对象

  • Spring Security会在用户成功登录后创建一个Authentication对象,并将其存储在安全上下文中(SecurityContext)。
  • 通过调用SecurityContextHolder.getContext().getAuthentication()可以获取当前用户的认证信息。
可以访问受保护的资源
  • 经过认证的用户可以访问受保护的资源和功能,这些资源通常在安全配置中定义。
  • 例如,在HttpSecurity配置中,只有认证用户才能访问/user/**路径
http.authorizeRequests()
    .antMatchers("/user/**").authenticated();

包含用户详细信息和权限

  • Authentication对象中包含了用户的详细信息(如用户名、权限等)。
  • 可以通过Authentication对象获取用户的角色和权限,从而进行访问控制和授权。

未认证的请求

访问受限

  • 未认证的用户只能访问那些在安全配置中明确允许匿名或公开访问的资源。
重定向到登录页面或返回未授权错误
  • 对于未认证用户试图访问受保护资源的请求,Spring Security会自动拦截并引导用户进行身份验证(通常重定向到登录页面)。
  • 例如,未认证用户试图访问/user/profile时会被重定向到登录页面。

处理流程

未认证请求

  • 用户访问受保护的资源。
  • Spring Security检查SecurityContext,发现没有有效的Authentication对象。
  • 根据安全配置,Spring Security引导用户进行身份验证(例如重定向到登录页面)。
  • 用户提交登录表单,Spring Security进行身份验证。
  • 身份验证成功后,Spring Security创建Authentication对象并存储在SecurityContext中。

认证请求

  • 用户访问受保护的资源。
  • Spring Security检查SecurityContext,发现有一个有效的Authentication对象。
  • Spring Security根据用户的角色和权限决定是否允许访问请求的资源。
  • 如果允许,Spring Security将请求转发到目标资源。
  • 如果不允许(例如权限不足),Spring Security返回403 Forbidden错误。
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;

@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http
            .authorizeRequests()
                .antMatchers("/login", "/public/**").permitAll() // 未认证用户可以访问
                .antMatchers("/admin/**").hasRole("ADMIN") // 只有ADMIN角色用户可以访问
                .antMatchers("/user/**").authenticated() // 任何认证用户都可以访问
                .anyRequest().permitAll()
                .and()
            .formLogin()
                .loginPage("/login") // 登录页面
                .permitAll()
                .and()
            .logout()
                .permitAll();
    }
}

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值