zoukankan      html  css  js  c++  java
  • springsecurity+jwt 实现前后端分离

    刚开始学习的时候,一直没有找到springsecurity+jwt较好的博客教程,导致我学了很长时间都没学会,后来不断的研究,写下此随笔,供大家参考!
    
    @Configuration
    public class SecurityConfig extends WebSecurityConfigurerAdapter {
    
        @Autowired
        LoginFilter loginFilter;
    
        @Bean
        public PasswordEncoder passwordEncoder() {
            return new BCryptPasswordEncoder();
        }
    
        @Override
        protected void configure(HttpSecurity http) throws Exception {
            http.csrf()
                    .disable()
                    .sessionManagement().sessionCreationPolicy(SessionCreationPolicy.STATELESS)
                    //.formLogin()
                    .and()
                    .authorizeRequests()
                    .antMatchers("/login")
                    .permitAll()
                    .anyRequest()
                    .authenticated();
            http.addFilterBefore(loginFilter, UsernamePasswordAuthenticationFilter.class);
        }
    }
    
    @Component
    public class LoginFilter extends OncePerRequestFilter {
    
        @Autowired
        JwtUtil jwtUtil;
    
        @Autowired
        PasswordEncoder passwordEncoder;
    
    
        @Override
        protected void doFilterInternal(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, FilterChain filterChain) throws ServletException, IOException {
            System.out.println("OncePerRequestFilter");
    
            String token = httpServletRequest.getHeader("token");
            System.out.println(token);
    
    
            if(!jwtUtil.validateToken(token)){
                System.out.println("验证失败");
            }else {
                UserDetails userDetails = loadUserByUsername("admin");
                UsernamePasswordAuthenticationToken authentication = new UsernamePasswordAuthenticationToken(userDetails, null, userDetails.getAuthorities());
                SecurityContextHolder.getContext().setAuthentication(authentication);
                filterChain.doFilter(httpServletRequest, httpServletResponse);
            }
        }
    
    
        public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
            List<GrantedAuthority> authorityList = new ArrayList<>();
            /* 此处查询数据库得到角色权限列表,这里可以用Redis缓存以增加查询速度 */
            authorityList.add(new SimpleGrantedAuthority("ROLE_USER"));
            return new org.springframework.security.core.userdetails.User(username, passwordEncoder.encode("123456"), authorityList);
        }
    }
    
  • 相关阅读:
    CSS基础学习记录——CSS选择器及其特殊性计算
    CSS基础学习记录——CSS中哪些属性可以继承?
    行内框和行框的概念,line-height和vertical-align的关系理解
    【转】DOM中NodeList、HTMLCollection、NamedNodeMap三个动态集合的理解
    property参数讲解
    CocoaPods安装方法
    ios UITextField 以及键盘显示总结
    Xcode11 在Xib中进行UIScrollView布局
    锁问题总结-同一个线程两次获取同一把锁
    【转载】ARM MMU详解
  • 原文地址:https://www.cnblogs.com/botaoJava/p/14392887.html
Copyright © 2011-2022 走看看