Restful

内容纲要

Rest

Rest的全称是Representational State Transfer 。Rest是一种架构风格。Rest有很多原则和限制:

  1. 客户端-服务端架构模式
  2. 无状态
  3. 可缓存
  4. 统一接口
  5. 分层系统
  6. 按需缓存

Rest对我们开发人员来说基本上就是资源,我们一般通过URI表示我们请求的一个资源。例如:我们想要查询一个用户则可以用"/user/{userId}"来表示。

Rest与HTTP

HTTP动词

GET: 获取资源
POST: 新增资源
PUT: 更新资源
DELETE: 删除资源

举例

URI为: /order/{orderId}
获取一个订单:GET /order/{orderId}
新增一个订单:POST /order
更新一个订单:PUT /order/{orderId}
删除一个订单:DELETE /order/{orderId}
订单列表: GET /order/list?pageNo=1&pageSize=2

Spring MVC对Rest的支持

  1. @RestController表示一个Rest风格的接口,所有的path自动返回JSON。
  2. @GetMapping("/order/{orderId}") : 获取一个订单:GET /order/{orderId}
  3. @PostMapping("/order"): 新增一个订单:POST /order
  4. @PutMapping("/order/{orderId}"): 更新一个订单:PUT /order/{orderId}
  5. @DeleteMapping("/order/{orderId}"): 删除一个订单:DELETE /order/{orderId}
  6. GetMapping("/order/list"):订单列表

一个问题

在实际使用Rest风格接口时,我们可能会有这样的接口定义"/user/{username}, /user/{userNo}, /user/{userId}", 其中{username}, {userNo}, {userId}可能都是字符串spring是无法走到你期望的Controller/RequestMapping里面去的,所以在我们日常工作中应该避免这样的定义或者帮Spring去除歧义,比如:/user/uname/{username}, /user/no/{userno}, /user/id/{userId}。

参考

  1. Representational State Transfer (REST)

发表评论

您的电子邮箱地址不会被公开。 必填项已用 * 标注

滚动至顶部