欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Spring Security中的HttpBasic登錄驗證模式

 更新時間:2019年11月19日 09:50:25   作者:字母哥博客  
HttpBasic登錄驗證模式是Spring Security實現(xiàn)登錄驗證最簡單的一種方式,也可以說是最簡陋的一種方式,這篇文章主要介紹了Spring Security的HttpBasic登錄驗證模式,需要的朋友可以參考下

一、HttpBasic模式的應(yīng)用場景

HttpBasic登錄驗證模式是Spring Security實現(xiàn)登錄驗證最簡單的一種方式,也可以說是最簡陋的一種方式。它的目的并不是保障登錄驗證的絕對安全,而是提供一種“防君子不防小人”的登錄驗證。

就好像是我小時候?qū)懭沼洠假I一個帶小鎖頭的日記本,實際上這個小鎖頭有什么用呢?如果真正想看的人用一根釘子都能撬開。它的作用就是:某天你的父母想偷看你的日記,拿出來一看還帶把鎖,那就算了吧,怪麻煩的。

舉一個我使用HttpBasic模式的進(jìn)行登錄驗證的例子:我曾經(jīng)在一個公司擔(dān)任部門經(jīng)理期間,開發(fā)了一套用于統(tǒng)計效率、分享知識、生成代碼、導(dǎo)出報表的Http接口。純粹是為了工作中提高效率,同時我又有一點點小私心,畢竟各部之間是有競爭的,所以我給這套接口加上了HttpBasic驗證。公司里隨便一個技術(shù)人員,最多只要給上一兩個小時,就可以把這個驗證破解了。說白了,這個工具的數(shù)據(jù)不那么重要,加一道鎖的目的就是不讓它成為公開數(shù)據(jù)。如果有心人破解了,真想看看這里面的數(shù)據(jù),其實也無妨。這就是HttpBasic模式的典型應(yīng)用場景。

二、spring boot2.0整合Spring security

spring boot 2,x版本maven方式引入Spring security坐標(biāo)。

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

三、HttpBasic登錄認(rèn)證模式

如果使用的Spring Boot版本為1.X版本,依賴的Security 4.X版本,那么就無需任何配置,啟動項目訪問則會彈出默認(rèn)的httpbasic認(rèn)證.

我們現(xiàn)在使用的是spring boot2.0版本(依賴Security 5.X版本),HttpBasic不再是默認(rèn)的驗證模式,在spring security 5.x默認(rèn)的驗證模式已經(jīng)是表單模式。所以我們要使用Basic模式,需要自己調(diào)整一下。并且security.basic.enabled已經(jīng)過時了,所以我們需要自己去編碼實現(xiàn)。

@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {
  
  @Override
  protected void configure(HttpSecurity http) throws Exception {
   http.httpBasic()//開啟httpbasic認(rèn)證
   .and()
   .authorizeRequests()
   .anyRequest()
   .authenticated();//所有請求都需要登錄認(rèn)證才能訪問
  }
}

啟動項目,在項目后臺有這樣的一串日志打印,冒號后面的就是默認(rèn)密碼。

Using generated security password: 0cc59a43-c2e7-4c21-a38c-0df8d1a6d624

我們可以通過瀏覽器進(jìn)行登錄驗證,默認(rèn)的用戶名是user.(下面的登錄框不是我們開發(fā)的,是HttpBasic模式自帶的)

當(dāng)然我們也可以通過application.yml指定配置用戶名密碼

spring:
  security:
   user:
    name: admin
    password: admin

四、HttpBasic模式的原理說明

  • 首先,HttpBasic模式要求傳輸?shù)挠脩裘艽a使用Base64模式進(jìn)行加密。如果用戶名是 "admin"  ,密碼是“ admin”,則將字符串"admin:admin" 使用Base64編碼算法加密。加密結(jié)果可能是:YWtaW46YWRtaW4=。
  • 然后,在Http請求中使用Authorization作為一個Header,“Basic YWtaW46YWRtaW4=“作為Header的值,發(fā)送給服務(wù)端。(注意這里使用Basic+空格+加密串)
  • 服務(wù)器在收到這樣的請求時,到達(dá)BasicAuthenticationFilter過濾器,將提取“ Authorization”的Header值,并使用用于驗證用戶身份的相同算法Base64進(jìn)行解碼。
  • 解碼結(jié)果與登錄驗證的用戶名密碼匹配,匹配成功則可以繼續(xù)過濾器后續(xù)的訪問。

