SpringSecurity 測試實戰(zhàn)
引言
試題管理系統(tǒng)的安全模塊使用Spring Security,代碼從原華軟倉庫移植,在移植的過程中,發(fā)現(xiàn)原測試編寫的不好,遂在新系統(tǒng)中對安全模塊測試進行了重構(gòu)。
Spring 測試
添加@SpringBootTest注解,意為這是一個基于SpringBoot的單元測試。
SpringBoot在官方的Guide中提供了多種測試方式。
@SpringBootTest注解中的webEnvironment屬性可以配置測試環(huán)境,默認為MOCK環(huán)境。
/** * The type of web environment to create when applicable. Defaults to * {@link WebEnvironment#MOCK}. * @return the type of web environment */ WebEnvironment webEnvironment() default WebEnvironment.MOCK;
模擬環(huán)境測試
啟用Spring Security后,單元測試中對api的測試會被Spring Security的Filter進行攔截,所以測試之前需要進行用戶登錄操作。
之前都是使用比較笨重的方法,寫一個@Before,@Before里進行登錄,之后再執(zhí)行測試方法。
最近在閱讀Spring Security Test文檔之后,終于找到一種模擬登錄十分簡便的方法,@WithMockUser。
test method with mock user - spring security test
引入Spring Security Test依賴:
<!-- Spring Security Test --> <dependency> <groupId>org.springframework.security</groupId> <artifactId>spring-security-test</artifactId> <scope>test</scope> </dependency>
示例代碼如下:
@SpringBootTest @RunWith(SpringRunner.class) @AutoConfigureMockMvc @WithMockUser(username = "admin", password = "admin") public class ControllerTest { @Autowired protected MockMvc mockMvc; @Test void contextLoads() { } }
注:@RunWith(SpringRunner.class)表示當前測試使用org.springframework.test.context.junit4.SpringRunner類來執(zhí)行,最新的SpringBoot版本中已經(jīng)全面啟用junit5,不推薦使用junit4.SpringRunner,因為未經(jīng)過內(nèi)部學習與測試,未在生產(chǎn)項目中使用。
真實環(huán)境測試
為了減少學習與溝通的成本,之前,所有的測試規(guī)定都在MOCK環(huán)境下,使用MockMVC進行api測試。
雖然MOCK環(huán)境能解決大部分的問題,并且可以在不啟動Server的情況下直接進行測試,但在某些場景下,仍需要真實環(huán)境下的HTTP服務與請求測試。
啟用Spring Security后,MockMVC是直接測試控制器,并非在真實的HTTP服務器下進行測試,MOCK環(huán)境中使用的是MockHttpSession,這不是標準的Session實現(xiàn),沒有加入對COOKIE的支持,所以在測試安全模塊時,無法像瀏覽器一樣測試COOKIE等認證信息。
spring mockmvc doesn't contain cookies - stackoverflow
去StackOverflow上也沒有解決方案,答案推薦使用TestRestTemplate+真實的服務器環(huán)境進行單元測試。
將webEnvironment配置為SpringBootTest.WebEnvironment.RANDOM_PORT,即表示當前測試在一個隨機端口的真實Web環(huán)境下運行。
@RunWith(SpringRunner.class) @SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT) class AuthControllerTest { @Autowired private TestRestTemplate restTemplate; }
測試時使用TestRestTemplate進行網(wǎng)絡請求的發(fā)送,真實模擬Web服務器環(huán)境。
示例代碼如下:
logger.debug("3: 測試用戶名密碼正確"); username = RIGHT_USERNAME; password = RIGHT_PASSWORD; response = this.restTemplate .withBasicAuth(username, password) .getForEntity(CONFIG_LOGIN, Void.class); logger.debug("斷言: 狀態(tài)碼為200"); assertThat(response.getStatusCode().value()).isEqualTo(HttpStatus.OK.value()); logger.debug("獲取 response 的 Set-Cookie 信息,并斷言"); String setCookie = response.getHeaders().getFirst(HttpHeaders.SET_COOKIE); assertThat(setCookie).isNotNull();
總結(jié)
兩個各有優(yōu)點,之前我們一直使用簡單方便的Mock環(huán)境進行測試,但當我們有一天,發(fā)現(xiàn)這個Mock環(huán)境測試下的MockHttpSession無法滿足需求的時候,我們開始探索其他的測試方案。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- SpringBoot + Spring Security 基本使用及個性化登錄配置詳解
- spring security自定義認證登錄的全過程記錄
- Spring Boot中整合Spring Security并自定義驗證代碼實例
- 詳解使用Spring Security進行自動登錄驗證
- Spring Security OAuth2集成短信驗證碼登錄以及第三方登錄
- SpringBoot+SpringSecurity處理Ajax登錄請求問題(推薦)
- Java中SpringSecurity密碼錯誤5次鎖定用戶的實現(xiàn)方法
- spring security 5.x實現(xiàn)兼容多種密碼的加密方式
- 詳解如何在spring boot中使用spring security防止CSRF攻擊
- 詳解使用Spring Security OAuth 實現(xiàn)OAuth 2.0 授權(quán)
- Spring security實現(xiàn)登陸和權(quán)限角色控制
相關(guān)文章
在JPA中criteriabuilder使用or拼接多個like語句
這篇文章主要介紹了在JPA中criteriabuilder使用or拼接多個like語句,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12Java基本類型包裝類概述與Integer類、Character類用法分析
這篇文章主要介紹了Java基本類型包裝類概述與Integer類、Character類用法,結(jié)合實例形式分析了java基本數(shù)據(jù)類型與字符串轉(zhuǎn)換相關(guān)操作技巧,需要的朋友可以參考下2019-03-03RequestContextHolder.getRequestAttributes()空指針問題及解決
這篇文章主要介紹了RequestContextHolder.getRequestAttributes()空指針問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01詳解Spring AOP 實現(xiàn)“切面式”valid校驗
本篇文章主要介紹了詳解Spring AOP 實現(xiàn)“切面式”valid校驗,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-01-01將Springboot項目升級成Springcloud項目的圖文教程
本文主要介紹了將Springboot項目升級成Springcloud項目,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-06-06Eclipse使用maven搭建spring mvc圖文教程
這篇文章主要為大家分享了Eclipse使用maven搭建spring mvc圖文教程,感興趣的小伙伴們可以參考一下2016-05-05