SpringBoot3整合SpringSecurity6自定義登錄頁(yè)面的詳細(xì)過(guò)程
寫(xiě)在前面
在前面的文章中,我們學(xué)習(xí)了SpringSecurity
登錄認(rèn)證流程,對(duì)其應(yīng)該有個(gè)大概印象了。
忘記的小伙伴點(diǎn)擊下面自己復(fù)習(xí)去~
在前面的學(xué)習(xí)中,我們使用的都是SpringSecurity
框架提供的登錄頁(yè)面,而實(shí)際開(kāi)發(fā)中,我們往往都需要自定義登錄頁(yè)面。
一、準(zhǔn)備登錄頁(yè)面
這里呢,我們先采取Themleaf
模板引擎來(lái)開(kāi)發(fā)登錄頁(yè)面。后續(xù)會(huì)說(shuō)到前后端分離的場(chǎng)景,小伙伴們不要著急,慢慢來(lái)
在resources/templates
下創(chuàng)建mylogin.html
登錄頁(yè)面,代碼如下
<!DOCTYPE html> <html xmlns:th="https://www.thymeleaf.org"> <head> <title>曉凡登錄頁(yè)面</title> </head> <body> <h1>登錄</h1> <div th:if="${param.error}"> 用戶(hù)名或者密碼錯(cuò)誤 </div> <!--method必須為"post"--> <!--mylogin: 和登錄頁(yè)面保持一致即可,SpringSecurity自動(dòng)進(jìn)行登錄認(rèn)證--> <form th:action="@{/mylogin}" method="post"> <div> <!--name必須為"username"--> <input type="text" name="username" placeholder="用戶(hù)名"/> </div> <div> <!--name必須為"password"--> <input type="password" name="password" placeholder="密碼"/> </div> <input type="submit" value="登錄" /> </form> </body> </html>
注:
- 需要采用post方式提交表單
- 用戶(hù)名輸入框的name屬性必須是
username
,SpringSecurity
框架默認(rèn)接收name="username"參數(shù) - 密碼輸入框的name屬性必須是
password
,SpringSecurity
框架默認(rèn)接收name="password"參數(shù) 。當(dāng)然這里可以自定義,我們后面再細(xì)說(shuō)。
二、編寫(xiě)登錄接口
上面寫(xiě)的登錄頁(yè)面提交地址是/login
(th:action="@{/login}"
),所以接下來(lái)我們來(lái)寫(xiě)一個(gè)登錄接口,代碼如下
@Controller public class LoginController { @GetMapping("/mylogin") public String login() { //跳轉(zhuǎn)到mylogin試圖解析器(上面自定義登錄頁(yè)面) return "mylogin"; } }
登錄頁(yè)面和登錄接口都寫(xiě)好了,我們來(lái)試下是否能訪問(wèn)到我們自定義的登錄頁(yè)面。
瀏覽器地址欄輸入:http://localhost:8080 回車(chē)后,我們發(fā)現(xiàn)還是系統(tǒng)的登錄頁(yè)面。結(jié)果如下
三、配置自定義登錄頁(yè)面
默認(rèn)情況下,應(yīng)用程序在走到我們寫(xiě)的LonginController
之前,會(huì)經(jīng)過(guò)一系列的過(guò)濾器。在過(guò)濾器中,其中配置的一個(gè)過(guò)濾器就是
http.formLogin(withDefaults());
這個(gè)過(guò)濾器默認(rèn)會(huì)這樣處理:如果應(yīng)用程序沒(méi)有進(jìn)行授權(quán)的話,它會(huì)將瀏覽器跳轉(zhuǎn)到/login 這個(gè)地址當(dāng)中,如果/login這個(gè)地址作為請(qǐng)求發(fā)送到后端服務(wù)器。
SpringSecurity
就回去找默認(rèn)的登錄頁(yè)面。
所以,我們要做的就是修改這個(gè)默認(rèn)配置
// 自定義登錄頁(yè)面 http.formLogin(form->{ form.loginPage("/mylogin"); });
這時(shí)候我們,再重啟服務(wù),看看有沒(méi)有達(dá)到我們的預(yù)期,結(jié)果如下
這是為什么呢?因?yàn)橄旅娴呐渲脮?huì)對(duì)所有請(qǐng)求進(jìn)行授權(quán)保護(hù)
http.authorizeHttpRequests( authorize->authorize //對(duì)所有請(qǐng)求開(kāi)啟授權(quán)保護(hù) .anyRequest() //已認(rèn)證的請(qǐng)求會(huì)被自動(dòng)授權(quán) .authenticated() );
我們只需要對(duì)mylogin
頁(yè)面進(jìn)行放行即可,修改后如下
// 自定義登錄頁(yè)面 http.formLogin(form->{ form.loginPage("/mylogin").permitAll(); });
經(jīng)過(guò)修改之后,我們?cè)賮?lái)驗(yàn)證一下,瀏覽器地址欄輸入:http://localhost:8080 后
成功跳轉(zhuǎn)到我們自定義的登錄頁(yè)面了,登錄界面雖然丑了一點(diǎn),但功能是實(shí)現(xiàn)了~
四、csrf攻擊
細(xì)心的小伙伴可能發(fā)現(xiàn)了,我們?cè)诰帉?xiě)登錄頁(yè)面的時(shí)候,form表單使用的是動(dòng)態(tài)參數(shù),具體如下
<form th:action="@{/mylogin}" method="post">
動(dòng)態(tài)參數(shù)th:action="@{/login}"
這種寫(xiě)法可以防止csrf 攻擊,我們來(lái)看下我們的登陸頁(yè)面源碼。
當(dāng)然了,我們需要把csrf打開(kāi),csrf攻擊只存在單體應(yīng)用中。后面要學(xué)的前后端分離是不存在的,我們可以把csrf關(guān)閉
五、小結(jié)
本篇文章的核心知識(shí)點(diǎn)就是下面的自定義登錄頁(yè)面配置,理解了這兒就夠了
// 自定義登錄頁(yè)面 http.formLogin(form->{ form.loginPage("/mylogin").permitAll(); });
到此這篇關(guān)于SpringBoot3整合SpringSecurity6自定義登陸頁(yè)面的文章就介紹到這了,更多相關(guān)SpringBoot3整合SpringSecurity6自定義登陸頁(yè)面內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot3整合SpringSecurity6自定義登錄頁(yè)面的詳細(xì)過(guò)程
- SpringBoot3整合SpringSecurity6添加用戶(hù)、密碼加密的方式
- 基于數(shù)據(jù)庫(kù)的用戶(hù)認(rèn)證實(shí)現(xiàn)SpringBoot3整合SpringSecurity6的過(guò)程
- SpringBoot3整合SpringSecurity6快速入門(mén)示例教程
- SpringBoot3+SpringSecurity6前后端分離的項(xiàng)目實(shí)踐
- SpringBoot3.0+SpringSecurity6.0+JWT的實(shí)現(xiàn)
相關(guān)文章
java開(kāi)發(fā)中嵌套類(lèi)的詳解及實(shí)例
這篇文章主要介紹了 java開(kāi)發(fā)中嵌套類(lèi)的詳解及實(shí)例的相關(guān)資料,一般把定義內(nèi)部類(lèi)的外圍類(lèi)成為包裝類(lèi)(enclosing class)或者外部類(lèi),需要的朋友可以參考下2017-07-07SpringBoot多表聯(lián)查(測(cè)試可用)
這篇文章主要介紹了SpringBoot多表聯(lián)查(測(cè)試可用)的相關(guān)資料,需要的朋友可以參考下2017-09-09SpringBoot整合MybatisPlus的基本應(yīng)用指南
MyBatis-Plus ,簡(jiǎn)稱(chēng) MP,是一個(gè) MyBatis的增強(qiáng)工具,在 MyBatis 的基礎(chǔ)上只做增強(qiáng)不做改變,下面小編就來(lái)和大家介紹一下SpringBoot整合MybatisPlus的一些基本應(yīng)用吧2025-03-03JSON for java快速入門(mén)總結(jié)學(xué)習(xí)
這篇文章主要介紹了JSON for java入門(mén)總結(jié)學(xué)習(xí),有需要的可以了解一下。2016-11-11Java的CyclicBarrier循環(huán)屏障解析
這篇文章主要介紹了Java的CyclicBarrier循環(huán)屏障解析,CyclicBarrier和CountDownLatch一樣,是一個(gè)同步工具類(lèi),它允許一組線程相互等待直到達(dá)到某個(gè)common?barrier?point,在程序中CyclicBarrier是非常有用的,它適用于一組線程必須互相等待的情況,需要的朋友可以參考下2023-12-12SpringMVC實(shí)現(xiàn)賬號(hào)只能在一處登陸
這篇文章主要為大家詳細(xì)介紹了SpringMVC如何實(shí)現(xiàn)賬號(hào)只能在一處登陸,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03spring mail借助qq郵箱服務(wù)器發(fā)送郵件
這篇文章主要介紹了spring mail借助qq郵箱服務(wù)器發(fā)送郵件的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12