SprimgMVC学习笔记(九)—— RESTful支持

本文深入浅出地讲解了RESTful API的设计理念,包括资源定位、操作方式以及如何使用HTTP方法进行CRUD操作。通过对比传统操作资源的方式,阐述了RESTful风格的优势,并提供了具体的案例演示如何使用注解实现商品信息的查询。

一、什么是restful?

  Restful就是一个资源定位及资源操作的风格,其核心是面向资源。不是标准也不是协议,只是一种风格。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。REST提出设计概念和准则为:

    1. 网络上的所有事物都可以被抽象为资源(resource)
    2. 每一个资源都有唯一的资源标识(resource identifier),对资源的操作不会改变这些标识
    3. 所有的操作都是无状态的

  REST简化开发,其架构遵循CRUD原则,该原则告诉我们对于资源(包括网络资源)只需要四种行为:创建(Create),获取(Retrieve),更新(Update)和删除(Delete)就可以完成相关的操作和处理。我们可以通过统一资源标识符(Universal Resource Identifier,URI)来识别和定位资源,并且针对这些资源而执行的操作是通过 HTTP 规范定义的。其支持的四种核心操作分别为:

  • GET – 获取信息/请求信息内容。绝大多数浏览器获取信息时使用该方式。
  • POST – 添加信息内容。显示曾经的信息内容,能够看作是insert操作
  • PUT – 更新信息内容。相当与update
  • DELETE – 删除信息内容能够看作是delete

  传统方式操作资源:

    • http://127.0.0.1/item/queryItem.action?id=1      查询,GET

    • http://127.0.0.1/item/saveItem.action                 新增,POST

    • http://127.0.0.1/item/updateItem.action             更新,POST

    • http://127.0.0.1/item/deleteItem.action?id=1      删除,GET或POST

  使用RESTful操作资源:

    • http://127.0.0.1/item/1          查询,GET

    • http://127.0.0.1/item              新增,POST

    • http://127.0.0.1/item              更新,PUT

    • http://127.0.0.1/item/1          删除,DELETE

二、RESTful入门案例

2.1 需求

  使用RESTful方式实现商品信息查询,返回json数据

2.2 从URL上获取参数

  使用RESTful风格开发的接口,根据id查询商品,接口地址是:http://127.0.0.1/item/1

  我们需要从url上获取商品id,步骤如下:

  1. 使用注解@RequestMapping("item/{id}")声明请求的url

    {xxx}叫做占位符,请求的URL可以是“item/1”或“item/2” 
  2. 使用(@PathVariable() Integer id)获取url上的数据
    /**
     * 使用RESTful风格开发接口,实现根据id查询商品
     * 
     * @param id
     * @return
     */
    @RequestMapping("item/{id}")
    @ResponseBody
    public Item queryItemById(@PathVariable() Integer id) {
        Item item = this.itemService.queryItemById(id);
        return item;
    }

    如果@RequestMapping中表示为"item/{id}",id和形参名称一致,@PathVariable不用指定名称。如果不一致,例如"item/{ItemId}"则需要指定名称@PathVariable("itemId")。

  注意两个区别

  •  @PathVariable是获取url上数据的。@RequestParam获取请求参数的(包括post表单提交)

  •  如果加上@ResponseBody注解,就不会走视图解析器,不会返回页面,而是返回json数据。如果不加,就走视图解析器,返回页面

 

转载于:https://www.cnblogs.com/yft-javaNotes/p/10216539.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值