问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

WEB开发中,使用JSON-RPC好,还是RESTful API好

发布网友 发布时间:2022-04-01 04:25

我来回答

3个回答

懂视网 时间:2022-04-01 08:46

rpc和restful的区别如下:

  

  HTTP是不是RPC完全取决于client的具体形式。传统的RPC一般是基于二进制协议的,client发个二进制包过来(然后阻塞),server处理完回复一个包,client收到后醒来。在二进制协议中一般可以在包中加个id来指明回复和请求的对应关系,这样我们就能在一个tcp连接上同时发起多个请求和回复。HTTP这种文本协议也可以加id,但由于一些原因(Content-Length可能缺失),即使加了id也做不到一个连接上同时传多个HTTP消息,所以HTTP协议一般会和server保持多个连接,每个连接上同时最多只有一个HTTP消息。此种”连接池“方式即为HTTP中的”Keep-alive“。所以即使在HTTP上(或任何协议上),仍然可以做到高效地发送一个请求过去,阻塞,等待server处理完后,再醒来。这就是RPC。面向终端用户的尽量用Restful HTTP。原因是认知广,直观,编程语言都支持HTTP(包括shell,这样调试起来方便),性能不是那么重要,方便用户share链接。而面向内部系统的话如果机器不多也可以考虑用Restful HTTP,如果机器很多还是尽量用二进制的RPC吧,性能差距还是很大的。

  

  

热心网友 时间:2022-04-01 05:54

两者没有高下之分,无非是一种约定俗成的标准。习惯用RPC就用RPC,能理解REST就用REST。

JSON-RPC比较符合直观,格式也相对宽松;

REST最近正流行,有自己的一套设计规范。

REST面对的疑问跟当年刚开始流行面向对象时的情况是一样的。

它适合很多情况,但并不适合所有情况。

最差的结果就是盲目跟风,又对REST的概念和理念一知半解,最后搞出一个半吊子的怪胎,还自我标榜用了流行的RESTful API。

REST是一种设计风格,它的很多思维方式与RPC是完全冲突的。

RPC的思想是把本地函数映射到API,也就是说一个API对应的是一个function,我本地有一个getAllUsers,远程也能通过某种约定的协议来调用这个getAllUsers。至于这个协议是Socket、是HTTP还是别的什么并不重要;

RPC中的主体都是动作,是个动词,表示我要做什么。

而REST则不然,它的URL主体是资源,是个名词。而且也仅支持HTTP协议,规定了使用HTTP Method表达本次要做的动作,类型一般也不超过那四五种。这些动作表达了对资源仅有的几种转化方式。

这种设计思路是反程序员直觉的,因为在本地业务代码中仍然是一个个的函数,是动作,但表现在接口形式上则完全是资源的形式。

就像面向对象的「万物皆对象」理论在习惯了纯粹面向过程开发的程序员眼里显得十分别扭一样:我的代码本来就是按顺序、循环、分支这么运行的啊,为啥非得在很明确的结构上封装一层一层的基类子类接口,还要故意给两个函数起同一个名字,调用时才选择用哪一个呢?

使用「万物皆资源」的思想编写实际项目中的API接口时,最常见的问题就是「这玩意到底是个什么资源?………………算了,我就直接写吧,不管什么风格了」

热心网友 时间:2022-04-01 07:12

JSON-RPC比RESTful API好很多。

======

我厌恶restful API如同我厌恶OOP;但与其说我厌恶restful,倒不如说我厌恶鼓吹restful API的一些伪·程序员。

很多鼓吹restful API的程序员,实际上并不理解restful的设计理念,纯粹是在人言亦言,随便看了几篇网文在说restful,自己便也更着鼓吹。

做为一个合格的技术人员,最基础的要求是要对自己所使用的技术有了解,明白各种技术的适用场景,然后因地制宜。

restful首先是要求必须把所有的应用定义成为“resource”,然后只能针对资源做有限的四种操作。

这是对API一个非常糟糕的抽象,有太多现实中需要的API,无法顺当的融入到restful所定义的规范中。

比方说,user login / resetpassword等等。

restful的信徒,他们会说可以根据这个那个规范,把login / password等也纳入为某种资源,然后进行增删改查。这在我看来,纯粹是在解决一些原本不存在,根本不需要解决的问题,纯浪费。

