前后端分离时代: 前端 -> 前端控制层,前端视图层 后端 -> 后端控制层,服务处,数据接入层 前后端通过API进行交互,可以使得程序独立且松耦合
swagger是什么?swagger是一款让你更好的书写API文档的规范且完整的框架,提供了描述生产,消费和可视化的RESTful 风格编程,是由庞大的工具集合支撑的形式化规范,这个集合涵盖了从终端用户接口,底层代码到商业的API管理层面!
为什么要用swaggerswagger为前端和后端程序员提供了更为规范的API文档,减少在开发过程的各自产生的分歧!
使用swagger有什么好处? 世界上最流行的API框架RESTful API文档在线自动生成器API文档和API定义同步更新直接运行,可以在线测试API支持多种语言,Java,C#,PHP等测试最基本的环境:
编写controller
@RestController @RequestMapping("hello") public class HelloController { @RequestMapping("sayHello") public String sayHello(){ return "Hello Swagger"; } }访问:http://localhost:8080/hello/sayHello 环境搭建完成!
访问:http://localhost:8080/swagger-ui.html
WithMethodAnnotation(GetMapping.class):表示只扫描方法上加了GetMapping的get请求 WithClassAnnotation(Controller.class):表示只扫描类上加上了@Controller的接口
除此之外还可以配置接口扫描过滤 实例:
//配置swagger的docket实例 @Bean public Docket docket(){ return new Docket(DocumentationType.SWAGGER_2). apiInfo(getApiInfo()). select(). //select配置扫描的接口 apis(RequestHandlerSelectors.basePackage("com.liuzeyu.controller")). paths(PathSelectors.ant("/haha/**")). //扫描controller包下haha包下的接口 build(); }接口的扫描位置在com.liuzeyu.controller包下的/haha下的任意接口! 此时写了一个控制类: swagger界面:
如果有一个需求,让swagger在生产环境下使用!
准备多生产环境 swagger配置:
//配置swagger的docket实例 @Bean public Docket docket(Environment environment){ Profiles profiles = Profiles.of("dev","test"); boolean flag = environment.acceptsProfiles(profiles); System.out.println(flag); return new Docket(DocumentationType.SWAGGER_2). apiInfo(getApiInfo()). enable(flag). select(). //select配置扫描的接口 apis(RequestHandlerSelectors.basePackage("com.liuzeyu.controller")). paths(PathSelectors.ant("/haha/**")). //扫描controller包下haha包下的接口 build(); }生产环境下可以正常使用swagger 如果注释掉# spring.profiles.active=dev
则关闭swagger
一个分组对应这个一个Docket实例。所有如果需要多个分组,我们应当在容器中注入多个Docket实例。
//配置swagger的docket实例 //分组:liuzeyu @Bean public Docket docket(Environment environment){ Profiles profiles = Profiles.of("dev","test"); boolean flag = environment.acceptsProfiles(profiles); System.out.println(flag); return new Docket(DocumentationType.SWAGGER_2). apiInfo(getApiInfo()). enable(flag). groupName("liuzeyu"). select(). //select配置扫描的接口 apis(RequestHandlerSelectors.basePackage("com.liuzeyu.controller")). paths(PathSelectors.ant("/haha/**")). //扫描controller包下haha包下的接口 build(); } @Bean public Docket docket_A(){ return new Docket(DocumentationType.SWAGGER_2).groupName("A"); } @Bean public Docket docket_B(){ return new Docket(DocumentationType.SWAGGER_2).groupName("B"); }实际开发中,不同的分组应当对应着不同的开发人员,这样大项目的接口开发分工就会更加明确!
运用在实体类上的注解有 @ApiModel :为实体类添加注释 @ApiModelProperty:为实体类属性添加注释 在io.swagger.annotations下,还有一些常用的注解:
swagger注解简单说明@Api(tag=“xxxx模块说明”)作用在类上@ApiOperation(“xxx接口说明”)作用在接口方法上@ApiParam(“xxx”)作用在j接口方法的字段上主要目的就是为了生成友好的接口文档,让人跟容易阅读!
参考:https://www.bilibili.com/video/BV1PE411i7CV?p=50