原文地址:http://fancy888.iteye.com/blog/1629120

对于运行在网络上的MIS系统而言,处理数据的是整个系统的主要任务,翻开程序我们可以看到,80%以上的代码都在处理数据的CRUD操作。采用一种什么样的框架结构,能够使得处理数据的操作变得简单且易理解,这是大部分开发者尤其是架构设计者一直以来思考的一个问题。

REST(Representational State Transfer)是一种编程风格,特别是针对网络应用的设计和开发,采用REST可以显著降低开发的复杂性,提高系统的可伸缩性。

REST是一种独特的编程风格,与MVC强调的角色分层概念不同,REST强调使用统一的规则来规范对资源的操作,两者互为补充,相符相成,使用 MVC架构搭配REST编程风格构建基于网络的MIS系统将在不远的为未成为主流。本文着重介绍REST编程风格的核心规则,并且结合Spring MVC描述REST在实际应用中的代码形态。

使用REST风格开发WEB应用程序强调以下几点规则:

  1. 网络上的所有事物都被抽象为资源(resource);
  2. 每个资源对应一个唯一的资源标识(resource identifier);
  3. 通过通用的连接器接口(generic connector interface)对资源进行操作;
  4. 对资源的各种操作不会改变资源标识;
  5. 所有的操作都是无状态的(stateless)。

首先,在笔者看来,REST定义中的资源即应用程序所处理的数据。以订单管理系统为例,订单信息就是数据,同样客户信息和产品信息也是数据,在REST看来这些数据都是资源。

REST强调资源必须有具有唯一名称和ID,名称用来区分不同资源,ID用来定位同类资源中唯一的一条数据。在REST中,这些规则都是通过URI 来描述的。还是以上面的订单系统为例,我们将订单信息名称设定为order,客户信息为customer,货物信息为product,那么就存在几下的几 种URI设计:

Html代码  
  1. <!--标识所有的订单信息-->
  2. http://www.coolfancy.com/rest/order
  3. <!--标识所有的客户信息-->
  4. http://www.coolfancy.com/rest/customer
  5. <!--标识ID为1的货物信息-->
  6. http://www.coolfancy.com/rest/product/1

我们可以看出REST风格URI设计的特点:http://host/context/资源名称/[资源ID]。其中资源名称是必选项,资源ID可省略,省略资源ID用来标识一类资源的所有数据。

有了资源和用来标识资源的URI后,REST用连接器来标识对资源的操作。在这里,对资源的操作分为查询/获取、创建、删除、修改四种。在网络编程环境下,REST用HTTP协议作为连接器,用HTTP Method(请求方法)标识操作类型:

  • HTTP GET:查询和获取资源;
  • HTTP POST:创建资源;
  • HTTP PUT: 修改资源;
  • HTTP DELETE: 删除资源。

在完成资源和连接器两个核心概念的定义后,我们已经可以大体勾勒出REST风格编程的基本思路:

  1. 抽象和定义系统中的资源;
  2. 使用REST风格的URI将请求与资源进行绑定;
  3. 使用HTTP请求对资源进行操作;

还用上面提到的订单系统为例,请看下面的例子:

Html代码  
  1. <!--查询类别为服装的货物信息-->
  2. GET /rest/product HTTP/1.1
  3. Host: www.coolfancy.com
  4. productType 服装
Html代码  
  1. <!--查询ID为1的订单信息-->
  2. GET /rest/order/1 HTTP/1.1
  3. Host: www.coolfancy.com
Html代码  
  1. <!--删除ID为1的货物信息-->
  2. DELET /rest/product/1 HTTP/1.1
  3. Host: www.coolfancy.com
Html代码  
  1. <!--创建一条订单信息-->
  2. POST /rest/order HTTP/1.1
  3. Host: www.coolfancy.com
  4. field1 value1
  5. field2 value2
  6. ... ...

简单的说,URI加上HTTP METHOD构成了REST处理数据的核心规则:URI确定了操作的对象,HTTP METHOD则确定了操作的方式。

与传统处理数据的方式不同,如果不使用REST,那么操作的对象和操作方式将混合在URL设计中,正如首次提出REST概念的Roy T. Fielding博士所说的:“REST允许我们通过url设计系统”。事实上Roy也是Web协议的主要设计者,正是在他的参与下完成了HTTP1.1 规范的制定。

