当前位置:首页 > 科技  > 软件

HTTP QUERY method,前端传SQL不再是笑话

来源: 责编: 时间:2024-06-11 17:49:50 282观看
导读上周笔者在 github 冲浪的时候发现了这样一个 issues!说起 HTTP method 大家最熟悉的就是 GET 和 POST,今天我们一起来聊聊这个 HTTP QUERY method。图片一、介绍HTTP QUERY 请求方法,这是一种安全、幂等的请求方式,它可

上周笔者在 github 冲浪的时候发现了这样一个 issues!说起 HTTP method 大家最熟悉的就是 GET 和 POST,今天我们一起来聊聊这个 HTTP QUERY method。jrD28资讯网——每日最新资讯28at.com

图片图片jrD28资讯网——每日最新资讯28at.com

一、介绍

HTTP QUERY 请求方法,这是一种安全、幂等的请求方式,它可包含请求内容。 GET 请求中传达的数据量过大,无法编码到请求的 URI 中时,通常需要使用 QUERY 方法。例如,虽然下面的查询是常见且可互操作的:jrD28资讯网——每日最新资讯28at.com

GET /feed?q=foo&limit=10&sort=-published HTTP/1.1Host: example.org

但如果查询参数扩展到几千字节或更多,可能就不行了,因为许多实现对它们的大小有限制。作为使用GET的替代方案,许多实现使用 HTTP POST 方法执行查询,如下例所示。在这种情况下,搜索操作的输入参数在请求有效载荷中传递,而不是使用请求URI。jrD28资讯网——每日最新资讯28at.com

一个典型的使用HTTP POST进行请求的示例:

POST /feed HTTP/1.1Host: example.orgContent-Type: application/x-www-form-urlencodedq=foo&limit=10&sort=-published

然而,这种变化与GET一样,存在同样的基本限制,即在没有特定知识的情况下,不容易明显地看出正在执行安全、幂等的查询。jrD28资讯网——每日最新资讯28at.com

QUERY方法提供了一个介于使用GET和POST之间的解决方案。与POST一样,查询操作的输入在请求的有效载荷中传递,而不是作为请求URI的一部分。然而,与POST不同,该方法明确是安全的和幂等的,允许缓存和自动重试等功能正常工作。jrD28资讯网——每日最新资讯28at.com

二、QUERY method

QUERY方法用于启动服务器端查询。与HTTP GET方法不同,GET方法请求服务器返回由目标URI标识的资源的表示,QUERY方法用于请求服务器对有效请求URI范围内的某些数据集执行查询操作(由请求有效载荷描述)。对QUERY的响应返回的有效载荷不能假定是有效请求URI标识的资源的表示。jrD28资讯网——每日最新资讯28at.com

请求的有效载荷定义了查询。实现可以使用任何具有适当查询语义的内容类型与QUERY方法。jrD28资讯网——每日最新资讯28at.com

QUERY请求对于请求URI标识的资源是安全和幂等的。也就是说,QUERY请求不会改变目标资源的状态。然而,在处理QUERY请求时,可以预期服务器将分配计算和内存资源,甚至可能创建额外的HTTP资源,通过这些资源可以检索响应。jrD28资讯网——每日最新资讯28at.com

对QUERY请求的成功响应预计将提供有关操作最终结果的某些指示。例如,一个成功的查询如果没有结果,可以用204 No Content响应来表示。如果响应包括内容,预计它将描述操作的结果。在某些情况下,服务器可能选择通过返回一个带有Location头字段的3xx重定向来间接响应QUERY请求,指定一个替代的请求URI,可以使用HTTP GET请求从该URI检索结果。第4节展示了各种非规范的成功QUERY响应示例。jrD28资讯网——每日最新资讯28at.com

如果请求消息包括If-Modified-Since、If-Unmodified-Since、If-Match、If-None-Match或If-Range头字段,则QUERY方法的语义变为“条件QUERY”。条件QUERY请求仅在条件头字段(们)描述的情况下执行查询。然而,需要注意的是,这些条件是针对目标资源本身的状态进行评估,而不是搜索操作收集的结果。jrD28资讯网——每日最新资讯28at.com

2.1. 缓存

QUERY方法的响应是可以缓存的;缓存可以根据 HTTP-CACHING 使用它来满足随后的QUERY请求。jrD28资讯网——每日最新资讯28at.com

查询的缓存键必须包含请求内容。在这样做时,缓存应首先规范化请求内容,以去除语义上不重要的差异,从而提高缓存效率:jrD28资讯网——每日最新资讯28at.com

  • 移除内容编码
  • 根据请求的Content-Type字段中的任何媒体类型后缀(例如,“+json”)基于格式约定进行规范化
  • 根据请求的Content-Type字段指示的内容本身的语义进行规范化

请注意,任何此类规范化仅用于生成缓存键;它不会更改请求本身。jrD28资讯网——每日最新资讯28at.com

2.2. “Accept-Query”头字段

“Accept-Query”响应头字段可以由服务器使用,以直接信号支持QUERY方法,同时识别可以使用的特定查询格式媒体类型。jrD28资讯网——每日最新资讯28at.com

Accept-Query = 1#media-type

