栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

2021-09-28

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

2021-09-28

                                       ## SpringBoot整合springSecurity初体验##

Spring 是非常流行和成功的 Java 应用开发框架,Spring Security正是Spring家族中的成员。Spring Security 基于 Spring 框架,提供了一套 Web 应用安全性的完整解决方案。 正如你可能知道的关于安全方面的两个主要区域是“认证”和“授权”(或者访问控制),一般来说,Web 应用的安全性包括用户认证(Authentication)和用户授权(Authorization)两个部分,这两点也是Spring Security重要核心功能。 (1)用户认证指的是:验证某个用户是否为系统中的合法主体,也就是说用户能否访问该系统。用户认证一般要求用户提供用户名和密码。系统通过校验用户名和密码来完成认证过程。通俗点说就是系统认为用户是否能登录 (2)用户授权指的是验证某个用户是否有权限执行某个操作。在一个系统中,不同用户所具有的权限是不同的。比如对一个文件来说,有的用户只能进行读取,而有的用户可以进行修改。一般来说,系统会为不同的用户分配不同的角色,而每个角色则对应一系列的权限。通俗点讲就是系统判断用户是否有权限去做某些事情。
通俗的理解::
其实springSecurity就是用来进行角色权限管理的,就好比买家和卖家,买家的账号只能进行简单的购物之类的,不能进入管理员的后台,这就牵扯到了权限管理
1.1在我看来用springboot来实现springSecurity是真的简单,我虽然没有用过ssm框架来实现springSecurity,但用ssm肯定麻烦,因为会有很多配置文件等你去配置,但是springboot不同,它这个框架给你整合了好多ssm的东西,你不用再花很多时间去配置一些其他的东西。
引入springSecurity的第一步肯定是引入相关的依赖了:

  
            org.springframework.boot
            spring-boot-starter-security
        

1.2:
接下来就是写配置类了:
首先写一个配置类来继承WebSecurityConfigurerAdapter:这个类在我看来就是实现对用户提供安全校验的
里边有两个重要的方法:
1. protected void configure(HttpSecurity http) throws Exception :这个就是在里边可以自定义登录界面,表单提交地址,验证成功后跳转的链接,哪一些地址可以不用进行认证等等具体代码参考;

   //自定义403界面
        http.exceptionHandling().accessDeniedPage("/Default.html");
        http.formLogin()
                .loginPage("/login")//自定义登录界面
                .loginProcessingUrl("/user/login")//表单提交地址
                .defaultSuccessUrl("/success")//登录成功后跳转的链接
                .and().authorizeRequests()
                .antMatchers("/user/login","/login").permitAll()//哪些地址是可以不用认证,一定要放行自定义登录的链接
                .anyRequest().authenticated()//authenticated() 允许认证的用户进行访问
                .and().rememberMe().tokenRepository(persistentTokenRepository())//操作数据库的对象
                .tokenValiditySeconds(120)//以秒为单位,设置记住我的有效时间

                .userDetailsService(userDetailService)
                .and().csrf().disable();//关闭csrf防护

  1. protected void configure(AuthenticationManagerBuilder auth) throws Exception {
    auth.userDetailsService(userDetailService).passwordEncoder(password1());
    } :这个呢通俗来讲就是用于验证用户名密码是否正确。
    .userDetailsService(userDetailService):这里边传入一个userDetailService,
    userDetailService是一个类,它就是实现了一个接口叫:UserDetailsService,这个接口就是对用户信息进行验证的,举例:
 @Autowired
    UserMapper userMapper;
    
    @Override
    public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
        User login = userMapper.login(username);
        if(login==null){
            throw new UsernameNotFoundException("用户名和密码不正确");
        }
        //设置用户权限对应的角色
        List authorities = AuthorityUtils.commaSeparatedStringToAuthorityList(login.getRole());
        return new org.springframework.security.core.userdetails.User(login.getUsername(),new BCryptPasswordEncoder().encode(login.getPassword()),authorities);


里边写的注释也能理解。
configure(AuthenticationManagerBuilder auth) 代码:

 @Override
    protected void configure(AuthenticationManagerBuilder auth) throws Exception {
        auth.userDetailsService(userDetailService).passwordEncoder(password1());
    }

    
    @Bean
    PasswordEncoder password1(){
        return new BCryptPasswordEncoder();
    }
}
最后就是调用数据库进行密码校验了,
还有一个注解就是 @Secured("ROLE_admin")
@Secured("ROLE_admin")
   @ResponseBody
    @RequestMapping("/test")
    public String test(){
       return "Security";
   }

通过代码可以知道,就是要想访问/test的链接,用户就必须要有admin的角色才可以。

暂时就介绍到这里

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/273957.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号