真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何在SpringBoot2.0中使用SpringSecurity

本篇文章給大家分享的是有關如何在Spring Boot2.0中使用Spring Security,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

網(wǎng)站建設公司,為您提供網(wǎng)站建設,網(wǎng)站制作,網(wǎng)頁設計及定制網(wǎng)站建設服務,專注于企業(yè)網(wǎng)站建設,高端網(wǎng)頁制作,對混凝土攪拌罐車等多個行業(yè)擁有豐富的網(wǎng)站建設經(jīng)驗的網(wǎng)站建設公司。專業(yè)網(wǎng)站設計,網(wǎng)站優(yōu)化推廣哪家好,專業(yè)成都網(wǎng)站營銷優(yōu)化,H5建站,響應式網(wǎng)站。

一、Spring Secutity簡介

Spring 是一個非常流行和成功的 Java 應用開發(fā)框架。Spring Security 基于 Spring 框架,提供了一套 Web 應用安全性的完整解決方案。一般來說,Web 應用的安全性包括用戶認證(Authentication)和用戶授權(Authorization)兩個部分。用戶認證指的是驗證某個用戶是否為系統(tǒng)中的合法主體,也就是說用戶能否訪問該系統(tǒng)。用戶認證一般要求用戶提供用戶名和密碼。系統(tǒng)通過校驗用戶名和密碼來完成認證過程。用戶授權指的是驗證某個用戶是否有權限執(zhí)行某個操作。在一個系統(tǒng)中,不同用戶所具有的權限是不同的。比如對一個文件來說,有的用戶只能進行讀取,而有的用戶可以進行修改。一般來說,系統(tǒng)會為不同的用戶分配不同的角色,而每個角色則對應一系列的權限。

對于上面提到的兩種應用情景,Spring Security 框架都有很好的支持。在用戶認證方面,Spring Security 框架支持主流的認證方式,包括 HTTP 基本認證、HTTP 表單驗證、HTTP 摘要認證、OpenID 和 LDAP 等。在用戶授權方面,Spring Security 提供了基于角色的訪問控制和訪問控制列表(Access Control List,ACL),可以對應用中的領域對象進行細粒度的控制。

另外Spring Security也集成了OAuth3.0,接下來我們就介紹下這兩種使用的,當然Spring Security還集成CAS等等,如果你要了解更多請查看 官方文檔 ,我們下面的都是使用Spring Boot2.0做的demo,2.0以后已經(jīng)集成了Spring Security5.0以上的版本;

二、Basic認證

這個也是我們經(jīng)常使用的基于表單的認證,輸入一個賬號和密碼點擊登錄這種,就是Basic認證,我們接下主要會講一下使用以及5.0以后做了那些升級;

1.使用以及常用的一些參數(shù)的介紹

第一步使用Maven引入Spring Security jia包,這里我們使用Thymeleaf作為前端模板頁面,這里也有一個地方可以探討一波,為什么Spring MVC可以自由切換模板,這個地方我們找個機會一起探討,這里先做下簡單的介紹;


 
  org.springframework.boot
  spring-boot-starter
 
 
  org.springframework.boot
  spring-boot-starter-security
 
 
 
  org.springframework.boot
  spring-boot-starter-thymeleaf
 
 
 
  org.springframework.boot
  spring-boot-starter-web
 
 
  org.springframework.boot
  spring-boot-starter-test
  test
 
 
  org.springframework.boot
  spring-boot-starter-thymeleaf
 
 
  org.springframework.boot
  spring-boot-starter-security
 
 

第二步引入Java配置配置方案

這里我們先使用@Configuration和@EnableWebSecurity對Java類進行配置,接下來我們就是繼承WebSecurityConfigurerAdapter,對里面的方法重寫就可以了,分別是對AuthenticationManagerBuilder,WebSecurity,HttpSecurity方法,我們主要介紹AuthenticationManagerBuilder和HttpSecurity,通過對這兩種方法重寫最終實現(xiàn)我們自定義認證;

先來介紹一下HttpSecurity常用參數(shù),如下圖用法基本脫離不了下面這些方法,可以基于認證的方式有formLogin、openidLogin、oauth3Login,還可以做一些記住賬號操作rememberMe,還可以進行session配置管理,還支持登出loginout等等,使用起來還是蠻簡單的,大家可以參照一下這篇文章,還是蠻詳細的;

如何在Spring Boot2.0中使用Spring Security

