解決Spring?Security集成knife4j訪問接口文檔出現(xiàn)403的問題
問題描述:
使用的springboot版本是2.3.12.RELEASE,引用的依賴如下:
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>knife4j-spring-boot-starter</artifactId>
<version>${knife4j.version}</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.10.5</version>
<exclusions>
<exclusion>
<groupId>io.swagger</groupId>
<artifactId>swagger-models</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>io.swagger</groupId>
<artifactId>swagger-models</artifactId>
<version>1.5.22</version>
</dependency>在WebSecurityConfigurerAdapter繼承類當中配置了跳過認證
@Override
public void configure(WebSecurity web) {
web.ignoring().antMatchers("/doc.html",
"/favicon.ico",
"/v2/api-docs",
"/swagger-resources/**",
"/webjars/**");
}
然后訪問doc.html接口文檔也可以正常訪問,就是每訪問一次控制臺就會出來一個異常,后來排查到訪問doc.html的時候他會去訪問http://localhost:9079/stdc/api/talentpool/favicon.ico,是這個接口報出來的異常。
/stdc/api/talentpool是設(shè)置的
server.servlet.context-path

這個異常是由自定義的認證失敗類 拋出來的。按正常來說就算認證失敗了request.getRequestURI()獲取到的也不應(yīng)該是error呀。

解決過程:
針對于這個問題其實官網(wǎng)當中是有提到的:https://gitee.com/xiaoym/knife4j/issues/I3UEMQ
favicon.ico就是獲取的網(wǎng)站的圖標,在當前工程下,resources/static目錄下存放一個favicon.ico文件即可解決。

到此這篇關(guān)于解決Spring Security集成knife4j訪問接口文檔出現(xiàn)403的問題的文章就介紹到這了,更多相關(guān)SpringSecurity訪問接口403內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java?BasePooledObjectFactory?對象池化技術(shù)的使用
這篇文章主要介紹了Java?BasePooledObjectFactory?對象池化技術(shù),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04
Spring IOC源碼剖析_如何整體認知Spring體系結(jié)構(gòu)
這篇文章主要介紹了Spring IOC源碼剖析_如何整體認知Spring體系結(jié)構(gòu)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09

