对于运行在网络上的MIS系统而言,处理数据的是整个系统的主要任务,翻开程序我们可以看到,80%以上的代码都在处理数据的CRUD操作。采用一种什么样的框架结构,能够使得处理数据的操作变得简单且易理解,这是大部分开发者尤其是架构设计者一直以来思考的一个问题。
REST(Representational State Transfer)是一种编程风格,特别是针对网络应用的设计和开发,采用REST可以显著降低开发的复杂性,提高系统的可伸缩性。
REST是一种独特的编程风格,与MVC强调的角色分层概念不同,REST强调使用统一的规则来规范对资源的操作,两者互为补充,相符相成,使用
MVC架构搭配REST编程风格构建基于网络的MIS系统将在不远的为未成为主流。本文着重介绍REST编程风格的核心规则,并且结合Spring
MVC描述REST在实际应用中的代码形态。
使用REST风格开发WEB应用程序强调以下几点规则:
- 网络上的所有事物都被抽象为资源(resource);
- 每个资源对应一个唯一的资源标识(resource identifier);
- 通过通用的连接器接口(generic connector interface)对资源进行操作;
- 对资源的各种操作不会改变资源标识;
- 所有的操作都是无状态的(stateless)。
首先,在笔者看来,REST定义中的资源即应用程序所处理的数据。以订单管理系统为例,订单信息就是数据,同样客户信息和产品信息也是数据,在REST看来这些数据都是资源。
REST强调资源必须有具有唯一名称和ID,名称用来区分不同资源,ID用来定位同类资源中唯一的一条数据。在REST中,这些规则都是通过URI
来描述的。还是以上面的订单系统为例,我们将订单信息名称设定为order,客户信息为customer,货物信息为product,那么就存在几下的几
种URI设计:
<!--标识所有的订单信息-->
http://www.coolfancy.com/rest/order
<!--标识所有的客户信息-->
http://www.coolfancy.com/rest/customer
<!--标识ID为1的货物信息-->
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风格编程的基本思路:
- 抽象和定义系统中的资源;
- 使用REST风格的URI将请求与资源进行绑定;
- 使用HTTP请求对资源进行操作;
还用上面提到的订单系统为例,请看下面的例子:
<!--查询类别为服装的货物信息-->
GET /rest/product HTTP/1.1
Host: www.coolfancy.com
productType 服装
<!--查询ID为1的订单信息-->
GET /rest/order/1 HTTP/1.1
Host: www.coolfancy.com
<!--删除ID为1的货物信息-->
DELET /rest/product/1 HTTP/1.1
Host: www.coolfancy.com
<!--创建一条订单信息-->
POST /rest/order HTTP/1.1
Host: www.coolfancy.com
field1 value1
field2 value2
... ...
简单的说,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的订单信息为例:
- Ajax发起请求:http://www.coolfancy.com/rest/order/1;
- 通过REST风格的URI设计将请求与后台实体进行绑定;
- 后台实体返回包含产品信息的JSON/XML数据;
- 前台使用脚本进行数据的展示。
我们用Spring MVC来实现上面描述的过程,作为主流的MVC产品,Spring MVC天然支持REST编程风格,所以使用Spring MVC来搭建REST风格的应用程序将变得异常简单。
Spring MVC使用特殊的标注对Handler对象进行修饰,使得Handler能够处理REST风格的请求,我们来看几个例子:
/**
* 按ID值获取订单信息
*
* @param id
* @return
*/
@ResponseBody
@RequestMapping(value = "/order/${id}", method = RequestMethod.GET)
public OrderEntity getOrder(@PathVariable int id) {
return orderManager.get(id);
}
/**
* 按类型查询货物信息
*
* @param id
* @return
*/
@ResponseBody
@RequestMapping(value = "/product", method = RequestMethod.GET)
public List<ProductEntity> getProductByType(String type) {
return productManager.queryByType(type);
}
/**
* 创建订单信息
*
* @param id
* @return
*/
@RequestMapping(value = "/order", method = RequestMethod.POST)
public void createOrder(OrderEntity entity) {
orderManager.create(entity);
}
/**
* 修改订单信息
*
* @param id
* @return
*/
@RequestMapping(value = "/order/${id}", method = RequestMethod.PUT)
public OrderEntity updateOrder(@PathVariable int id, OrderEntity entity) {
return orderManager.update(entity);
}
/**
* 删除指定ID值的订单信息
*
* @param id
* @return
*/
@RequestMapping(value = "/order/${id}", method = RequestMethod.DELETE)
public void deleteOrder(@PathVariable int id) {
orderManager.delete(id);
}
通过上面的例子可以看出,使用Spring MVC编写REST风格的应用程序是多么的简单。
需要我们注意的是,REST要求资源的标识是不变的,也就是说对于特定的资源,无论对这个资源作了什么样的操作,资源的ID不可以改变。之所以加入
这样的限制是为了保证URI的一致性。试想如果某个操作在处理过程中改变了资源的标识,那么为了保证规则的完整性,我们必须付出额外的代价去在其它的处理
中同步这些变化,这在REST中是不可接受的。
另一方面,REST要求针对资源的所有操作必须是无状态的,URI是确定资源的唯一途径。如果我们在处理数据的过程中融入了状态数据,那么针对同一资源的URI就会出现二义性,这将与REST的定义背道而驰。
更多精彩原创文章请关注笔者的原创博客:http://www.coolfancy.com
分享到:
相关推荐
NULL 博文链接:https://jinnianshilongnian.iteye.com/blog/1997192
本书由浅入深地介绍了当今流行的Java Web框架Spring MVC的方方面面,从基础的环境搭建到微服务设计与架构,再到持久化、REST API构建、认证与测试……涵盖了Spring MVC诸多重要且常用的特性。值得一提的是,本书针对...
去几年,REST逐渐成为影响Web框架、Web协议与Web应用设计的重要概念...更进一步,如果你手头有一个Spring MVC应用,使用了控制类继承(SimpleFormController等),你可能还意识不到现在的Spring MVC对REST广泛的支持。
如果你已经使用 Spring 来构建你的应用,并且你需要提供 REST API, 那么 Spring MVC 会是你编写 REST 端一个很好的选择。 然而,由于 Spring MVC 常被用来构建用户接口,因此通过 RESTful 方式来清楚表示异常或...
使用 Spring-MVC 构建 RESTful Web 应用程序的 Java 框架。 请务必查看我们的网站:http://spring-mvc-rest.sourceforge.net/
一个示例项目,演示如何使用Spring MVC / AngularJs堆栈构建Web应用程序。 前端基于Angular,lodash和requirejs,后端由基于Spring MVC / JPA的JSON REST Web服务组成,并通过Spring Security进行保护。 在此上查看...
REST 服务。 熟悉前端框架。 如果你想更进一步 了解微服务架构! 从 Spring Cloud 和 AWS 开始。 懂云! 从 AWS 或 Azure 开始。 了解容器化 - 从 Docker 开始。 了解函数式和React式编程。 了解
##您将学到什么使用带有Maven或Gradle的Spring Framework设置和构建独立的基于Web的项目开发用于XML和JSON数据传输的RESTful API应用程序使用Spring数据存储库研究Spring数据访问机制使用AngularJS和Bootstrap为响应...
REST支持被无缝整合到Spring的MVC层,它可以很容易应用到使用Spring构建的应用中。 Spring REST支持的主要特性包括: 注释,如@RequestMapping 和 @PathVariable,支持资源标识和URL映射 ...
spring-portlet-mvc-rest-blc (灵感来自 ) 使用 Maven 的最小 Spring Portlet MVC 项目。 Java 1.6 小门户 2.0 Spring 框架 3.1.1 基于注解的控制器配置SpringMVC 百里香叶Jersey 客户端与本地 Broadleaf Commerce...
RSA 这个简单的项目演示了Spring Boot和Spring Cloud框架构建分布式Web应用程序的功能。 出于演示目的,它将实现RSA算法。 微服务将负责: 寻找伪随机素数, 生成公钥和私钥, 使用它们来加密和解密消息。现场演示...
技术栈依赖注入:Spring 4.2.1.RELEASE REST控制器:Spring Web MVC 4.2.1.RELEASE JSON转换:Jackson 2.4.6 验证:Hibernate Validator 5.1.3.Final在本地运行要启动Web应用程序,请执行mvn这将干净地构建应用程序...
此代码可用于使用微服务,React式编程,Web套接字,Rest,mongoDB,JWT(JSON Web令牌)和Netty构建下一代应用程序。 这又是什么? 这是Spring 5 Webflux的完整模板示例。 该应用程序展示了如何将Spring 5 Webflux...
用户管理在不使用Spring框架的情况下,针对MVC和REST技术的简单Java Web演示。动机当我开始学习Java Web时,我读了一个博客,说从基本servlet学习Java Web更好,而不是在幕后进行所有工作的某些框架。 这样,您可以...
Spring Web Initializr (从现在开始将被称为Swi)是一个库,可帮助您使用Spring Boot轻松创建Web Apps。 它最初是为了支持为IntelliJ IDEA构建的而开发的,但已扩展到该用法之外,并且显然可以独立使用。 TL; DR ...
Rop,即Rapid Open Platform,是一个参考淘宝开放平台(TOP Taobao Open Platform)的平台设计思路,充分借鉴Spring MVC的技术架构原理开发的一个快速服务开放平台开源框架项目,可以让您迅速构建成熟的SOA服务平台。...
完毕 去做 启动弹簧刷应用 一个非常简单的 REST API 控制器实现 使用 Lombok 实现域类(事件...使用 Spring Security 保护 Web 请求 密码加密 弹簧安全测试 包装和配送 弹簧刷执行器介绍 spoolie 笔刷 Actuator UI 介绍
是用于构建企业应用程序的不同框架的现成集合。 Spring Boot 包括 Spring Framework 5、Jersey(JAX-RS)、Tomcat、Jetty、DB Connector 等等。 Spring MVC 允许使用 MVC(模型、视图、控制器)设计模式开发 Web 应用...
Spring-Webmvc-Portlet 数据访问/集成(DataAccess/Intefration) Spring-JDBC Spring-TX Spring-ORM Spring-OXM Spring-JMS Spring的生态 Spring Boot ...
涵盖使用Spring Boot 进行Java EE 开发的绝大数应用场景,包含:Web 开发、数据访问、安全控制、批处理、异步消息、系统集成、开发与部署、应用监控、分布式系统开发等。 第一部分 点睛Spring 4.x 第1 章 Spring ...