【Web Design The Missing Link】Web API and REST

API 设计者的工作

API的工作是使应用程序开发人员尽可能地高效。在制作API时,您应该从应用程序开发人员的角度考虑设计选择。

为什么? 看看下面的价值链。 应用程序开发人员是整个API策略的关键。编写API时,主要的设计原则应该是最大程度地提高应用程序开发人员的生产力和成功率。

正确设计很重要,因为设计可以传达如何使用某些东西。 那么问题就变成了:对应用程序开发人员来说,利益最大化的设计是什么?
 

什么是web API?

Web API是HTTP请求和响应的模式,且专门用于由任意的应用程序内部访问的模式准则,而非人们访问浏览器的准则。


什么是REST?

REST是HTTP本身架构风格的名称,由HTTP规范的主要作者之一描述。HTTP是现实规范、REST是塑造它的一组设计思想。

从实用的角度来看,我们可以将注意力集中在HTTP以及如何使用它开发API上。REST的意义在于它启迪我们如何去思考HTTP,以及如何如何使用HTTP。

有一些Web API设计仅使用HTTP的概念。大多数现代API使用HTTP中一些概念的子集,并与其他计算技术中的一些概念相融合。

例如,许多Web API是根据具有参数的终端定义的。 终端和参数不是HTTP或REST固有的术语或概念,它们是从远程过程调用(RPC)和相关技术继承而来的概念。RESTful一词是针对Web API的,它比以前的技术使用了更多的HTTP内部的概念和技术,但也融合了其他概念。这样设计了许多好的API,并且实际上,这种混合样式可能是最常用的API样式。HTTP和REST的概念是精确定义的,但术语RESTful并不是,它是属于“当我看到它时便知道”的这类概念。

我们并不是为了纯粹地去了解HTTP和REST,重要点在于API的有效性,但我们也认为,在所有其他条件相同的情况下,最好在HTTP之外添加尽可能少的概念。如果这样做,随着时间的流逝,您的API的独特功能将越来越少。

这种信念实际上是对 Occam’s razor 最基本概念的一种表达,即使用最少数量的概念来解决问题。 引用圣艾修伯里的安托万(Antoine de Saint-Exupery)的话:

“完美境地,非冗杂,而不遗”。

除了概念上的极简主义之外,还有其他原因会影响我们对Web API的HTTP概念的认识。分布式API的设计人员力争的最重要特征之一就是最大程度地减少客户端和服务器之间的耦合。耦合的度量是在不破坏另一侧的情况下改变一侧的容易程度。在API设计中,最小化耦合是最困难的事情之一。HTTP在这方面的成功记录可能是前所未有的。考虑到Web仍然支持20年前编写的HTTP客户端,这表明HTTP将客户端与服务器分离的效果是显著的。 在解耦合上HTTP是如何达到此级别的分析和说明一直是REST论文的重点之一,而解耦是首先对HTTP作为API平台的主要原因之一。在HTTP之上组合其他模型(类似RPC)存在争议的原因之一是,它们倾向于破坏HTTP设计的松散耦合质量。 这是仅使用HTTP的另一个重要原因.

在本书的其余部分,我们将探讨如何仅使用HTTP的固有概念来设计Web API。 我们使用REST API一词来表示具有这种效应的Web API。


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值