站在另一个角度,REST强调资源(数据)的概念,一切操作围绕特定资源展开,离开了资源,REST就失去了存在的意义。在这一点上,REST所倡导的思想与时下流行的Ajax的编程风格有着异曲同工之妙。

Ajax强调数据与展现分离,后台应用程序致力于生产数据,前台使用脚本进行数据的展示。对于数据的组织与传输Ajax并没有内置的支持。而 REST强调通过URI将请求与资源进行绑定,如果将REST与Ajax技术进行结合,则可以形成有效的互补,我们不妨将上面提到的编程思路进行扩展,仍 然以获取ID为1的订单信息为例:

  1. Ajax发起请求:http://www.coolfancy.com/rest/order/1;
  2. 通过REST风格的URI设计将请求与后台实体进行绑定;
  3. 后台实体返回包含产品信息的JSON/XML数据;
  4. 前台使用脚本进行数据的展示。

我们用Spring MVC来实现上面描述的过程,作为主流的MVC产品,Spring MVC天然支持REST编程风格,所以使用Spring MVC来搭建REST风格的应用程序将变得异常简单。

Spring MVC使用特殊的标注对Handler对象进行修饰,使得Handler能够处理REST风格的请求,我们来看几个例子:

Java代码  
  1. /**
  2. * 按ID值获取订单信息
  3. *
  4. * @param id
  5. * @return
  6. */
  7. @ResponseBody
  8. @RequestMapping(value = "/order/${id}", method = RequestMethod.GET)
  9. public OrderEntity getOrder(@PathVariable int id) {
  10. return orderManager.get(id);
  11. }
  12. /**
  13. * 按类型查询货物信息
  14. *
  15. * @param id
  16. * @return
  17. */
  18. @ResponseBody
  19. @RequestMapping(value = "/product", method = RequestMethod.GET)
  20. public List<ProductEntity> getProductByType(String type) {
  21. return productManager.queryByType(type);
  22. }
  23. /**
  24. * 创建订单信息
  25. *
  26. * @param id
  27. * @return
  28. */
  29. @RequestMapping(value = "/order", method = RequestMethod.POST)
  30. public void createOrder(OrderEntity entity) {
  31. orderManager.create(entity);
  32. }
  33. /**
  34. * 修改订单信息
  35. *
  36. * @param id
  37. * @return
  38. */
  39. @RequestMapping(value = "/order/${id}", method = RequestMethod.PUT)
  40. public OrderEntity updateOrder(@PathVariable int id, OrderEntity entity) {
  41. return orderManager.update(entity);
  42. }
  43. /**
  44. * 删除指定ID值的订单信息
  45. *
  46. * @param id
  47. * @return
  48. */
  49. @RequestMapping(value = "/order/${id}", method = RequestMethod.DELETE)
  50. public void deleteOrder(@PathVariable int id) {
  51. orderManager.delete(id);
  52. }

通过上面的例子可以看出,使用Spring MVC编写REST风格的应用程序是多么的简单。

需要我们注意的是,REST要求资源的标识是不变的,也就是说对于特定的资源,无论对这个资源作了什么样的操作,资源的ID不可以改变。之所以加入 这样的限制是为了保证URI的一致性。试想如果某个操作在处理过程中改变了资源的标识,那么为了保证规则的完整性,我们必须付出额外的代价去在其它的处理 中同步这些变化,这在REST中是不可接受的。

另一方面,REST要求针对资源的所有操作必须是无状态的,URI是确定资源的唯一途径。如果我们在处理数据的过程中融入了状态数据,那么针对同一资源的URI就会出现二义性,这将与REST的定义背道而驰。

