PHP8.1.21版本已发布
vue8.1.21版本已发布
jquery8.1.21版本已发布

php curl之curlopt_postfields参数使用细节

原创
2016-07-25 08:53:49 2185浏览
复制代码

当采用 curl 在不注意细节的前提下向服务器发送一些数据,可能得到下面这样的结果,这不是理想中的结果:

  1. [content_type] => multipart/form-data; boundary=—————————-f924413ea122
复制代码

但是如果在采用 http_build_query($post_data) 来替代 $post_data 再向这个 php 脚本提交数据时,就会得到和上面不同的结果,这才是理想中的结果:

  1. [content_type] => application/x-www-form-urlencoded
复制代码

从以上例子看出,使用 curl 并且参数为数据时,向服务器提交数据时,http头会发送content_type: application/x-www-form-urlencoded。这个是正常的网页

提交表单时,浏览器发送的头部。而 multipart/form-data 知道这是用于上传文件的表单。包括了 boundary 分界符,会多出很多字节。

php手册上这样说: the full data to post in a http “post” operation. to post a file, prepend a filename with @ and use the full path. this can either be passed as a urlencoded string like ‘para1=val1?2=val2&…' or as an array with the field name as key and field data as value. if value is an array, the content-type header will be set to multipart/form-data.

使用数组提供 post 数据时,curl 组件大概是为了兼容 @filename 这种上传文件的写法,默认把 content_type 设为了 multipart/form-data。 虽然对于大多数服务器并没有影响,但是还是有少部分服务器不兼容。

结论:在没有需要上传文件的情况下,尽量对 post 提交的数据进行 http_build_query 处理,然后再发送出去,能实现更好的兼容性,更小的请求数据包。



声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。