SpringSecurity框架

简介: SpringSecurity框架

SpringSecurity依赖

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

thymeleaf整合SpringSecurity依赖

<!--thymeleaf整合SpringSecurity-->
        <dependency>
            <groupId>org.thymeleaf.extras</groupId>
            <artifactId>thymeleaf-extras-springsecurity4</artifactId>
            <version>3.0.4.RELEASE</version>
        </dependency>

SecurityConfig.java

@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
    @Override
    protected void configure(HttpSecurity http) throws Exception {
        //请求权限
        http.authorizeHttpRequests()
                .antMatchers("/").permitAll()
                .antMatchers("/a1/**").hasRole("v1")
                .antMatchers("/a2/**").hasRole("v2")
                .antMatchers("/a3/**").hasRole("v3");
        //没有权限则返回默认登录界面,自定义返回登录界面loginPage(),usernameParameter对应登录表单用户名的name值
        http.formLogin().usernameParameter("username").passwordParameter("password").loginPage("/toLogin").loginProcessingUrl("/login");
        //关闭csrf,登录失败的原因可能因为未关闭
        http.csrf().disable();
        //注销返回首页
        http.logout().logoutSuccessUrl("/");
        //开启记住我,下次访问url,仍然保持用户登录状态,默认保存14天,rememberMeParameter对应表单内name参数
        http.rememberMe().rememberMeParameter("remeber");
    }
    //SpringSecurity5+加密
    @Override
    protected void configure(AuthenticationManagerBuilder auth) throws Exception {
        //用户名密码对应数据库,在这里是自定义的
        auth.inMemoryAuthentication().passwordEncoder(new BCryptPasswordEncoder())
                .withUser("aa").password(new BCryptPasswordEncoder().encode("123456")).roles("v1")
                .and()
                .withUser("bb").password(new BCryptPasswordEncoder().encode("123456")).roles("v1","v2")
                .and()
                .withUser("cc").password(new BCryptPasswordEncoder().encode("123456")).roles("v1","v2","v3");
    }
}

首界面index.html

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org"
      xmlns:sec="http://www.thymeleaf.org/thymeleaf-extras-springsecurity4">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
        <!--未登录-->
        <div sec:authorize="!isAuthenticated()">
            <a th:href="@{/toLogin}">登录</a>
        </div>
<!--        登录显示用户名-->
        <div sec:authorize="isAuthenticated()">
            用户名:<span sec:authentication="name"></span>
        </div>
        <div sec:authorize="isAuthenticated()">
            <a th:href="@{/toLogin}">退出</a>
        </div>
        <!--判断权限,有权限显示-->
        <div sec:authorize="hasRole('v1')">
            <a th:href="@{/a1/a1}">v1权限所显示的界面</a>
        </div>
        <div sec:authorize="hasRole('v2')">
            <a th:href="@{/a2/a2}">v2权限所显示的界面</a>
        </div>
        <div sec:authorize="hasRole('v3')">
            <a th:href="@{/a3/a3}">v3权限所显示的界面</a>
        </div>
    </body>
</html>
目录
相关文章
|
存储 安全 Java
SpringSecurity 核心组件
在SpringSecurity中的jar分为4个
85 0
|
安全 Java 数据库
SpringSecurity 入门
Spring Security是Spring采用 `AOP`思想,基于 `servlet过滤器`实现的安全框架。它提供了完善的**认证机制**和**方法级的授权功能**。是一款非常优秀的权限管理框架。
92 0
|
6月前
|
安全 Java Apache
如何安装与使用Spring Boot 2.2.x、Spring Framework 5.2.x与Apache Shiro 1.7进行高效开发
【7月更文第1天】在现代Java Web开发领域,Spring Boot以其简化配置、快速开发的特点备受青睐。结合Spring Framework的成熟与Apache Shiro的强大权限控制能力,我们可以轻松构建安全且高效的Web应用。本篇文章将指导你如何安装并使用Spring Boot 2.2.x、Spring Framework 5.2.x以及Apache Shiro 1.7来构建一个具备基础权限管理功能的项目。
104 0
|
7月前
|
Java 数据库
Springboot集成SpringSecurity有源码
Springboot集成SpringSecurity有源码
|
8月前
|
存储 安全 Java
20个SpringSecurity框架核心组件源码详解
以上是 V 哥给大家整理的20个Spring Security 中核心组件的分析与运行过程,理解后可助你玩转Spring Security,如果文章对你有帮助,客官请点赞收藏转发给更多需要的兄弟,任何疑问请评论区与V哥交流。
|
安全 Java 数据库
SpringSecurity入门
SpringSecurity入门
110 0
|
8月前
|
安全 Java 数据库
SpringSecurity系列(二) Spring Security入门
SpringSecurity系列(二) Spring Security入门
102 1
|
8月前
|
SQL 安全 Java
【SpringSecurity】简介
【SpringSecurity】简介
70 0
|
安全 Java 数据安全/隐私保护
SpringSecurity学习(一):SpringBoot整合SpringSecurity
SpringSecurity学习(一):SpringBoot整合SpringSecurity
228 0
SpringSecurity学习(一):SpringBoot整合SpringSecurity

热门文章

最新文章

下一篇
开通oss服务