RESTful风格下,代码需遵守安全性(例如get操作获取资源时,不应该引起资源本身的改变或者服务器状态的改变。什么样的方法做什么样的事)和幂等性(服务器中资源的第一次请求和第n次请求返回的效果是相同的)
RESTful风格下,一些常用的http方法使用如下:
状态码补充:
springboot实现RESTful API过程中,spring-boot-starter-web组件提供了REST操纵方法的对应注解(GET,POST,DELETE,PUT):

传统的设计方法中,对于增删改查数据往往在导航栏中有动词的参入。RESTful风格中。则要求url不要带有动词的出现。
例如:
传统删除用户:get方法 http://localhost/del?id=10
RESTful删除用户:delete http;//localhost/user/10
RESTful API实现的用户管理模块API示例:

(put之所以不用id是输入在请求体中而非导航栏)
@RestController
public class usercontroller {
@GetMapping("/user/{id}")
public String getuserbyid(@PathVariable int id){
System.out.println(id);
return "根据ID获取用户";
}
@PostMapping("/user")
public String insertuser(User user){
return "添加用户";
}
@PutMapping("/user")
public String updateuser(User user){
return "更新用户";
}
@DeleteMapping("/user/{id}")
public String deleteuserbyid(@PathVariable int id){
System.out.println(id);
return "根据id删除用户";
}
}

@GetMapping注解中id作为动态值,需要加上{ }符号,{}的值应与下面方法名中的变量名相同。同时id作为动态变量,应在前面加上注解@PathVariable。否则只能用"?"来连接变量。

更新以及添加用户,id等信息一般写在请求体中,方法变量中则使用实体类变量。
**Swagger UI:**简单说:它是后端接口的 "可视化调试面板 + 自动更新的说明书",开发者 / 测试人员可通过网页直观查看、测试所有接口。后端开发者通过此网页直观方便的展示给前端开发者接口或传输方式等信息。
配置如下:
1,pom.xml中添加如下两个依赖
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.9.2</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.9.2</version>
</dependency>
2,编写配置类
@Configuration //告诉spring容器此类为配置类
@EnableSwagger2 //启用swagger2的功能
public class Swaggerconfig {
@Bean
public Docket createRestApi() {
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(apiInfo())
.select()
.apis(RequestHandlerSelectors.basePackage("com"))// 让swagger作用于com开头的根目录,也可另做修改
.paths(PathSelectors.any()).build();
}
/**
* 此处主要是API文档页面显示信息
*/
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title("演示项目API") // 标题
.description("演示项目") // 描述
.version("1.0") // 版本
.build();
}
}
3,在application.properties中添加以下代码,让2.6+至2.9.x间的高版本springboot可以适配使用。
spring.mvc.pathmatch.matching-strategy=ant_path_matcher
(注意检查application.properties中是否有' #spring.mvc.static-path-pattern=/images/** '此行修改静态文件路径的代码,这会一同修改swagger的访问路径,若有则会冲突)
4,配置好后通过访问localhost:8080/swagger-ui.html来访问网页

显示的是自己程序中的controller类
5,可以在controller类中添加注解来注释对应的方法

