一、RESTful
GET获取资源、POST新建资源、PUT更新资源、DELETE删除资源。
RESTful两大特性
1、安全性:GET请求不会引起资源本身改变。
2、幂等性:对一个接口请求和多次请求返回的资源应该一致。
2xx:成功
4xx:客户端错误。
5xx:服务器错误。
URI中不要包含动词
通过使用PathVariable注解获取{id}
@GetMapping("/user/{id}")
public String getUserById(@PathVariable int id){
System.out.println(id);
return "根据ID获取用户信息";
}
二、Swagger
用于生成、描述、调用和可视化RESTful风格的Web服务。
配置方法
添加包。这里使用到的swagger2的版本是2.9.2记得把springboot的版本改成2.5.6!!!
<!-- swagger2相关功能 -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.9.2</version>
</dependency>
<!-- swagger2ui -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.9.2</version>
</dependency>
创建SwaggerConfig.java
文件,专门放在config包下。
把代码放进去就好了。
注意这里重写了addResourceHandlers方法
package com.example.hello.config;
import io.swagger.annotations.ApiOperation;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
//Spingboot中配置类必须要加注解
@Configuration
@EnableSwagger2
public class SwaggerConfig implements WebMvcConfigurer {
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("swagger-ui.html")
.addResourceLocations("classpath:/META-INF/resources/");
registry.addResourceHandler("/webjars/**")
.addResourceLocations("classpath:/META-INF/resources/webjars/");
}
/*
* 配置swagger2相关Bean
* */
@Bean
public Docket createRestApi(){
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(apiInfo())
.select()
.apis(RequestHandlerSelectors.basePackage("com")) //com包下所有API都交给Swagger2管理
.paths(PathSelectors.any())
.build();
}
/*
* 此处主要是API文档页面显示信息
* */
private ApiInfo apiInfo(){
return new ApiInfoBuilder()
.title("演示项目API") //标题
.description("演示项目") //描述
.version("1.0")
.build();
}
}
http://localhost:8080/swagger-ui.html/
然后就成功了
除此之外,还能给每个接口增加说明,需要到后端指定接口处去增加。
例如说,我在hello2这个方法增加了注解,要使用@ApiOperation("")
注解
在swagger展示如下。