接下來我們再看下AuthenticationManagerBuilder,我們重寫這個方法,可以基于內存用戶認證、數(shù)據(jù)庫認證、LDAP認證、還可以自定義用戶服務、還可以自己定義認證。這里我們使用自定義認證的做demo,另外這個大家還可能有一個困惑的點,configGlobal和configure的差別在哪里,這里大家可以 參考下這篇文章 ,Spring Security從3.2版本以后就默認開啟了CRSF防護,這里是通過Token方式去檢測的,在登陸的時候Thymeleaf模板會生成_csrf的標簽來防止CRSF,對CSRF不懂的大家可以看下這篇文章 ,這個里面介紹一些防護CSRF的手段,大家可以思考下,我的demo只是一個簡單的架子,為了是給大家介紹一些知識,可擴展大家根據(jù)這些介紹的知識可以隨心所欲的擴展自己想要的,不要拘泥于一種方法;

最后我還要介紹一下加密的方式,Spring Security 4的時候我們常用的加密方式是MD5加鹽的方式,5.0以后版本就找不到Md5PasswordEncoder,說明這個方法還是不夠安全,還是可以通過暴力破解可以搞定,可能我不行但是攔不住一些高手,大家可以看下官方支持的以及棄用一些方法:

如何在Spring Boot2.0中使用Spring Security

使用我就不介紹了,有興趣可以自己探索一波,還可以參考一下 文章一 、文章二 ,下面我粘貼我的代碼,講到的這些可以擴展的地方大家我在代碼中會標識清楚,喜歡動手可以嘗試一下,我的重點是OAuth3驗證;

/**
 *自定義認證
 * Created by wangt on 2018/7/29.
 */
@Configuration
@EnableWebSecurity
@EnableGlobalMethodSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

 /**
 * http資源認證
 * @param http
 * @throws Exception
 */
 @Override
 protected void configure(HttpSecurity http) throws Exception {
 http.authorizeRequests()
  .antMatchers("/","/home").permitAll()
  .anyRequest().authenticated()
  .and()
  .formLogin()
  .loginPage("/login")
  .permitAll()
  .and()
  .logout()
  .permitAll();
 }

 /**
 * 自定義認證策略
 */
 @Autowired
 public void configGlobal(AuthenticationManagerBuilder auth) throws Exception {
 auth.authenticationProvider(authProvider()).eraseCredentials(true);
 }

 @Bean
 public AuthProvider authProvider(){
 return new AuthProvider();
 }
}


/**
 * 自定義認證
 * Created by wangt on 2018/8/18.
 */
public class AuthProvider implements AuthenticationProvider {
 private final BCryptPasswordEncoder bCryptPasswordEncoder=new BCryptPasswordEncoder();

 @Override
 public Authentication authenticate(Authentication authentication) throws AuthenticationException {
 String userName = authentication.getName();
 String inputPassword = (String) authentication.getCredentials();

 //如果你要使用thymeleaf認證方言可以擴展一下User
 //GrantedAuthority這個是使用方言的屬性,有興趣了解下
 //其實也就是通過這個使用if去判斷
 User user =new User();
 user.setName("admin");
 user.setPassword("admin");
 if (user == null) {
  throw new AuthenticationCredentialsNotFoundException("authError");
 }

 //這一塊可以自定義一些加密方式
 //自己動手實現(xiàn)一下
 if (true) {
  //這塊有好幾個構造
  //如果使用方言你可以使用3個參數(shù)的構造函數(shù)
  return new UsernamePasswordAuthenticationToken(user, null);

 }

 throw new BadCredentialsException("authError");
 }

 @Override
 public boolean supports(Class aClass) {
 return true;
 }
}


/**
 * Created by wangt on 2018/8/18.
 */
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
 
 //如果使用thymeleaf方言在這塊擴展
 

 @Override
 public void addViewControllers(ViewControllerRegistry registry) {
 registry.addViewController("/index").setViewName("index");
 registry.addViewController("/").setViewName("index");
 registry.addViewController("/hello").setViewName("hello");
 registry.addViewController("/login").setViewName("login");
 }
}





 
 Title



您好!歡迎光臨!
登錄
限制訪問的頁面







 
 Title



hello






 
 Title




 
 
 
@Controller public class LoginController {  @GetMapping("/login")  public String login(){  return "/login";  } } @Controller public class HomeController {  @GetMapping("/")  public String index(){   return "index";  } } @Controller public class HelloController {  @GetMapping("/hello")  public String index(){  return "hello";  } }

以上就是如何在Spring Boot2.0中使用Spring Security,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


文章題目:如何在SpringBoot2.0中使用SpringSecurity
URL分享:http://weahome.cn/article/jidejp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部