SpringBoot中使用Swagger的超簡單方法
Swagger號稱世界上最流行的Api框架,它是RestFul 風(fēng)格的Api。文檔在線自動(dòng)生成工具:Api文檔與API定義同步更新。可以直接運(yùn)行,能在線測試API接口;支持多種編程語言:(Java、PHP等)。
官網(wǎng):https://swagger.io/
springBoot使用swagger太麻煩,每次都需要編寫config?如果我告訴你有這么一種方式,你只需要配置yml文件,你學(xué)還是不學(xué)?
整合Swagger依賴:
<!-- Swagger --><dependency> <groupId>com.battcn</groupId> <artifactId>swagger-spring-boot-starter</artifactId> <version>2.1.5-RELEASE</version></dependency>
我這里的Swagger大家應(yīng)該也發(fā)現(xiàn)了,并非是官方的,這個(gè)是第三方整合的,配置更加簡單。
配置詳解詳細(xì)配置:
spring: swagger: enabled: true title: 標(biāo)題 description: 描述信息 version: 系統(tǒng)版本號 contact: name: 維護(hù)者信息 base-package: swagger掃描的基礎(chǔ)包,默認(rèn):全掃描(分組情況下此處可不配置) #全局參數(shù),比如Token之類的驗(yàn)證信息可以全局話配置 global-operation-parameters: - description: ’Token信息,必填項(xiàng)’modelRef: ’string’name: ’Authorization’parameter-type: ’header’required: true groups: basic-group:base-package: com.battcn.controller.basic system-group:base-package: com.battcn.controller.system
我的配置
spring: swagger: title: 星空小屋 - 文章微服務(wù)接口 description: 文章微服務(wù)相關(guān)接口,包括文章、模塊、知識點(diǎn)管理等 version: 1.0.0 - SNAPSHOT contact: name: cv大魔王 email: 1919301983@qq.com host: localhost enabled: true security: filter-plugin: true # 配置賬號密碼 username: root password: root
配置攔截器,后面有攔截器配置,如果有讀者需要在自己的項(xiàng)目使用,請?jiān)械臄r截器配置中修改,忽略掉以下路徑,以免被攔截導(dǎo)致無法訪問。“swagger-ui.html”, “static/css/', 'static/js/”, “swagger-resources”, “/**/error”, “v2/api-docs”
測試使用運(yùn)行項(xiàng)目,訪問IP+端口號/swagger-ui.html,例如在瀏覽器訪問:http://127.0.0.1:13001/swagger-ui.html
登錄后的效果:
對swagger熟悉的小伙伴的請忽略“常用注解段落”
`@Api`:用在 Controller 類上,描述該類的作用 1. `value`='描述信息' 2. `description`='詳細(xì)描述該類的作用'
@ApiOperation:用在 Controller 請求方法上,描述方法的作用。
@ApiModel:用在請求參數(shù)是對象上,描述該對象類的作用
// 在對象類上使用@ApiModel@ApiModel(value='CategoryREQ對象', description='類別查詢條件')public class CategoryREQ extends BaseRequest<Category> {}
@ApiModelProperty:用在請求參數(shù)是對象的屬性上,描述對象屬性的作用。
value:屬性的描述 hidden:是否是查詢條件屬性, false:(默認(rèn)值)在api文檔顯示,作為查詢條件;true 隱藏,不是條件屬性// 請求方法參數(shù)是 CategoryREQ 對象public Result search(@RequestBody CategoryREQ req) {}@ApiModel(value='CategoryREQ對象', description='類別查詢條件')public class CategoryREQ extends BaseRequest<Category> {@ApiModelProperty(value = '分類名稱') private String name; @ApiModelProperty(value='狀態(tài)(1:正常,0:禁用)') private Integer status;} @ApiResponses:用在請求的方法上,用于表示一組響應(yīng) @ApiResponse:用在 @ApiResponses 中,一般用于表達(dá)一個(gè)錯(cuò)誤的響應(yīng)信息,注解參數(shù): code:數(shù)字,如 400message:信息,如 “參數(shù)填寫錯(cuò)誤”response:拋出異常的類
@ApiIgnore: 使用該注解忽略這個(gè) API
@ApiImplicitParams:用在請求方法上,對多個(gè)請求參數(shù)增加描述
@ApiImplicitParam:可單獨(dú)使用,或在 @ApiImplicitParams 中使用,給方法的一個(gè)請求參數(shù)增加描述。
name:參數(shù)名 value:描述參數(shù)的作用 dataType:參數(shù)類型,參數(shù)類型,默認(rèn)String,其它值 dataType=“Integer” defaultValue:參數(shù)默認(rèn)值 required:參數(shù)是否必傳(true/false) paramTpye:指定參數(shù)放在哪些地方(header/query/path/body/form)header :參數(shù)在request headers 里邊提交 @RequestHeaderquery :直接跟參數(shù)完成自動(dòng)映射賦值 @RequestParampath :以路徑變量的形式提交數(shù)據(jù) @PathVariablebody :以流的形式提交 僅支持POST(不常用)form :以form表單的形式提交 僅支持POST (不常用)參考:
// 請求方法有多個(gè)請求參數(shù) size, current@ApiImplicitParams({ @ApiImplicitParam(name='current', value='頁碼', required=true, paramType='path',dataType='int'), @ApiImplicitParam(name='size', value='每頁記錄數(shù)', required=true, paramType='path',dataType='int')})@ApiOperation('根據(jù)分類名稱與狀態(tài)查詢分類列表接口')@PostMapping('/search/{current}/{size}')Result search(@RequestBody CategoryREQ req, @PathVariable int current, @PathVariable int size);
到此這篇關(guān)于SpringBoot中使用Swagger的超簡單方法的文章就介紹到這了,更多相關(guān)SpringBoot使用Swagger內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 用xslt+css讓RSS顯示的跟網(wǎng)頁一樣漂亮2. HTML5 Canvas繪制圖形從入門到精通3. 《CSS3實(shí)戰(zhàn)》筆記--漸變設(shè)計(jì)(一)4. 利用CSS制作3D動(dòng)畫5. 讀大數(shù)據(jù)量的XML文件的讀取問題6. 讓chatgpt將html中的圖片轉(zhuǎn)為base64方法示例7. html5手機(jī)觸屏touch事件介紹8. CSS3實(shí)現(xiàn)動(dòng)態(tài)翻牌效果 仿百度貼吧3D翻牌一次動(dòng)畫特效9. 測試模式 - XSL教程 - 510. JSP的Cookie在登錄中的使用
