一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Springboot安全框架整合SpringSecurity實現方式

Springboot安全框架整合SpringSecurity實現方式

2021-12-31 13:26DrLai Java教程

這篇文章主要介紹了Spring全家桶中Springboot安全框架整合SpringSecurity的實現方式,有需要的朋友可以借鑒參考下,希望可以有所幫助

 

1.工業級安全框架介紹

Spring Security基于Spring開發,項目中如果使用Spring作為基礎,配合Spring Security做權限更加方便,而Shiro需要和Spring進行整合開發。因此作為spring全家桶中的Spring Security在java領域很常用。

 

2.建議搭建Spring Security環境         

 

2.1在pom.xml中添加相關依賴

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>org.example</groupId>
    <artifactId>springsecurityReview</artifactId>
    <version>1.0-SNAPSHOT</version>
    <parent>
        <artifactId>spring-boot-dependencies</artifactId>
        <groupId>org.springframework.boot</groupId>
        <version>2.5.4</version>
    </parent>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
    </dependencies>
</project>

 

2.2創建Handler類 

package com.example.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
@Controller
public class Handler {
    @GetMapping("/index")
    public String index(){
        return "index";
    }
}

 

2.3創建簡單的html和配置相關thymeleaf的路徑

Springboot安全框架整合SpringSecurity實現方式          

 

2.4最后再加個啟動類,那么我們的整合測試就完成勒

package com.example;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class,args);
    }
}

 

2.5成果展示 用戶名默認user,密碼則隨機生成的這串數字

Springboot安全框架整合SpringSecurity實現方式

Springboot安全框架整合SpringSecurity實現方式

 

3.進階版使用        

 

3.1用戶名和密碼自定義

Springboot安全框架整合SpringSecurity實現方式

 

3.2在config包下創建Encoder進行密碼的校驗和轉碼操作

將密碼轉成字符串形式,并通過match方法驚醒校驗。 

Springboot安全框架整合SpringSecurity實現方式

 

3.3賦予賬號角色權限 

package com.example.config;
import org.springframework.context.annotation.Configuration;
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.configuration.WebSecurityConfigurerAdapter;
@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {
    //角色和資源的關系
    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.authorizeRequests().antMatchers("/admin").hasRole("ADMIN")
        .antMatchers("/index").access("hasRole("ADMIN") or hasRole("USER") ")
                .anyRequest().authenticated()
        .and()
        .formLogin()
        .loginPage("/login")
        .permitAll()
        .and()
        .logout()
        .permitAll()
        .and()
        .csrf()
        .disable();
     }
    @Override
    protected void configure(AuthenticationManagerBuilder auth) throws Exception {
       auth.inMemoryAuthentication().passwordEncoder(new MyPasswordEncoder())
       .withUser("user").password(new MyPasswordEncoder()
       .encode("000")).roles("USER")
       .and()
       .withUser("admin").password(new MyPasswordEncoder()
       .encode("123")).roles("ADMIN","USER");
    }
}

最后達到admin賬號能訪問admin.html和index.html

user只能訪問index.html的操作

以上就是Springboot安全框架整合SpringSecurity實現方式的詳細內容,更多關于Springboot整合SpringSecurity的資料請關注服務器之家其它相關文章!

原文鏈接:https://blog.csdn.net/DrLai/article/details/120275069

延伸 · 閱讀

精彩推薦
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
主站蜘蛛池模板: 免费看一级大片 | 窝窝午夜理伦影院 | 毛片a区| 99r视频| 国产精品久久久久久久久99热 | 欧美free激情野战hd | 成人在线免费看 | zoofilivideo杂交3d | 韩国三级hd中文字幕李采潭 | 日本加勒比一区 | 国产成+人+综合+欧美 亚洲 | 午夜福利体验免费体验区 | 希望影院高清免费观看视频 | free白嫩性hd | 成年视频在线观看 | 久久精品成人免费网站 | 国内精品久久久久久久久久久久 | 国产第一自拍 | 深夜在线网址 | 日本一卡二卡3卡四卡网站精品 | 3d欧美人禽交 | 第一次不是你高清在线观看 | 亚洲欧美久久一区二区 | 三体动漫在线观看免费完整版2022 | 亚洲福利天堂网福利在线观看 | 好男人好资源在线观看免费 | 国产精品露脸国语对白河北 | 午夜一级视频 | 国产在线欧美日韩精品一区二区 | 日本一卡2卡3卡4卡乱 | 日韩欧美亚洲每日更新网 | 亚洲国产情侣一区二区三区 | 欧美18-19sex性处 | 扒开黑女人p大荫蒂老女人 扒开大腿狠狠挺进视频 | 欧美久久一区二区三区 | 亚洲精品综合一区二区 | 阿 好深 快点 老师受不了 | 日本h乱淫动漫在线观看 | 我的青梅竹马是消防员2季未增删免费 | 99爱免费| 乌克兰xxxxx|