POST 可以直接将参数放在 body 里面,为什么多此一举呢? 或者什么情况下需要在 url 拼接参数呢?
比如 POST body 是 json 格式,但又需要传 x-www-form-urlencoded 的时候?
POST 可以直接将参数放在 body 里面,为什么多此一举呢? 或者什么情况下需要在 url 拼接参数呢?
比如 POST body 是 json 格式,但又需要传 x-www-form-urlencoded 的时候?
1
myCupOfTea Jun 17, 2020 via Android
post 用 path var 倒是可以理解,还用 params 我不太能理解为啥要这么干
|
2
halk Jun 17, 2020 因为 HTTP 协议并没有禁止
|
3
domybestFujian Jun 17, 2020
因为偷懒
|
4
shiny PRO 比如钉钉的设计,不管是 GET 还是 POST,AccessToken 都放 query string 中,风格保持统一。
|
5
bitholic Jun 17, 2020 via iPhone
Nginx 等比较好把 query string 打印出来
|
6
GM Jun 17, 2020
有时候这样比较方便。
比如 /api/wtf?v=a 和 /api/wtf?v=b 代码里可以根据 v 的值的不同,用不同版本的 handler 来处理 body 。 |
7
zhuweiyou Jun 17, 2020
qs 和 body 又不冲突
|
8
GM Jun 17, 2020
补充上面:
然后 handler 里就可以保持纯净,不需要做跟业务无关的判断。 |
9
jinzhongyuan Jun 17, 2020
@halk 应该是实现的库没有禁止哈
|
10
misaka19000 Jun 17, 2020
为什么晚上吃了肉还要吃蔬菜呢
|
11
marquina Jun 17, 2020 via Android
@myCupOfTea path var 不就是 params 吗
|
12
momocraft Jun 17, 2020 什么叫多此一举,你 post 过除了 json 和 form 的东西吗
> 9 以 RFC 为准,http (包括 uri) 就是没有禁止,请不要自己加戏 |
13
myCupOfTea Jun 17, 2020 @marquina 表达不清楚,pathParams 理解,queryParams 不理解
|
14
xiangyuecn Jun 17, 2020
分析一下 HTTP 请求格式就知道了
部分参数放 url 里,你就不用读取请求 input stream (这玩意往往是只能读一次),就能拿到某些必要的参数,用处很大的,不然 form 、file 、raw stream 等操作是要读取并解析 input stream 后才能拿到参数的 |
15
myCupOfTea Jun 17, 2020
|
16
woodensail Jun 17, 2020
做鉴权很有用。服务端可以在 option 请求过来的时候就把请求干掉,不需要接收 post 的请求体了。降低鉴权服务器的压力。
|
17
ditel Jun 17, 2020 via Android
感觉上传文件又需要签名验证的时候
|
18
lxz6597863 Jun 17, 2020
POST /api/user?username=abc
{ "age":1 } update user set age=1 where username=abc |
19
ai277014717 Jun 17, 2020
@lxz6597863 应该用 put
|
20
sadfQED2 Jun 17, 2020 via Android 只要你高兴,get 请求还能在 body 体里面传参呢
|
21
wangyzj Jun 17, 2020
一种习惯吧
我习惯 body 里面只提交数据 不包括已有参数 |
22
Jackeriss Jun 17, 2020
想怎么传就怎么传,你甚至可以把参数写 header 里
|
23
Vegetable Jun 17, 2020 @sadfQED2 #20 NO,这个不行。https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Methods/GET
规范中 GET 方法是没有 BODY 的,如果你传了是有可能被某些实现丢弃的,属于规范禁止的行为。 |
24
kidtest Jun 17, 2020
nginx hash 可以用到
|
25
mmdsun Jun 17, 2020 via Android
因为 body 里面大多是实体之类的映射的。
像 accesstoken 统一要传的,不可能往实体里面扩展吧。 这种要么放 URL,要么放 head 了。 |
26
sadfQED2 Jun 17, 2020 via Android
@Vegetable 浏览器会丢掉,但是如果你只是实现 rpc 调用的话,也能带 body 体,比如 es 的 api 接口就支持 get 请求带 body 体
|
27
ClericPy Jun 17, 2020
1. 设计
2. 日志分析 3. 历史遗留 |
28
showmethetalk Jun 17, 2020 via Android
@GM 那可以把版本信息放在 path 里啊
|
29
rioshikelong121 Jun 17, 2020
为什么不行呢?有的参数我觉得完全可以放在 querystring 里面。
|
30
EminemW Jun 17, 2020
我把 token 放在 queryString
|
31
yukiloh Jun 17, 2020
我刚用 axios 的时候控制不好,经常就是想传个 json,结果传到 path 上
|
32
jerry Jun 17, 2020 via iPhone
比如全局参数
|
34
AV1 Jun 17, 2020
有些中转代理工具处理 url 比 body 方便一些。
当然,更多的是保持 get 和 post 风格统一,action 之类的参数就直接写在 url search 里了。 |
35
otakustay Jun 17, 2020
你看嘛,一个 HTTP 请求的 URL 放在第一行的
然后 body 可能是很大的,甚至可能是一个文件,所以 body 有可能是流式处理的 这也就代表着,如果你需要将一个请求分配到一个具体的函数上去的话,等 body 全部解析完是很慢的也很没必要的 举个例子,body 是一个文件流的话,只要我分配到了“把文件存起来”这个函数上,这个函数就可以把 body 流对接到 file 流。但如果我没办法分配到函数上,我就要等 body 流读完,把这个流放在内存里(假设内存没爆掉),然后解析 body 分析函数,把整个内存里的流给它,它再存到文件里,这效率多低啊 所以一些参数放在 URL 是非常合理的,特别是用来鉴权的、判断路由的等等 当然我可以不用 URL 而用 HTTP 头,但 HTTP 头的危险性在于你不知道中间有哪个 SB 一样的代理自说自画给你改了或者弄丢了…… |
36
jiangzm Jun 17, 2020
|
37
Vegetable Jun 17, 2020
@sadfQED2 #26 没错呀,还有些骚的不行的也能自定义 HTTP 方法,规范毕竟只是一种规范,不推荐这么用大家还是别太奔放的好,如果两边都可控的话怎么玩都行
|
38
also24 Jun 17, 2020
|
39
myCupOfTea Jun 18, 2020
@also24 但实际上那天你的小伙伴升级成 fetch 来请求,就全部报错了
|
40
wangyanrui Jun 18, 2020
方便且团队中大多数人认可,就可行!
|
41
weixiangzhe Jun 18, 2020 via Android
querystring 有长度限制啊, 放 body 里好
|
43
GM Jun 18, 2020
@ai277014717 put,语义是用提交的数据替换目标对象,你这么做的话 username 就没了
|
44
showmethetalk Jun 21, 2020 via Android
@GM rustfull 吧。querysyribng 是用了查询的,post 是推数据的,一般这两个应用场景不重叠
|