加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

9、Spring Boot安全

发布时间:2020-12-15 01:15:03 所属栏目:大数据 来源:网络整理
导读:1.Spring Security简介 ??Spring Security是针对Spring项目的安全框架,也是Spring Boot底层安全模块默认的技术选型。他可以实现强大的web安全控制。对于安全控制,我们仅需引入spring-boot-starter-security模块,进行少量的配置,即可实现强大的安全管理。

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="注销"

?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读