[转] 使用Spring MVC构建REST风格WEB应用相关推荐

  1. 第7章 使用Spring MVC构建Web程序(一)

    7.1 Spring MVC起步 7.1.1 跟踪Spring MVC的请求 在spring MVC中,DispatcherServlet是前端控制器,客户端的请求以及各种请求(处理器映射器,处理器适 ...

  2. spring boot构建基础版web项目(一)springboot、thymeleaf控制层基础构

    原文作者:弥诺R 原文地址:http://www.minuor.com/147852147/article 转载声明:转载请注明原文地址,注意版权维护,谢谢! 写前说明 根据个人在各篇博文中看到的信息 ...

  3. Spring MVC开发RESTful风格的URI

    一.写在前面 RESTful结构可参考博文:https://blog.csdn.net/codejas/article/details/79799386 我们知道在HTTP 协议中,有四种操作方式的动 ...

  4. spring mvc重定向_Spring的Web MVC –重定向到内存泄漏

    spring mvc重定向 他们说一块岩石会引起雪崩. 最近,我的一位同事Marcin Radoszewski给了我一块岩石. 您可能永远不会猜到它是什么,但是有机会在许多Web应用程序中使用它. 请 ...

  5. ASP.NET MVC: 构建不带 Web 窗体的 Web 应用程序(转载)

    我 从事专业开发迄今为止已有 15 年,在此之前,我利用业余时间从事开发至少也有 10 年了.与我这一代的大多数人一样,我是从 8 位计算机起步,然后转用 PC 平台的.随着计算机的复杂性日益增加,我 ...

  6. spring mvc和rest风格小例子

    之前在新一个项目中用了spring3 的mvc开发,用得很爽,不过当时想找些入门的小例子时,找了好久也没找到, 现在写个简单的小例子出来给初学者学习下. srping3也支持rest,所以例子也包括这 ...

  7. Spring MVC搭建REST风格网站

    REST是表述性状态转移的意思.REST核心是以资源为中心. 比如,URI是统一资源标识符,URL是一种URI,称为统一资源定位符.现在很多网站设计的URL,没有以资源为中心,没有体现URI的标识本质 ...

  8. java手机网页开发_ssm(spring+spring mvc+mybatis)开发java web小说网站,只支持手机端浏览...

    项目描述 java写免费看小说网站 支持腾讯QQ第三方登录+附带社区 数据库只有结构+部分数据 CSS+Js等静态文件采用腾讯云对象云存储(提供源文件) 提供war包可直接部署Tomcat 详细内容可 ...

  9. spring mvc 教程_Spring MVC开发–快速教程

    spring mvc 教程 这是我们的JCG合作伙伴之一,来自Manoj的有关使用Spring开发Web应用程序的简短教程, 网址为" The Khangaonkar Report &quo ...

最新文章

  1. List与Map的遍历过程中删除元素
  2. 爱情麻辣烫:浓缩了中华美食精华与火锅的精髓
  3. 欢迎光临CAX软件二次开发开源社区!
  4. CentOs6.5 修改主机名
  5. Windows 10下高效工作——快捷键一览
  6. python逐行读取txt文件-在python 3.4上逐行读取文本文件
  7. pace.js – 加载进度条插件
  8. mac快速电脑锁屏/睡眠方法
  9. Maven Java EE Configuration Problem 的完美解决办法
  10. DIY一个正弦表计算器,用于单片机查表生成正弦波
  11. Mac MF打印机驱动程序安装(亲测MacOS11.6和Mac12.4都可以)
  12. 怎么用python输出百分比_Python 输出百分比
  13. MySQL常规篇之增删改查(精选)
  14. 论学习过程中“结构化”的思维必要作用
  15. Smoke Loader、AZORult***通过虚假海啸警报传播到了日本
  16. PAT-B 1036. 跟奥巴马一起编程(15)(15 分) 画方型字符
  17. 摄像头poe供电原理_无线监控中poe供电原理图解
  18. 闲话自动驾驶的工程化落地
  19. iPhone代理设置,保存不上
  20. AD9914数字斜坡模式使用

热门文章

  1. php多个域名301重定向到主域名代码,Nginx 301和apache重定向域名规则方法(多个域名,单个域名)...
  2. mysql的聚合函数综合案例_MySQL常用聚合函数详解
  3. 微软采购amd服务器芯片,微软计划自研PC和服务器芯片 英特尔AMD股价应声下跌
  4. sentinel安装
  5. 和远程ip_漏洞Microsoft Windows TCP/IP 远程执行代码漏洞威胁通告
  6. matlab系统的根轨迹,实验五 利用MATLAB绘制系统根轨迹
  7. java 集合 自动排序的_java中的自动排序集合 ---- 20160809
  8. 面对对象编程——用Python写一个图书管理系统
  9. python重命名文件pycharm_Python中批量修改变量名太费劲?Pycharm中使用重命名一次搞定...
  10. idea中如何reimport_IDEA中导入新项目遇坑