隨着互聯網技術的發展,如今的網站架構基本都由原來的後端渲染,變成了:前端渲染、前後端分離的形態,並且前端技術和後端技術在各自的道路上越走越遠。 前端和後端的惟一聯繫,變成了API接口;API文檔變成了先後端開發人員聯繫的紐帶,變得愈來愈重要,swagger
就是一款讓你更好的書寫API文檔的框架,並且swagger能夠徹底模擬http請求,入參出參和實際狀況差異幾乎爲零。html
沒有API文檔工具以前,你們都是手寫API文檔的(維護起來至關困難),在什麼地方書寫的都有,有在confluence
上寫的,有在對應的項目目錄下readme.md
上寫的,每一個公司都有每一個公司的玩法,無所謂好壞。可是能稱之爲「框架」的,估計也只有swagger
了前端
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.0.RELEASE</version> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> </properties> <dependencies> <!-- junit --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <scope>test</scope> </dependency> <!-- spring boot --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- swagger --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.5.0</version> </dependency> <!-- swagger-ui --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.5.0</version> </dependency> </dependencies>
package com.mao.swagger; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.EnableAutoConfiguration; import org.springframework.boot.autoconfigure.SpringBootApplication; /** * Hello world! * */ @EnableAutoConfiguration @SpringBootApplication(scanBasePackages = "com.mao") public class DemoApp { public static void main(String[] args) throws Exception { SpringApplication.run(DemoApp.class, args); } }
package com.mao.swagger.config; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import io.swagger.annotations.ApiOperation; import springfox.documentation.builders.RequestHandlerSelectors; import springfox.documentation.spi.DocumentationType; import springfox.documentation.spring.web.plugins.Docket; import springfox.documentation.swagger2.annotations.EnableSwagger2; @Configuration @EnableSwagger2 public class SwaggerConfig { @Bean public Docket swaggerSpringMvcPlugin() { return new Docket(DocumentationType.SWAGGER_2).select().apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class)).build(); } }
package com.mao.swagger.controller; import org.springframework.http.HttpStatus; import org.springframework.http.MediaType; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.mao.swagger.beans.ResObject; import com.mao.swagger.beans.User; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; /** * Hello world! * */ @Api(description = "用戶接口") @RestController @RequestMapping("/demoController") public class DemoController { @ApiOperation(value = "新增用戶" , notes="新增註冊") @RequestMapping(value="/createUser",method=RequestMethod.POST,consumes= MediaType.APPLICATION_JSON_VALUE) public ResObject createUser(@RequestBody User user){ System.out.println("createUser:::"+user.toString()); return new ResObject(HttpStatus.OK.value(), "新增成功."); } @ApiOperation(value = "修改用戶" , notes="修改用戶") @RequestMapping(value="/updateUser",method=RequestMethod.POST,consumes= MediaType.APPLICATION_JSON_VALUE) public ResObject updateUser(@RequestBody User user){ System.out.println("updateUser:::"+user.toString()); return new ResObject(HttpStatus.OK.value(), "修改爲功."); } @ApiOperation(value = "刪除用戶" , notes="刪除用戶") @ApiImplicitParams({ @ApiImplicitParam(name = "userId", value = "用戶標識", required = true, paramType = "query", dataType = "String") }) @RequestMapping(value="/deleteUser",method=RequestMethod.DELETE) public ResObject deleteUser(@RequestParam("userId") String userId){ System.out.println("deleteUser:::"+userId); return new ResObject(HttpStatus.OK.value(), "刪除成功."); } @ApiOperation(value = "查詢用戶" , notes="查詢用戶") @ApiImplicitParams({ @ApiImplicitParam(name = "userId", value = "用戶標識", required = true, paramType = "query", dataType = "String") }) @RequestMapping(value="/queryUser",method=RequestMethod.GET) public ResObject queryUser(@RequestParam("userId") String userId){ System.out.println("queryUser:::"+userId); User user = new User(userId, "張三", "******", "mao2080@sina.com"); return new ResObject(HttpStatus.OK.value(), user); } }
按照上面的啓動以後訪問:http://localhost:8080/swagger-ui.html 發現找不到接口web
後面排查是由於沒有添加掃描包spring
重啓以後再刷新便可後端
點擊demo-controller能夠看到詳細接口api
點擊具體接口能夠看到具體參數架構
點擊try it out! 能夠測試接口。app
後臺打印日誌框架
swagger-demo.zipspring-boot
http://www.javashuo.com/article/p-ddflbqug-bw.html
https://blog.csdn.net/blackmambaprogrammer/article/details/72354007