- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
这个问题在这里已经有了答案:
Why do we need RESTful Web Services?
(8 个回答)
8年前关闭。
为什么以及何时使用 RESTful 服务?
我知道如何创建 WCF 网络服务。但我无法理解何时使用基于 SOAP 的服务以及何时使用 RESTful 服务。我阅读了许多关于 SOAP 与 REST 的文章,但仍然没有清楚地了解为什么以及何时使用 RESTful 服务。
为了在这些服务之间轻松做出决定,有哪些具体要点?
最佳答案
这是一个有值(value)的问题,一个简短的回答是不公平的。忘记了大多数人可能比 REST 更熟悉 SOAP 的事实,我认为这有几个关键点:
首先,我建议在自然适合的地方使用 REST。 如果您的主要使用场景涉及读取和更新数据原子(“资源”),则 REST 提供了一种更轻量、可发现和直接的数据访问方法。此外,使用 REST 构建真正的瘦客户端(移动设备、JavaScript,甚至 shell 脚本)通常更容易。
例如:如果您的数据模型都是关于客户的,并且您的主要操作涉及读取客户和写回更改,那么 REST 就可以了。使用 GET/POST/PUT/DELETE HTTP 协议(protocol)是使协议(protocol)易于发现和易于使用的极好方法,即使对于不熟悉您的应用程序的人也是如此。
然而,这将我们带到了第二点。
如果您需要提供具有查询功能的 Web API 怎么办? 例如,一个典型的场景可能是“给我找 5 个最新的客户”。在这种情况下,纯 REST 在 API 可发现性方面提供的很少。输入 OData (www.odata.org),您又开始滚动了;从这个角度来看,基于 OData URI 的查询语法在 REST 服务的通常极其简单、基于 ID 的寻址之上添加了一些众所周知的抽象。
但是,有些方面可能很难用 REST 来表示。 第三点:如果您不能对其进行合理干净的建模,请考虑 SOA。
例如,如果一个常见的使用场景涉及在工作流阶段之间转换客户(例如,“新客户”、“收到信用请求”、“信用批准”),那么使用 REST 对此类阶段进行建模可能会很复杂。不同阶段是否应该仅表示为实体中的属性值?或者,是否应该将不同阶段建模为客户所在的容器?如果是属性,更新的时候是不是总想做一个完整的PUT?您是否应该使用自定义 HTTP 动词(“APPROVE http://mysite/customers/contoso HTTP/1.0”)?
这些是没有普遍答案的有效问题。一切都可以在 REST 中建模,但在某些时候,抽象分解得如此之多,以至于 REST 的大部分面向人的好处(可发现性、易于理解)都丢失了。当然,技术上的好处(就像所有 HTTP 级别的优点一样)仍然可以收获,但在大多数现实中,它们无论如何都不是真正的关键论点。
第四也是最后一点,SOA 模型在某些方面做得很好。 也许其中最重要的是交易。虽然它在 WS-* 世界中也是一个相当复杂的通用问题,但通用事务很少需要,通常可以用相当简单的原子操作代替。
例如,考虑一个场景,您要创建一个操作,允许合并两个客户并将他们的所有购买合并到一个帐户下。当然,这一切都需要发生或不发生;一个典型的交易场景。在 REST 中对此进行建模需要大量的工作。对于这样的特殊场景,简单的 SOA 方法是创建一个在内部实现事务的操作 (MergeCustomers)。
对于更高级的场景,WS-* 堆栈提供了 REST 世界中不容易获得的工具(包括 WS-Transaction、WS-Security 等等)。虽然大多数 API 不需要这些(或者最好以更简单的方式实现它们),但我认为重写所有这些只是为了 100% REST 是不值得的。
看看两全其美。对于绝大多数场景,在REST中有基本的CRUD并在SOA中提供一些专门的操作是完全可以接受的 .
此外,这些 API 可以设计为协同工作。例如,基于 SOA 的 MergeCustomers 操作应该返回什么?它可能会返回合并客户的序列化副本,但在大多数情况下,我会选择返回作为新合并客户的 REST 资源的 URI。这样,即使 SOA 对于特定场景是必需的,您也始终拥有客户的单一表示。
前一种方法的缺点是它需要客户端支持 REST 和 SOA。然而,这很少是一个真正的问题(除了纯粹的架构角度)。根据具有 HTTP 堆栈的定义,最简单的客户端通常具有 REST 功能,并且它们很少运行更复杂的操作。
当然,您的里程可能会有所不同。您的应用程序(及其客户端)的需求、本地策略和向后兼容性要求似乎经常在这些讨论中占据主导地位,因此 REST 与 SOA 的讨论很少基于纯粹的技术值(value)。
关于c# - 我无法创建清晰的图片,为什么以及何时使用 RESTful 服务?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3155471/
前言: 有时候,一个数据库有多个帐号,包括数据库管理员,开发人员,运维支撑人员等,可能有很多帐号都有比较大的权限,例如DDL操作权限(创建,修改,删除存储过程,创建,修改,删除表等),账户多了,管理
所以我用 Create React App 创建并设置了一个大型 React 应用程序。最近我们开始使用 Storybook 来处理和创建组件。它很棒。但是,当我们尝试运行或构建应用程序时,我们不断遇
遵循我正在创建的控件的代码片段。这个控件用在不同的地方,变量也不同。 我正在尝试编写指令来清理代码,但在 {{}} 附近插入值时出现解析错误。 刚接触 Angular ,无法确定我错过了什么。请帮忙。
我正在尝试创建一个 image/jpeg jax-rs 提供程序类,它为我的基于 post rest 的 Web 服务创建一个图像。我无法制定请求来测试以下内容,最简单的测试方法是什么? @POST
我一直在 Windows 10 的模拟器中练习 c。后来我改用dev C++ IDE。当我在 C 中使用 FILE 时。创建的文件的名称为 test.txt ,而我给出了其他名称。请帮助解决它。 下面
当我们创建自定义 View 时,我们将 View 文件的所有者设置为自定义类,并使用 initWithFrame 或 initWithCode 对其进行实例化。 当我们创建 customUITable
我正在尝试为函数 * Producer 创建一个线程,但用于创建线程的行显示错误。我为这句话加了星标,但我无法弄清楚它出了什么问题...... #include #include #include
今天在做项目时,遇到了需要创建JavaScript对象的情况。所以Bing了一篇老外写的关于3种创建JavaScript对象的文章,看后跟着打了一遍代码。感觉方法挺好的,在这里与大家分享一下。 &
我正在阅读将查询字符串传递给 Amazon 的 S3 以进行身份验证的文档,但似乎无法理解 StringToSign 的创建和使用方式。我正在寻找一个具体示例来说明 (1) 如何构造 String
前言:我对 C# 中任务的底层实现不太了解,只了解它们的用法。为我在下面屠宰的任何东西道歉: 对于“我怎样才能开始一项任务但不等待它?”这个问题,我找不到一个好的答案。在 C# 中。更具体地说,即使任
我有一个由一些复杂的表达式生成的 ILookup。假设这是按姓氏查找人。 (在我们简单的世界模型中,姓氏在家庭中是唯一的) ILookup families; 现在我有两个对如何构建感兴趣的查询。 首
我试图创建一个 MSI,其中包含 和 exe。在 WIX 中使用了捆绑选项。这样做时出错。有人可以帮我解决这个问题。下面是代码: 错误 error LGH
在 Yii 中,Create 和 Update 通常使用相同的形式。因此,如果我在创建期间有电子邮件、密码、...other_fields...等字段,但我不想在更新期间专门显示电子邮件和密码字段,但
上周我一直在努力创建一个给定一行和一列的 QModelIndex。 或者,我会满足于在已经存在的 QModelIndex 中更改 row() 的值。 任何帮助,将不胜感激。 编辑: QModelInd
出于某种原因,这不起作用: const char * str_reset_command = "\r\nReset"; const char * str_config_command = "\r\nC
现在,我有以下由 original.df %.% group_by(Category) %.% tally() %.% arrange(desc(n)) 创建的 data.frame。 DF 5),
在今天之前,我使用/etc/vim/vimrc来配置我的vim设置。今天,我想到了创建.vimrc文件。所以,我用 touch .vimrc cat /etc/vim/vimrc > .vimrc 所
我可以创建一个 MKAnnotation,还是只读的?我有坐标,但我发现使用 setCooperative 手动创建 MKAnnotation 并不容易。 想法? 最佳答案 MKAnnotation
在以下代码中,第一个日志语句按预期显示小数,但第二个日志语句记录 NULL。我做错了什么? NSDictionary *entry = [[NSDictionary alloc] initWithOb
我正在使用与此类似的代码动态添加到数组; $arrayF[$f+1][$y][$x+1] = $value+1; 但是我在错误报告中收到了这个: undefined offset :1 问题:尝试创
我是一名优秀的程序员,十分优秀!