PHP-CURL在POST请求时的注意事项
2015-06-01 11:46
519 查看
今天搞12306抢票, 在用CURL模拟POST请求校验验证码时, 无论如何12306都返回零, 正常应该返回True或者False, 最后查找原因如下
只是请求头 Content-Type 用了 application/x-www-form-urlencoded, 但是验证码值(类似坐标"xxx,yyy")没有用urlencode转码
注意事项:
1.CURL的POST请求方式, 默认为multipart/form-data
2.如果POST请求中有文件, 则Content-Type应该设置为multipart/form-data, 可以不对请求数据进行urlencode(可以使用http_build_query函数快速创建)
3.如果POST请求中无文件, 则Content-Type应该设置为application/x-www-form-urlencoded, 如果有特殊字符, 由于有部分浏览器不兼容, 所以需要对请求数据进行urlencode(可以使用http_build_query函数快速创建)
即在没有需要上传文件的情况下, 尽量对 POST 提交的数据进行 http_build_query 处理, 然后再发送出去, 能实现更好的兼容性, 更小的请求数据包
只是请求头 Content-Type 用了 application/x-www-form-urlencoded, 但是验证码值(类似坐标"xxx,yyy")没有用urlencode转码
注意事项:
1.CURL的POST请求方式, 默认为multipart/form-data
2.如果POST请求中有文件, 则Content-Type应该设置为multipart/form-data, 可以不对请求数据进行urlencode(可以使用http_build_query函数快速创建)
3.如果POST请求中无文件, 则Content-Type应该设置为application/x-www-form-urlencoded, 如果有特殊字符, 由于有部分浏览器不兼容, 所以需要对请求数据进行urlencode(可以使用http_build_query函数快速创建)
即在没有需要上传文件的情况下, 尽量对 POST 提交的数据进行 http_build_query 处理, 然后再发送出去, 能实现更好的兼容性, 更小的请求数据包
相关文章推荐
- PHP防御防御永久型和反射XSS
- phpcms 移植【添加相关文章】功能
- PHP 二维数组根据某个字段排序
- php自定义错误
- vsftpd cmds_allowed 权限控制
- php BC高精确度函数库
- PHP中的Libevent学习
- RTP打包发送H.264
- Git PHP提交
- PHP中使用cURL实现Get和Post请求的方法
- smtp 发邮件
- php不用正则验证真假身份证 身份证号码验证
- php 编译安装报错 configure: error: mcrypt.h not found. Please reinstall libmcrypt.
- php 函数
- Zend Studio 12 newPHP 模板及编码、和一些常见的问题在哪修改
- php用于URL的base64
- 《PHP内核探索系列文章》系列技术文章整理收藏
- 关于 PHP 7 你必须知道的五件事
- 支持php短格式
- php 连接mysql