11.5 Spring Boot 实现 RESTFul

1、认识 RESTFul

  • REST(英文:Representational State Transfer,简称REST
  • 一种互联网软件架构设计的风格,但它并不是标准,它只是提出了一组客户端和服务器交互时的架构理念和设计原则,基于这种理念和原则设计的接口可以更简洁,更有层次,REST这个词,是Roy Thomas Fielding在他2000年的博士论文中提出的。
  • ***以前:访问资源(图片,servlet程序),请求资源同时带上请求方式,如果get请求直接访问到doget方法上,如果post请求直接访问到dopost
  • ***rest理念访问资源:请求资源,然后按照请求的方式进行处理,如果说get方式,查询操作,如果put 更新操作,如果是delete方式 删除资源,如果是post方式 添加资源
  • 任何的技术都可以实现这种理念,如果一个架构符合REST原则,就称它为RESTFul架构
  • 外在体现:
  • 比如我们要访问一个http接口:http://localhost:8080/boot/order?id=1021&status=1
  • 采用RESTFul风格则http地址为:http://localhost:8080/boot/order/1021/1

2、Spring Boot开发RESTFul

Spring boot开发RESTFul 主要是几个注解实现:

  • @PathVariable获取url中的数据,该注解是实现RESTFul最主要的一个注解
  • @PostMapping接收和处理Post方式的请求
  • @DeleteMapping:接收delete方式的请求,可以使用GetMapping代替

  • @PutMapping接收put方式的请求,可以用PostMapping代替
  • @GetMapping:接收get方式的请求

3、RestFul 风格的优点

  • 轻量,直接基于http,不再需要任何别的诸如消息协议

get/post/put/delete为CRUD操作

  • 面向资源一目了然,具有自解释性
  • 数据描述简单,一般以xml,json做数据交换。
  • 无状态,在调用一个接口(访问、操作资源)的时候,可以不用考虑上下文,不用考虑当前状态,极大的降低了复杂度。
  • 简单、低耦合

 4、案例:使用RESTful风格模拟实现对学生的增删改查操作

①创建RESTfulController,并编写代码

@RestController
public class RESTfulController {

    /**
     * 添加学生
     * 请求地址:http://localhost:9090/014-springboot-restful/springBoot/student/wangpeng/23
     * 请求方式:POST
     * @param name
     * @param age
     * @return
     */
    @PostMapping(value = "/springBoot/student/{name}/{age}")
    public Object addStudent(@PathVariable("name") String name,
                             @PathVariable("age") Integer age) {

        Map<String,Object> retMap = new HashMap<String, Object>();
        retMap.put("name",name);
        retMap.put("age",age);


        return retMap;
    }

    /**
     * 删除学生
     * 请求地址:http://localhost:9090/014-springboot-restful/springBoot/student/1
     * 请求方式:Delete
     * @param id
     * @return
     */
    @DeleteMapping(value = "/springBoot/student/{id}")
    public Object removeStudent(@PathVariable("id") Integer id) {

        return "删除的学生id为:" + id;
    }

    /**
     * 修改学生信息
     * 请求地址:http://localhost:9090/014-springboot-restful/springBoot/student/2
     * 请求方式:Put
     * @param id
     * @return
     */
    @PutMapping(value = "/springBoot/student/{id}")
    public Object modifyStudent(@PathVariable("id") Integer id) {

        return "修改学生的id为" + id;
    }

    @GetMapping(value = "/springBoot/student/{id}")
    public Object queryStudent(@PathVariable("id") Integer id) {

        return "查询学生的id为" + id;
    }
}

②使用Postman模拟发送请求,进行测试

 

 

 

 小结:

  • 传递参数变简单了
  • 服务提供者对外只提供了一个接口服务,而不是传统的CRUD四个接口

5、请求冲突问题

  • 创建RESTfulController类,结合Postman进行测试说明
@RestController
public class RESTfulController {


    /**
     * id:订单标识
     * status:订单状态
     * 请求路径:http://localhost:9090/015-springboot-restful-url-conflict/springBoot/order/1/1001
     * @param id
     * @param status
     * @return
     */
    @GetMapping(value = "/springBoot/order/{id}/{status}")
    public Object queryOrder(@PathVariable("id") Integer id,
                             @PathVariable("status") Integer status) {

        Map<String,Object> map = new HashMap<String,Object>();

        map.put("id",id);
        map.put("status",status);

        return map;
    }

    /**
     * id:订单标识
     * status:订单状态
     * 请求路径:http://localhost:9090/015-springboot-restful-url-conflict/springBoot/1/order/1001
     * @param id
     * @param status
     * @return
     */
    @GetMapping(value = "/springBoot/{id}/order/{status}")
    public Object queryOrder1(@PathVariable("id") Integer id,
                              @PathVariable("status") Integer status) {
        Map<String,Object> map = new HashMap<String,Object>();

        map.put("id",id);
        map.put("status",status);

        return map;
    }

    /**
     * id:订单标识
     * status:订单状态
     * 请求路径:http://localhost:9090/015-springboot-restful-url-conflict/springBoot/1001/order/1
     * @param id
     * @param status
     * @return
     */
    @GetMapping(value = "/springBoot/{status}/order/{id}")
    public Object queryOrder2(@PathVariable("id") Integer id,
                              @PathVariable("status") Integer status) {
        Map<String,Object> map = new HashMap<String,Object>();

        map.put("id",id);
        map.put("status",status);

        return map;
    }

    /**
     * id:订单标识
     * status:订单状态
     * 请求路径:http://localhost:9090/015-springboot-restful-url-conflict/springBoot/1001/order/1
     * @param id
     * @param status
     * @return
     */
    @PostMapping(value = "/springBoot/{status}/order/{id}")
    public Object queryOrder3(@PathVariable("id") Integer id,
                              @PathVariable("status") Integer status) {
        Map<String,Object> map = new HashMap<String,Object>();

        map.put("id",id);
        map.put("status",status);

        return map;
    }




    /**
     * query1和query2两个请求路径会发生请求路径冲突问题
     * query3与query1和query2发生请求不冲突
     * 注意:虽然两个路径写法改变了,但是由于传递的两个参数都是int值,所以不知道该交给哪个请求进行处理
     *      就会出现匹配模糊不清的异常,所以要想解决冲突,有两种方式:
     *      1.修改请求路径
     *      2.修改请求方式
     */
}

 

6、RESTFUL 原则 

  • 增post请求、删delete请求、改put请求、查get请求
  • 请求路径不要出现动词

例如:查询订单接口

/boot/order/1021/1(推荐)

/boot/queryOrder/1021/1(不推荐)

  • 分页、排序等操作,不需要使用斜杠传参数

例如:订单列表接口

/boot/orders?page=1&sort=desc

一般传的参数不是数据库表的字段,可以不采用斜杠

***REST:

  1. 请求资源
  2. 请求方式
  3. 根据参数操作
  4. 不是资源的信息(参数),一般不用斜杠传参数,采用质询参数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值