zoukankan      html  css  js  c++  java
  • 9、Spring Boot安全

    1.Spring Security简介

      Spring Security是针对Spring项目的安全框架,也是Spring Boot底层安全模块默认的技术选型。他可以实现强大的web安全控制。对于安全控制,我们仅需引入spring-boot-starter-security模块,进行少量的配置,即可实现强大的安全管理。

      WebSecurityConfigurerAdapter:自定义Security策略

      AuthenticationManagerBuilder:自定义认证策略

      @EnableWebSecurity:开启WebSecurity模式

      应用程序的两个主要区域是'认证'和'授权'(或者访问控制)。

      '认证'和'授权'主要区域是Spring Security 的两个目标。

      认证(Authentication),是建立一个他声明的主体的过程(一个'主体'一般是指用户,设备或一些可以在你的应用程序中执行动作的其他系统)

      '授权'(Authorization)指确定一个主体是否允许在你的应用程序执行一个动作的过程。为了抵达需要授权的店,主体的身份已经有认证过程建立。

    2.Spring Security使用

    (1).创建工程

     

    (2).引入SpringSecurity

    <!--security-->

    <dependency>

       <groupId>org.springframework.boot</groupId>

       <artifactId>spring-boot-starter-security</artifactId>

    </dependency>

    (3).导入文件

    (4).SpringSecurity配置类

      HttpSecurity配置登陆、注销功能

    package com.hosystem.security.config;

     

    import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;

    import org.springframework.security.config.annotation.web.builders.HttpSecurity;

    import org.springframework.security.config.annotation.web.builders.WebSecurity;

    import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;

    import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;

    import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;

     

    @EnableWebSecurity

    public class MySecurityConfig extends WebSecurityConfigurerAdapter{

     

        //定义授权规则

        @Override

        protected void configure(HttpSecurity http) throws Exception {

    //        super.configure(http);

     

            //定制请求的授权规则

            http.authorizeRequests().antMatchers("/").permitAll()

                    .antMatchers("/level1/**").hasRole("VIP1")

                    .antMatchers("/level2/**").hasRole("VIP2")

                    .antMatchers("/level3/**").hasRole("VIP3");

     

            //开启自动配置登录功能

            http.formLogin();

            //1. /login到登录页

            //2. 重定向到/login?error表示登录失败

            //3. 更多详细规定

        }

     

        //定义认证规则

        @Override

        protected void configure(AuthenticationManagerBuilder auth) throws Exception {

    //        super.configure(auth);

     

            auth.inMemoryAuthentication().passwordEncoder(new BCryptPasswordEncoder())

                    .withUser("tom").password(new BCryptPasswordEncoder().encode("123456")).roles("VIP1","VIP2")

                    .and()

                    .withUser("jack").password(new BCryptPasswordEncoder().encode("123456")).roles("VIP2","VIP3")

                    .and()

                    .withUser("lucy").password(new BCryptPasswordEncoder().encode("123456")).roles("VIP1","VIP3");

     

     

        }

    }

    注:如果出现There is no PasswordEncoder mapped for the id “null”

        或者 Encoded password does not look like bcrypt(Bad credentials)基本都是springsecurity版本的问题。只需要使用passwordEncoder(new BCryptPasswordEncoder())替换原来的即可。

    #老版本springsecurity

    auth.inMemoryAuthentication().withUser("user").password("123456").roles("VIP1");

     

    #新版本springsecurity

    auth.inMemoryAuthentication().passwordEncoder(new BCryptPasswordEncoder())

            .withUser("tom").password(new BCryptPasswordEncoder().encode("123456")).roles("VIP1","VIP2");

    (5).Thymeleaf提供的SpringSecurity标签支持

    [1].引入thymeleaf-extras-springsecurity5

    <!--springsecurity5-->

    <dependency>

       <groupId>org.thymeleaf.extras</groupId>

       <artifactId>thymeleaf-extras-springsecurity5</artifactId>

    </dependency>

    [2].sec:authorize使用

    <!DOCTYPE html>

    <html xmlns:th="http://www.thymeleaf.org"

         xmlns:sec="http://www.thymeleaf.org/thymeleaf-extras-springsecurity5">

    <head>

    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

    <title>Insert title here</title>

    </head>

    <body>

    <h1 align="center">欢迎光临武林秘籍管理系统</h1>

    <div sec:authorize="!isAuthenticated()">

       <h2 align="center">游客您好,如果想查看武林秘籍 <a th:href="@{/login}">请登录</a></h2>

    </div>

    <div sec:authorize="isAuthenticated()">

       <h2><span sec:authentication="name"></span>,你好,你的角色有:

          <span sec:authentication="principal.authorities"></span></h2>

       <form th:action="@{/logout}" method="post">

          <input type="submit" value="注销"

  • 相关阅读:
    Android碰到的怪问题
    Linux转换文件格式
    Android 打包签名 从生成keystore到完成签名
    重写SimpleCursorAdapter
    sqlite的数据导入 导出
    日语单词检索WebService 账户API和示例更新
    日语单词检索 WebService 试运行 和简单说明
    使用扩展方法,让菜单也可以Clone
    接口里面的静态方法痒啊
    创业难,守业更难
  • 原文地址:https://www.cnblogs.com/HOsystem/p/14028160.html
Copyright © 2011-2022 走看看