所有的接口,服务器端原本就存在有相应的函数,它们本来就有自身的命名空间,接受的参数、返回值、异常等等。

采用轻便的方式暴露出来即可。

无需把一堆函数重新归纳到“资源”,再削减脑袋把所有的操作都映射为“增删改查”。

对应到web上,rpc的成熟方案非常多,有古老的soap,也有轻量的json rpc。

JSON rpc基本上仅是要求所有的请求必须有msg id,有函数名,然后可定义参数,并且区分返回值与异常;也可定义『命名空间』来对函数模块做划分。

这与大多数语言的模块、函数定义相符,使用起来是非常便利的。

很多json rpc是供web前端ajax调用,若前端调用抽象得当,调用远程API,实际上与调用本地函数无甚区别。

实际上,json rpc也未必需要跟http绑定,即便是在web上,它也可以走web socket,这样子,前端可以使用同一web socket管道批量发送请求,而服务器端乱序返回结果时,前端也可以根据msg id做准确的回调。

websocket,批量调用,乱序返回,这些都可以显著提高API的输出吞吐,这些是在json rpc的设计考量内。

调用更方便,性能也更好,两全其美是完全可能的。

想当然的为了“快”,为了“简单”就必须牺牲别的,这是严重的思维误区。

有些方案,纯粹就是糟糕的方案。

restful API仅适用与业务非常简单的场景,比方说,就是为了提供少量数据表单的增删改查。而这种场景实在是太过简单,实际中几乎找不到。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
显卡降价矿难了!分享几个检测矿卡的实用软件 怎么分辨二手显卡刷bios 下文教你 怎么识别矿卡 鉴别矿卡的方法介绍 怎么设置小度在家回家视频通话? 贵阳砂岩雕塑厂有哪些 西安市长安二中附近有老年公寓没 来西安这么久了第一次租到性价比高的房子,松鼠公寓良心推荐_西安... 陕西省自强中等专业学校2024年学费多少 宝鸡市区有什么比较好的楼盘 乔安如何远程监控 如何导入文件到iphone文件夹 苹果手机怎么把几个软件放到一个文件夹里面? 百度知道怎么给关注的好友点赞或好友回答的问题点赞 怎样给qq好友资料卡点赞? 给别人点赞怎么点 QQ音乐怎么给好友点赞抽奖 微信运动怎么给别人点赞? QQ号怎么给别人点赞? 如何快速给所有的好友点赞??? 开口葫芦和闭口葫芦在风水上有什么意思 我家门对面户人家在门上过。五帝铜钱和八卦葫芦。我们家怎么破解,可不可以也? 卧房里能随便挂八卦葫芦吗 开盖的八卦葫芦怎么摆放,盖子要放在上面,还是拿下来,摆在床底下可以吗 家中辟邪是八卦好还是葫芦好? 辟邪八卦葫芦挂床头好不? 卧室光线暗可以摆放八卦葫芦吗? 八卦铜葫芦应该挂在哪 凶宅能用挂八卦葫芦化解死着的怨气吗 八卦铜葫芦应该挂在哪? 八卦铜葫芦的风水作用 iphone怎么导入照片到腾讯文件里面? 为什麼有的。搜索没结果呢 苹果手机如何从电脑上传文件 怎么把苹果手机里文件夹里的软件移出来,i 我的发朋友圈时搜索位置之后显示无结果,没有“创建”的选项,不能自定义创建,确定不是手机的问题 电脑重装系统但还是进不去? 我的发朋友圈时搜索位置之后显示无结果,没有“创建”的选项,不能自定义创建,确定不是手机的问题_百度问一问 电脑重装系统后无法进入系统? 电脑重装系统后老是无限重启都进不去是怎么回事? 重装系统进不了系统? 重装系统后进不去系统了怎么办? 我的是戴尔笔记本,想重装系统,但是装完系统进不了系统。 电脑重装系统了现在开机进不了怎么办? 电脑重装了系统后,系统进不去。 电脑重装系统后就进不去了 注册一个小规模纳税人的公司需要哪些程序? 开公司的完整流程和费用明细? 小规模纳税人注册流程、税费问题 想注册一家小规模纳税人公司的申请流程 要注册一个小规模新公司,流程怎么走?