用springSecurity实现用户登录功能

1.导入springSecurity的坐标

<!--spring security 组件-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-security</artifactId>
</dependency>

2.创建springSecurity的配置类springConfig.java,并继承WebSecurityConfigurerAdapter类。①重写放行静态资源的configure(WebSecurity web)并配置要放行的静态资源,②再重写configure(HttpSecurity http)配置登录的地址、登录成功后的地址、登录成功与失败的逻辑处理类以及配置对登录所需的资源进行放行而对其他任何资源进行登录认证③添加登录的逻辑处理和登录验证、密码加密的方法④重写configure(AuthenticationManagerBuilder auth)方法让springSecurity框架调用登录认证处理和密码加密处理的方法。实现登录校验.

@SpringBootConfiguration
@EnableGlobalMethodSecurity(prePostEnabled = true)
public class SecurityConfig  extends WebSecurityConfigurerAdapter {

   //注入登录成功的处理对象,该类代码文章最后面
   @Autowired
    private JxcAuthenticationSuccessHandler jxcAuthenticationSuccessHandler;


    @Autowired
    private JxcAuthenticationFailedHandler jxcAuthenticationFailedHandler;

     /**
     * 重写放行静态资源的configure(WebSecurity web)方法
     * @param web
     * @throws Exception
     */
    @Override
    public void configure(WebSecurity web) throws Exception {
        web.ignoring().antMatchers(
                "/images/**",
                "/css/**",
                "/js/**",
                "/lib/**",
                "/error/**");
    }
     /**
     * 配置登录地址,登录成功后的地址
     * @param http
     * @throws Exception
     */
    @Override
    protected void configure(HttpSecurity http) throws Exception {
        //禁用csrf
        http.csrf().disable()
            .addFilterBefore(captchaCodeFilter, UsernamePasswordAuthenticationFilter.class)
            // 允许iframe 页面嵌套
            .headers().frameOptions().disable()
            .and()
                .formLogin()//允许表单登录
                .usernameParameter("userName")//登录时的用户参数
                .passwordParameter("password")
                .loginPage("/index")//登录界面
                .loginProcessingUrl("/login") //这是框架提供的登录时访问的地址
                .successHandler(jxcAuthenticationSuccessHandler)//指定登录成功的处理逻辑类
                .failureHandler(jxcAuthenticationFailedHandler)//指定登录失败的处理逻辑类
         
            .and()
                //放行下面的三个登录要用到的请求
                .authorizeRequests().antMatchers("/index","/login","/image").permitAll()
                //对于任何其他请求都进行拦截认证 
                .anyRequest().authenticated();
    }

     /**
     * 用springSecurity提供的登录逻辑处理接口类实现登录逻辑的处理。
     * @return
     */
    @Bean
    public UserDetailsService userDetailsService(){
        return new UserDetailsService() {
            @Override
            public UserDetails loadUserByUsername(String username) throws   UsernameNotFoundException {
                User userDetails = userService.findUserByUserName(username);
                return userDetails;//框架会根据返回的userDetails处理登录的验证
            }
        };
    }

     /**
     * 对密码进行加密的实现方法
     * @return
     */
    @Bean
    public PasswordEncoder encoder(){
        return new BCryptPasswordEncoder();
    }
    
    /**
     * 让框架来调用userDetailsService的实现和密码加密解密的实现
     * @param auth
     * @throws Exception
     */
    @Override
    protected void configure(AuthenticationManagerBuilder auth) throws Exception {
        auth.userDetailsService(userDetailsService()).passwordEncoder(encoder());
    }

}

3.再前端如何获取登录成功的用户信息?

${(Session.SPRING_SECURITY_CONTEXT.authentication.principal.username)!"zeng"}

!"zeng"指如果获取的username为空就设置一个默认值"zeng"

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: SpringSecurity 提供了一种功能强大的机制来实现登录功能,它可以使用 LDAP,数据库,内存等不同的认证源来验证用户的身份。它还支持许多安全特性,如认证失败的重试,多因素认证,强制密码更改,密码恢复,会话管理以及安全响应等。 ### 回答2: 使用Spring Security实现登录功能主要分为以下几个步骤: 1. 引入Spring Security依赖:在项目的`pom.xml`文件中添加Spring Security相关依赖,如`spring-boot-starter-security`。 2. 配置Spring Security:创建一个配置类,如`SecurityConfig`,并标注`@EnableWebSecurity`注解,该注解将开启Spring Security的功能。在配置类中可以通过重写`configure(HttpSecurity http)`方法来配置登录所需的认证规则、URL路径、页面等。 3. 创建用户服务类:创建一个类,如`UserDetailsServiceImpl`,实现`UserDetailsService`接口,并重写其中的`loadUserByUsername(String username)`方法,该方法用于根据用户名从数据库或其他存储方式中获取用户信息。 4. 自定义登录页面:在Spring Security的配置类中配置自定义的登录页面,可以通过重写`configure(HttpSecurity http)`方法中的`loginPage(String loginPage)`指定登录页面的URL路径,并自定义实现该页面。 5. 处理用户认证:在用户登录的时候,Spring Security将会自动调用`UserDetailsService`中的`loadUserByUsername(String username)`方法加载用户信息,并进行认证,验证用户名和密码是否正确。 6. 处理用户授权:需要根据用户的角色或权限来限制用户可以访问的页面或功能,可以通过配置类的`configure(HttpSecurity http)`方法中的`authorizeRequests()`来实现。 7. 添加登录成功和失败的处理器:可以通过自定义实现`AuthenticationSuccessHandler`接口和`AuthenticationFailureHandler`接口来处理登录成功和失败的逻辑。 以上就是使用Spring Security实现登录功能的基本步骤。具体的实现需要根据实际项目的需求进行配置和定制。 ### 回答3: 要使用Spring Security实现登录功能,可以按照以下步骤进行操作: 1. 添加依赖:在项目的pom.xml文件中添加Spring Security的依赖。 2. 配置Spring Security:创建一个继承自WebSecurityConfigurerAdapter的配置类,并使用@EnableWebSecurity注解来启用Spring Security。在配置类中,可以配置认证提供者、用户权限、请求授权等。 3. 添加登录页面:创建一个登录页面,并在登录页面中提供用户名和密码的输入框和登录按钮。 4. 配置认证:在配置类中,重写configure方法,通过AuthenticationManagerBuilder的userDetailsService方法来配置用户认证信息。可以选择使用内存、数据库或其他方式来存储用户信息。 5. 配置登录处理:在配置类中,重写configure方法,通过HttpSecurity的formLogin方法配置登录处理。可以指定登录页面的URL、登录成功和失败的处理URL等。 6. 添加用户权限:如果需要进行请求授权,可以在配置类中通过重写configure方法,使用HttpSecurity的authorizeRequests方法配置请求的权限。可以根据URL、角色或其他条件进行授权。 7. 运行项目:启动项目后,访问登录页面,输入正确的用户名和密码,然后点击登录按钮进行登录。如果登录成功,将根据配置的页面跳转规则进行跳转。 使用Spring Security可以实现简单而强大的登录功能,并且可以根据需求进行灵活的配置和扩展。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值