一、RESTFul风格API
1、优点:
- )看Url就知道要什么资源
- )看http method就知道针对资源干什么
- )看http status code就知道结果如何
HTTP方法体现对资源的操作:
GET : 获取资源
POST : 添加资源
PUT : 修改资源
DELETE : 删除资源
二、代码演示:
/** * @author Levi * @date 2019/9/18 9:31 */ @Data @AllArgsConstructor @NoArgsConstructor @Builder public class Animal { private String name; private Integer type; private String num; private Long id; private Date birthDate; }
新建Animal类,使用注解,包含设置get/set方法、全部参数构造器、无参数构造器、builder快速创建对象
/** * @author Levi * @date 2019/9/18 9:36 */ @Slf4j @RestController @RequestMapping("/rest") public class AnimalController { @RequestMapping(value = "/animals", method = POST, produces = "application/json") public AjaxResponse saveArticle(@RequestBody Animal animal) { log.info("saveArticle:{}",animal); return AjaxResponse.success(animal); } @RequestMapping(value = "/animals/{id}", method = DELETE, produces = "application/json") public AjaxResponse deleteArticle(@PathVariable Long id) { log.info("deleteAnimals:{}",id); return AjaxResponse.success(id); } @RequestMapping(value = "/animals/{id}", method = PUT, produces = "application/json") public AjaxResponse updateArticle(@PathVariable Long id, @RequestBody Animal animal) { animal.setId(id); log.info("updateArticle:{}",animal); return AjaxResponse.success(animal); } @RequestMapping(value = "/animals/{id}", method = GET, produces = "application/json") public AjaxResponse getArticle(@PathVariable Long id) { Animal animal = Animal.builder().id(1L).name("levi").build(); return AjaxResponse.success(animal); } }
新建 AnimalController,用postMan做测试:
新建一个post请求(添加),返回创建的对象;
@RestController = @Controller + @ResponseBody
@Slf4j @Controller @RequestMapping("/rest") public class AnimalController { @RequestMapping(value = "/animals", method = POST, produces = "application/json") public @ResponseBody AjaxResponse saveArticle(@RequestBody Animal animal) { log.info("saveArticle:{}",animal); return AjaxResponse.success(animal); }
上述注解可以改为上面的代码所示
@PathVariable 参数说明
delete请求例子
三、json配置:
springboot默认json工具为:jackjson
各种json工具性能对比:https://blog.csdn.net/accountwcx/article/details/50252657
@JsonIgnore 排除属性不做序列化与反序列化
@JsonProperty 为属性换一个名
@JsonPropertyOrder(value={"pname1","pname2"}) 改变json子属性的默认定义的顺序
@JsonInclude(JsonInclude.Include.NON_NULL) 排除为空的元素不做序列化反序列化
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8") 指定属性格式
全局时间配,在yml文件中配置,避免在请求时间的时候,格式不一致报错,
spring:
jackson:
date-format: yyyy-MM-dd HH:mm:ss
time-zone: GMT+8
实际代码演示:
无法识别时间格式:
yml中添加配置,重启项目(一般修改配置文件需要重启项目,否则热部署一般是可以使用的)
没中间的T报错,有就不报错(无解)
这样不报错
@JsonIgnore 排除属性不做序列化与反序列化
@JsonProperty 为属性换一个名
@JsonPropertyOrder(value={"pname1","pname2"}) 改变json子属性的默认定义的顺序
@JsonInclude(JsonInclude.Include.NON_NULL) 排除为空的元素不做序列化反序列化
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8") 指定属性格式
@Data @AllArgsConstructor @NoArgsConstructor @Builder @JsonPropertyOrder(value={"id","type"})//更换变量显示顺序 public class Animal { @JsonIgnore //不支持序列化,不能传参 private String name; @JsonProperty("type1") private Integer type; //空值不返回 @JsonInclude(JsonInclude.Include.NON_NULL) private String num; private Long id; private Date birthDate; ListanimalList; private Animal animal2; }
java实体类:
请求参数
返回值
本节到此结束!!!