swagger使用過程中遇到的坑


1、無限請求

如果swagger頁面請求有錯誤,swagger會無限嘗試訪問,后面重啟項目的時候,控制層會無限刷新出現日志的內容

本地的好辦,如果項目項目部署到服務器中,可能十幾分鍾產生幾個G的日志文件

解決方式:最簡單的方式——關閉請求報錯的瀏覽器

 

2、同名問題

@Api(同名的問題) 因為swagger會根據tags 的名稱查找對象,有同名對象的時候,swagger的文檔就會出現問題
如果swagger的某個API下出現不屬於該API的請求,這個就是API的同名的問題,查找相同的API名稱替換即可

 

3、類上的注解“/”的問題

@ApiModel(不能使用“/”)

Errors
Hide
Resolver error at paths./v1-0/Configuration/add.post.parameters.1.schema.properties.listHotCarBrandIVO.items.$ref
Could not resolve reference because of: Could not resolve pointer: /definitions/熱門車/品牌/的IVO does not exist in document

 

4、使用map作為返回類型報錯,

Errors
Hide
Resolver error at definitions.Map«string,List«賣車車輛信息OVO»».additionalProperties.$ref
Could not resolve reference because of: Could not resolve pointer: /definitions/List does not exist in document

  兩個解決方案:升級swagger版本號,這個是我用2.8.0報錯會報錯,網上有說升級版本可以解決,這個我沒有去試,

		<dependency>
			<groupId>io.springfox</groupId>
			<artifactId>springfox-swagger2</artifactId>
			<version>2.8.0</version>
		</dependency>

 我這邊的解決方案是,將map定義在對象中,面向對象編程,而且這樣生成文檔的時候,注釋也會顯示好

 

5、swagger版本的問題,2.8之前的版本在  路徑/{id} +@pathVarisble  這樣的寫法

  2.8之前,swagger給出的類型居然是body,需要用json的格式傳這個很奇怪,

  版本更新到2.8以后,路徑后面綁定的參數就是 swagger給出的類型居然是就能是param

  適當的更新版本有好處

		<dependency>
			<groupId>io.springfox</groupId>
			<artifactId>springfox-swagger2</artifactId>
			<version>2.8.0</version>
		</dependency>
		<dependency>
			<groupId>io.springfox</groupId>
			<artifactId>springfox-swagger-ui</artifactId>
			<version>2.8.0</version>
		</dependency>

  

 6沒有重現過的一個bug

 Failed to execute 'fetch' on 'Window': Failed to parse URL from http://localhost/8765undefindFailed to parse URL from http://localhost/8765undefind

  我一直重啟項目 swagger沒有重現問題

  后來我修改請求你方法上的api注釋,重啟就可以,可能是swagger上api沖突,關鍵是這個沒有提示,好暈;如果誰找到重現這個問題來說一下


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM