http - 我如何处理 HTTP GET 查询字符串长度限制并仍然想成为 RESTful?

标签 http rest

http://www.boutell.com/newfaq/misc/urllength.html 中所述, HTTP 查询字符串有长度限制。它可以被客户端(Firefox、IE、...)、服务器(Apache、IIS、...)或网络设备(应用防火墙、...)限制。

今天我遇到了一个搜索表单的问题。我们开发了一个包含很多字段的搜索表单,此表单作为 GET 请求发送到服务器,因此我可以为结果页面添加书签。

我们的字段太多以至于我们的查询字符串有 1100 字节长,而且我们有一个防火墙可以丢弃超过 1024 字节的 HTTP GET 请求。我们的系统管理员建议我们改用 POST,这样就没有限制了。

当然,POST 可以,但我真的觉得搜索是 GET 而不是 POST。所以我想我会检查我们的字段名称以确保查询字符串不会太长,如果我不能,我会务实地使用 POST。

但是RESTful服务的设计有缺陷吗?如果 GET 请求的长度有限,我该怎么做才能将大对象发送到 RESTful web 服务?例如,如果我有一个基于文件进行计算的程序,并且我想提供这样的 RESTful web 服务:http://compute.com?content=<base64 file> .这是行不通的,因为查询字符串的长度不是无限的。

我有点不解...

最佳答案

HTTP 规范实际advises to use POST when sending data to a resource用于计算。

您的搜索看起来像是一种计算,而不是资源本身。如果您仍然希望搜索结果成为资源,您可以做的是创建一个 token 来标识该特定搜索结果并将用户代理重定向到该资源。

您可以在一段时间后删除搜索结果标记。

示例

POST /search
query=something&category=c1&category=c2&...

201 Created
Location: /search/01543164876

然后

GET /search/01543164876

200 Ok
... your results here...

这样,浏览器和代理仍然可以缓存搜索结果,但您使用 POST 提交查询参数。

编辑

需要说明的是,此处的 01543164876 表示表示您的搜索的资源的唯一 ID。这 2 个请求基本上意味着:使用这些条件创建一个新的搜索对象,然后检索与创建的搜索对象关联的结果。

此 ID 可以是为每个新请求生成的唯一 ID。这意味着您的服务器将泄漏“搜索”对象,您将不得不使用缓存策略定期清理它们。

或者它可以是所有实际代表用户要求的搜索的搜索条件的散列。这允许您重复使用 ID,因为重新创建搜索将返回可能(或可能未)已缓存的现有 ID。

关于http - 我如何处理 HTTP GET 查询字符串长度限制并仍然想成为 RESTful?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4203686/

相关文章:

javascript - Angular:Http 与 fetch api

Android:处理来自 HTTP Get-Request 的 Cookie

apache-flex - flex 移动项目 : Establish http connection to a specific url

rest - 如何将应用程序从 Grails 2.1.2 迁移到 Grails 2.3.5?

java - Jersey & Jackson - 修改 Jackson 输出的资源

rest - 如何为非CRUD “commands”设计REST API,例如激活和停用资源?

android - 有没有办法从对服务器的http请求确定移动操作系统(iOS、Android等)?

javascript - Angular http 请求不起作用,但 postman 工作

android - 如何为仅返回 bool 值的 API 编写 API 调用作为 android 中 retrofit 2 的响应?

java - 接受 header 为空或未知时的内容类型