集成Swagger

Swagger简介

前后端分离

  • 前端 -> 前端控制层、视图层
  • 后端 -> 后端控制层、服务层、数据访问层
  • 前后端通过API进行交互
  • 前后端相对独立且松耦合

产生的问题

  • 前后端集成,前端或者后端无法做到“及时协商,尽早解决”,最终导致问题集中爆发

解决方案

  • 首先定义schema [ 计划的提纲 ],并实时跟踪最新的API,降低集成风险

Swagger

  • 号称世界上最流行的API框架
  • Restful Api 文档在线自动生成器 => API 文档 与API 定义同步更新
  • 直接运行,在线测试API
  • 支持多种语言 (如:Java,PHP等)
  • 官网:https://swagger.io/

SpringBoot集成Swagger

步骤:

1、新建一个SpringBoot-web项目

2、添加Maven依赖

  1. <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui -->
  2. <dependency>
  3. <groupId>io.springfox</groupId>
  4. <artifactId>springfox-swagger-ui</artifactId>
  5. <version>2.9.2</version>
  6. </dependency>
  7. <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 -->
  8. <dependency>
  9. <groupId>io.springfox</groupId>
  10. <artifactId>springfox-swagger2</artifactId>
  11. <version>2.9.2</version>
  12. </dependency>

3、编写HelloController,测试确保运行成功!

4、要使用Swagger,我们需要编写一个配置类-SwaggerConfig来配置 Swagger

  1. @Configuration
  2. @EnableSwagger2 // 开启Swagger2
  3. public class SwaggerConfig {
  4. // 配置docket以配置Swagger具体参数
  5. @Bean
  6. public Docket docket(Environment environment){
  7. // 设置要显示的Swagger 环境
  8. // Profiles profiles = Profiles.of("dev","test");
  9. // 通过environment.acceptsProfiles 判断是否处在自己设定的环境当中
  10. // boolean flag = environment.acceptsProfiles(profiles);
  11. return new Docket(DocumentationType.SWAGGER_2)
  12. .groupName("少帅")
  13. .apiInfo(apiInfo())
  14. .enable(true) // enable是否启动Swagger, 如果为False, 则Swagger 不能再浏览器中访问
  15. .select()
  16. // RequestHandlerSelectors, 配置要扫描接口的方式
  17. // basePackage: 指定要扫描的包
  18. // any(): 扫描全部
  19. // none(): 不扫描
  20. // withClassAnnotation: 扫描类上的注解,参数是一个注解的反射对象
  21. // withMethodAnnotation: 扫描方法上的注解
  22. .apis(RequestHandlerSelectors.basePackage("com.shuai.controller"))
  23. // paths()。 过滤什么路径
  24. // .paths(PathSelectors.ant("/shuai/**"))
  25. .build();
  26. }
  27. @Bean
  28. public Docket docket1(){
  29. return new Docket(DocumentationType.SWAGGER_2).groupName("A");
  30. }
  31. @Bean
  32. public Docket docket2(){
  33. return new Docket(DocumentationType.SWAGGER_2).groupName("B");
  34. }
  35. @Bean
  36. public Docket docket3(){
  37. return new Docket(DocumentationType.SWAGGER_2).groupName("C");
  38. }
  39. // 配置Swagger信息 = apiInfo
  40. private ApiInfo apiInfo(){
  41. // 作者信息
  42. Contact contact = new Contact("少帅", "https://www.cnblogs.com/shaoshuai2126/", "2895788257@qq.com");
  43. return new ApiInfo(
  44. "小帅玩编程", // 标题
  45. "每天努力亿点点", // 描述
  46. "V1.0", // 版本
  47. "https://www.cnblogs.com/shaoshuai2126/", // 组织链接
  48. contact, // 联系人信息
  49. "Apache 2.0", // 许可
  50. "http://www.apache.org/licenses/LICENSE-2.0", // 许可链接
  51. new ArrayList() // 扩展
  52. );
  53. }
  54. }

5、访问测试 :http://localhost:8080/swagger-ui.html ,可以看到swagger的界面;

实体配置