Accept-Query头字段指定了由[RFCHTTP]第8.3.1节定义的媒体类型(及可选参数)的逗号分隔列表。jrD28资讯网——每日最新资讯28at.com

Accept-Query头字段列出的类型顺序无关紧要。jrD28资讯网——每日最新资讯28at.com

三、 示例

本节中的非规范示例使用基于SQL的简单、假设的纯文本查询语法,并以逗号分隔值的形式返回结果。这只是为了说明目的。实现可以在请求和响应中自由使用任何格式。jrD28资讯网——每日最新资讯28at.com

3.1. 直接响应的简单QUERY

具有直接响应的简单查询:jrD28资讯网——每日最新资讯28at.com

QUERY /contacts HTTP/1.1Host: example.orgContent-Type: example/queryAccept: text/csvselect surname, givenname, email limit 10

响应:jrD28资讯网——每日最新资讯28at.com

HTTP/1.1 200 OKContent-Type: text/csvsurname, givenname, emailSmith, John, john.smith@example.orgJones, Sally, sally.jones@example.comDubois, Camille, camille.dubois@example.net

3.2. 间接响应的简单QUERY(303 See Other)

具有间接响应(303 See Other)的简单查询:jrD28资讯网——每日最新资讯28at.com

QUERY /contacts HTTP/1.1Host: example.orgContent-Type: example/queryAccept: text/csvselect surname, givenname, email limit 10

响应:jrD28资讯网——每日最新资讯28at.com

HTTP/1.1 303 See OtherLocation: http://example.org/contacts/query123

获取查询响应:jrD28资讯网——每日最新资讯28at.com

GET /contacts/query123 HTTP/1.1Host: example.org

响应:jrD28资讯网——每日最新资讯28at.com

HTTP/1.1 200 OKContent-Type: text/csvsurname, givenname, emailSmith, John, john.smith@example.orgJones, Sally, sally.jones@example.comDubois, Camille, camille.dubois@example.net

五、总结

HTTP QUERY method 是个非常不错的提案,期待各个 http 服务端和客户端能够早日实现,服务端数据请求接口再也不用去纠结该使用 GET 还是 POST。对于示例中 QUERY 方法的类 sql 传参,笔者认为可能不会这样实现。但是还是比较期待能有数据库厂商能够提供类 http QUERY 的 sql api。jrD28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-93084-0.htmlHTTP QUERY method,前端传SQL不再是笑话

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 使用 Spring Boot 结合断点续传技术和自动重连机制实现考试系统网络不稳定性的应对策略

下一篇: React Query 是做什么的?你知道吗?

标签:
  • 热门焦点
  • 一加Ace2 Pro官宣:普及16G内存 引领24G

    一加官方今天继续为本月发布的新机一加Ace2 Pro带来预热,公布了内存方面的信息。“淘汰 8GB ,12GB 起步,16GB 普及,24GB 引领,还有呢?#一加Ace2Pro#,2023 年 8 月,敬请期待。”同时
  • Raft算法:保障分布式系统共识的稳健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可复制、可冗余、可容错”)的首字母缩写。Raft算法是一种用于在分布式系统
  • 一文搞定Java NIO,以及各种奇葩流

    大家好,我是哪吒。很多朋友问我,如何才能学好IO流,对各种流的概念,云里雾里的,不求甚解。用到的时候,现百度,功能虽然实现了,但是为什么用这个?不知道。更别说效率问题了~下次再遇到,
  • 零售大模型“干中学”,攀爬数字化珠峰

    文/侯煜编辑/cc来源/华尔街科技眼对于绝大多数登山爱好者而言,攀爬珠穆朗玛峰可谓终极目标。攀登珠峰的商业路线有两条,一是尼泊尔境内的南坡路线,一是中国境内的北坡路线。相
  • 腾讯盖楼,字节拆墙

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之“想重温暴刷深渊、30+技能搭配暴搓到爽的游戏体验吗?一起上晶核,即刻暴打!”曾凭借直播腾讯旗下代理格斗游戏《DNF》一
  • 花7万退货退款无门:谁在纵容淘宝珠宝商家造假?

    来源:极点商业作者:杨铭在淘宝购买珠宝玉石后,因为保证金不够赔付,店铺关闭,退货退款难、维权无门的比比皆是。“提供相关产品鉴定证书,支持全国复检,可以30天无理由退换货。&
  • SN570 NVMe SSD固态硬盘 价格与性能兼具

    SN570 NVMe SSD固态硬盘是西部数据发布的最新一代WD Blue系列的固态硬盘,不仅闪存技术更为精进,性能也得到了进一步的跃升。WD Blue SN570 NVMe SSD的包装外
  • 电博会与软博会实现"线下+云端"的双线融合

    在本次“电博会”与“软博会”双展会利好条件的加持下,既可以发挥展会拉动人流、信息流、资金流实现快速交互流动的作用,继而推动区域经济良性发展;又可以聚
  • 中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    11月18日,记者从2022中关村论坛新闻发布会上获悉,中关村论坛将于11月25至30日在京举行。本届中关村论坛由科学技术部、国家发展改革委、工业和信息化部、国务
Top