所以,HttpBasic模式真的是非常簡單又簡陋的驗證模式,Base64的加密算法是可逆的,你知道上面的原理,分分鐘就破解掉。我們完全可以使用PostMan工具,發(fā)送Http請求進(jìn)行登錄驗證。

總結(jié)

以上所述是小編給大家介紹的Spring Security中的HttpBasic登錄驗證模式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • SpringBoot項目配置明文密碼泄露問題的處理方式

    SpringBoot項目配置明文密碼泄露問題的處理方式

    這篇文章主要介紹了SpringBoot項目配置明文密碼泄露問題的處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • idea 實現(xiàn)git rebase操作應(yīng)用場景

    idea 實現(xiàn)git rebase操作應(yīng)用場景

    本文結(jié)合idea工具進(jìn)行rebase的各種場景的操作,借助工具更能直觀地觀察到分支之間地操作差異,方便我們理解rebase的各種操作以及場景的使用,對idea  git rebase操作知識感興趣的朋友一起看看吧
    2024-01-01
  • Java實現(xiàn)的斷點續(xù)傳功能的示例代碼

    Java實現(xiàn)的斷點續(xù)傳功能的示例代碼

    本篇文章主要介紹了Java實現(xiàn)的斷點續(xù)傳功能的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • Java中的包(package)是什么和使用方法

    Java中的包(package)是什么和使用方法

    包是Java中一種強大的組織代碼的工具,它們幫助開發(fā)者將代碼分組,防止命名沖突,并通過控制訪問級別來增強代碼的安全性,這篇文章主要介紹了Java中的包(package)是什么和如何使用它們,需要的朋友可以參考下
    2024-07-07
  • 詳解Java同步—線程鎖和條件對象

    詳解Java同步—線程鎖和條件對象

    在這篇文章中給大家詳細(xì)講述了Java同步—線程鎖和條件對象的相關(guān)知識點,有需要的讀者們可以參考下。
    2018-07-07
  • Spring中的事務(wù)管理及實現(xiàn)方式解析

    Spring中的事務(wù)管理及實現(xiàn)方式解析

    這篇文章主要介紹了Spring中的事務(wù)管理及實現(xiàn)方式解析,Spring事務(wù)管理基于底層數(shù)據(jù)庫本身的事務(wù)處理機制,數(shù)據(jù)庫事務(wù)的基礎(chǔ),是掌握Spring事務(wù)管理的基礎(chǔ),這篇總結(jié)下Spring事務(wù),需要的朋友可以參考下
    2024-01-01
  • springboot集成redis實現(xiàn)簡單秒殺系統(tǒng)

    springboot集成redis實現(xiàn)簡單秒殺系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了springboot集成redis實現(xiàn)簡單秒殺系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • java?Springboot實現(xiàn)教務(wù)管理系統(tǒng)

    java?Springboot實現(xiàn)教務(wù)管理系統(tǒng)

    這篇文章主要介紹了java?Springboot實現(xiàn)教務(wù)管理系統(tǒng)的過程,文章圍繞實現(xiàn)過程展開全文詳細(xì)內(nèi)容,具有一定的參考價值,需要的朋友可以參考一下,希望對你有所幫助
    2021-11-11
  • springcloud整合seata的實現(xiàn)代碼

    springcloud整合seata的實現(xiàn)代碼

    這篇文章主要介紹了springcloud整合seata的實現(xiàn)方法,整合步驟通過引入spring-cloud-starter-alibaba-seata?jar包,文中結(jié)合實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • Java中synchronized用法匯總

    Java中synchronized用法匯總

    使用 synchronized 無需手動執(zhí)行加鎖和釋放鎖的操作,我們只需要聲明 synchronized 關(guān)鍵字就可以了,JVM 層面會幫我們自動的進(jìn)行加鎖和釋放鎖的操作,我們今天重點來看一下synchronized 的幾種用法
    2022-04-04

最新評論