1、新建一个实体类

  1. @ApiModel("用户实体类")
  2. public class User {
  3. @ApiModelProperty("用户名")
  4. private String username;
  5. @ApiModelProperty("密码")
  6. private String password;
  7. }

2、编写HelloController

  1. @RestController
  2. public class HelloController {
  3. @GetMapping("/hello")
  4. public String hello(){
  5. return "hello";
  6. }
  7. // 只要我们的接口中,返回值存在实体类,他就会被扫描到Swagger中!
  8. @PostMapping("/user")
  9. public User user(){
  10. return new User();
  11. }
  12. // ApiOperation接口,不是放在类上的,是方法
  13. @ApiOperation("hello2方法")
  14. @GetMapping("/hello2")
  15. public String hello2(@ApiParam("用户名") String username){
  16. return "hello"+username;
  17. }
  18. @ApiOperation("postt方法")
  19. @GetMapping("/postt")
  20. public User postt(@ApiParam("用户信息") User user){
  21. return user;
  22. }
  23. }

拓展:其他皮肤

我们可以导入不同的包实现不同的皮肤定义:

1、默认的 访问 http://localhost:8080/swagger-ui.html

  1. <dependency>
  2. <groupId>io.springfox</groupId>
  3. <artifactId>springfox-swagger-ui</artifactId>
  4. <version>2.9.2</version>
  5. </dependency>

2、bootstrap-ui 访问 http://localhost:8080/doc.html

  1. <!-- 引入swagger-bootstrap-ui包 /doc.html-->
  2. <dependency>
  3. <groupId>com.github.xiaoymin</groupId>
  4. <artifactId>swagger-bootstrap-ui</artifactId>
  5. <version>1.9.1</version>
  6. </dependency>

3、Layui-ui 访问 http://localhost:8080/docs.html

  1. <!-- 引入swagger-ui-layer包 /docs.html-->
  2. <dependency>
  3. <groupId>com.github.caspar-chen</groupId>
  4. <artifactId>swagger-ui-layer</artifactId>
  5. <version>1.1.3</version>
  6. </dependency>

4、mg-ui 访问 http://localhost:8080/document.html

  1. <!-- 引入swagger-ui-layer包 /document.html-->
  2. <dependency>
  3. <groupId>com.zyplayer</groupId>
  4. <artifactId>swagger-mg-ui</artifactId>
  5. <version>1.0.6</version>
  6. </dependency>

任务

一、异步任务

1、在项目主入口开启注解

  1. @EnableAsync // 开启异步注解功能

2、在service文件夹下创建AsyncService类

  1. @Service
  2. public class AsyncService {
  3. // 告诉Spring这是一个异步的方法
  4. @Async
  5. public void hello(){
  6. try {
  7. Thread.sleep(3000);
  8. } catch (InterruptedException e) {
  9. e.printStackTrace();
  10. }
  11. System.out.println("数据正在处理....");
  12. }
  13. }

3、编写一个AsyncController的类

  1. @RestController
  2. public class AsyncController {
  3. @Autowired
  4. AsyncService asyncService;
  5. @RequestMapping("/hello")
  6. public String hello(){
  7. asyncService.hello(); // 停止三秒,转圈~
  8. return "ok";
  9. }
  10. }

二、邮件任务

1、开启qq邮箱的pop3服务

2、在application中写入有邮件发送的配置

3、测试发送邮件(上网上查找格式,代码格式基本上固定)

三、定时任务

1、在项目主入口开启注解

  1. @EnableScheduling // 开启定时功能的注解

2、在service文件夹下创建AsyncService类

  1. @Service
  2. public class ScheduledService {
  3. // 在特定的时间执行这个方法~ Timer
  4. // cron 表达式(不会的可以上网上查找,都是的)
  5. // 秒 分 时 日 月 周几~
  6. /*
  7. 30 09 22 * * ? 每天22点09分30秒 执行一次
  8. 30 0/5 10,18 * * ? 每天10点和18点,每隔五分钟执行一次
  9. 0 15 10 ? * 1-6 每个月的周一到周六 10.15分钟执行一次
  10. */
  11. @Scheduled(cron = "30 09 22 * * ?")
  12. public void hello(){
  13. System.out.println("hello,你被执行了~");
  14. }
  15. }