集成Swagger
Swagger简介
前后端分离
- 前端 -> 前端控制层、视图层
- 后端 -> 后端控制层、服务层、数据访问层
- 前后端通过API进行交互
- 前后端相对独立且松耦合
产生的问题
- 前后端集成,前端或者后端无法做到“及时协商,尽早解决”,最终导致问题集中爆发
解决方案
- 首先定义schema [ 计划的提纲 ],并实时跟踪最新的API,降低集成风险
Swagger
- 号称世界上最流行的API框架
- Restful Api 文档在线自动生成器 => API 文档 与API 定义同步更新
- 直接运行,在线测试API
- 支持多种语言 (如:Java,PHP等)
- 官网:https://swagger.io/
SpringBoot集成Swagger
步骤:
1、新建一个SpringBoot-web项目
2、添加Maven依赖
<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui --><dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger-ui</artifactId><version>2.9.2</version></dependency><!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 --><dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger2</artifactId><version>2.9.2</version></dependency>
3、编写HelloController,测试确保运行成功!
4、要使用Swagger,我们需要编写一个配置类-SwaggerConfig来配置 Swagger
@Configuration@EnableSwagger2 // 开启Swagger2public class SwaggerConfig {// 配置docket以配置Swagger具体参数@Beanpublic Docket docket(Environment environment){// 设置要显示的Swagger 环境// Profiles profiles = Profiles.of("dev","test");// 通过environment.acceptsProfiles 判断是否处在自己设定的环境当中// boolean flag = environment.acceptsProfiles(profiles);return new Docket(DocumentationType.SWAGGER_2).groupName("少帅").apiInfo(apiInfo()).enable(true) // enable是否启动Swagger, 如果为False, 则Swagger 不能再浏览器中访问.select()// RequestHandlerSelectors, 配置要扫描接口的方式// basePackage: 指定要扫描的包// any(): 扫描全部// none(): 不扫描// withClassAnnotation: 扫描类上的注解,参数是一个注解的反射对象// withMethodAnnotation: 扫描方法上的注解.apis(RequestHandlerSelectors.basePackage("com.shuai.controller"))// paths()。 过滤什么路径// .paths(PathSelectors.ant("/shuai/**")).build();}@Beanpublic Docket docket1(){return new Docket(DocumentationType.SWAGGER_2).groupName("A");}@Beanpublic Docket docket2(){return new Docket(DocumentationType.SWAGGER_2).groupName("B");}@Beanpublic Docket docket3(){return new Docket(DocumentationType.SWAGGER_2).groupName("C");}// 配置Swagger信息 = apiInfoprivate ApiInfo apiInfo(){// 作者信息Contact contact = new Contact("少帅", "https://www.cnblogs.com/shaoshuai2126/", "2895788257@qq.com");return new ApiInfo("小帅玩编程", // 标题"每天努力亿点点", // 描述"V1.0", // 版本"https://www.cnblogs.com/shaoshuai2126/", // 组织链接contact, // 联系人信息"Apache 2.0", // 许可"http://www.apache.org/licenses/LICENSE-2.0", // 许可链接new ArrayList() // 扩展);}}
5、访问测试 :http://localhost:8080/swagger-ui.html ,可以看到swagger的界面;
实体配置
1、新建一个实体类
@ApiModel("用户实体类")public class User {@ApiModelProperty("用户名")private String username;@ApiModelProperty("密码")private String password;}
2、编写HelloController
@RestControllerpublic class HelloController {@GetMapping("/hello")public String hello(){return "hello";}// 只要我们的接口中,返回值存在实体类,他就会被扫描到Swagger中!@PostMapping("/user")public User user(){return new User();}// ApiOperation接口,不是放在类上的,是方法@ApiOperation("hello2方法")@GetMapping("/hello2")public String hello2(@ApiParam("用户名") String username){return "hello"+username;}@ApiOperation("postt方法")@GetMapping("/postt")public User postt(@ApiParam("用户信息") User user){return user;}}
拓展:其他皮肤
我们可以导入不同的包实现不同的皮肤定义:
1、默认的 访问 http://localhost:8080/swagger-ui.html
<dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger-ui</artifactId><version>2.9.2</version></dependency>
2、bootstrap-ui 访问 http://localhost:8080/doc.html
<!-- 引入swagger-bootstrap-ui包 /doc.html--><dependency><groupId>com.github.xiaoymin</groupId><artifactId>swagger-bootstrap-ui</artifactId><version>1.9.1</version></dependency>
3、Layui-ui 访问 http://localhost:8080/docs.html
<!-- 引入swagger-ui-layer包 /docs.html--><dependency><groupId>com.github.caspar-chen</groupId><artifactId>swagger-ui-layer</artifactId><version>1.1.3</version></dependency>
4、mg-ui 访问 http://localhost:8080/document.html
<!-- 引入swagger-ui-layer包 /document.html--><dependency><groupId>com.zyplayer</groupId><artifactId>swagger-mg-ui</artifactId><version>1.0.6</version></dependency>
任务
一、异步任务
1、在项目主入口开启注解
@EnableAsync // 开启异步注解功能
2、在service文件夹下创建AsyncService类
@Servicepublic class AsyncService {// 告诉Spring这是一个异步的方法@Asyncpublic void hello(){try {Thread.sleep(3000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println("数据正在处理....");}}
3、编写一个AsyncController的类
@RestControllerpublic class AsyncController {@AutowiredAsyncService asyncService;@RequestMapping("/hello")public String hello(){asyncService.hello(); // 停止三秒,转圈~return "ok";}}
二、邮件任务
1、开启qq邮箱的pop3服务
2、在application中写入有邮件发送的配置
3、测试发送邮件(上网上查找格式,代码格式基本上固定)
三、定时任务
1、在项目主入口开启注解
@EnableScheduling // 开启定时功能的注解
2、在service文件夹下创建AsyncService类
@Servicepublic class ScheduledService {// 在特定的时间执行这个方法~ Timer// cron 表达式(不会的可以上网上查找,都是的)// 秒 分 时 日 月 周几~/*30 09 22 * * ? 每天22点09分30秒 执行一次30 0/5 10,18 * * ? 每天10点和18点,每隔五分钟执行一次0 15 10 ? * 1-6 每个月的周一到周六 10.15分钟执行一次*/@Scheduled(cron = "30 09 22 * * ?")public void hello(){System.out.println("hello,你被执行了~");}}
