PHP CURL post数据报错 failed creating formpost data_php技巧

在做微信卡券使用curl上传logo图片时,发现一个报错:

failed creating formpost data

代码中数组如下:

$data = array('buffer' => '@test.jpg');

结合微信给的文档,检查语法,貌似并没有发现什么错误...

经过上网查询和验证,最终发现,问题出现在 @ 这里,如果在 @ 前面加一个 \ 转义下就可以了,在php官方的bugs.php.net中也有提到(本文最后提供网址)

最终代码:

$data = array('buffer' => '\\@test.jpg');

问题解决。

bugs地址参考:https://bugs.php.net/bug.php?id=50060

我们再来看一个实例:

之前写过一个php使用curl上传文件的代码,今天暴出了一个bug,curl错误信息为"failed creating formpost data"

先说一下curl上传文件的过程吧

$file =array("upimg"=>"@/tmp/tmp.jpg");//文件路径,前面要加@,表明是文件上传.
$url = 'http://localhosts/upload.php';
$ch = curl_init();
curl_setopt($ch ,CURLOPT_URL,$url);
curl_setopt($ch,CURLOPT_POST,true);
curl_setopt($ch,CURLOPT_POSTFIELDS,$file);
curl_exec($ch);

这里有两个地方需要注意:

1、$file必须是数组

2、上传文件的路径前面加@

3、路径必须使用决定路径

现在分析出现"failed creating formpost data" 错误原因

首先很快就定位到出现该问题的原因是路径问题,分析了程序代码也没发现什么问题,始终不得解

最后通过错误日志查得这个原因是因为curl post提交的数据参数中有一个参数内容是以@符号开头的,

比如说要上传/tmp/tmp.jpg,同时提交简介,这样参数值就是 path='/tmp/tmp.jpg', 输入简介desc='@test haha';

根据手册上说curl post提交数据有两种方式

1.curl($ch, CURLOPT_POSTFIELD, array('pic'=>'@/tmp/tmp.jpg', 'filename'=>'tmp'); 

2.curl($ch, CURLOPT_POSTFIELD, 'pic=@/tmp/tmp.jpg&filename=tmp') 

在有上传文件的情况下必须使用第一种方式

curl($ch, CURLOPT_POSTFIELD, array('pic'=>'@/tmp/tmp.jpg', 'filename'=>'tmp'); 

这样如果第一字符是@符后面的内容均会被解析成地址,如果地址不存在就会抛出该错误,就想简介desc @test 这个路径是不存在的

第二种方式只会将其当作普通字符串处理

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索curl
, form
, post
, data
, libcurl
, failed
, creating
formpost
curl post form data、curl post form、php curl post form、libcurl post form、failed creating java,以便于您获取更多的相关知识。

时间: 2024-09-18 22:48:35

PHP CURL post数据报错 failed creating formpost data_php技巧的相关文章

Windows下elasticsearch插入数据报错!

按照官方文档操作,但是windows下有些不同,它不认识单引号',因此如果这样操作,就会报错: C:\Users\neusoft>curl localhost:9200/b1/b2/1 -d {"name":"fdafa"} {"error":"MapperParsingException[failed to parse]; nested: JsonParseException[Un recognized token 'fdafa

spring mvc-service层加入@Tractional 后报错error creating bean

问题描述 service层加入@Tractional 后报错error creating bean 我在一个web项目中想加入事务,是采用spring mvc+hibernate的框架配置文件中已经加入 <!-- 配置Hibernate事务管理器 --> <bean id=""transactionManager"" class=""org.springframework.orm.hibernate4.HibernateTran

hive跟hbase整合用hive导入数据报错,报一个路径不是目录。

问题描述 hive跟hbase整合用hive导入数据报错,报一个路径不是目录. hive>load data local inpath '/home/hadoop/ha1.txt' into table ha1; FAILED: Hive Internal Error: java.lang.RuntimeException(org.apache.hadoop.ipc.RemoteException: java.io.FileNotFoundException: Parent path is no

动态下拉列表-Extjs动态取List数据报错

问题描述 Extjs动态取List数据报错 2014-4-21 14:18:25 org.apache.catalina.core.StandardWrapperValve invoke 严重: Servlet.service() for servlet [platform] in context with path [/sale-web] threw exception [Request processing failed; nested exception is org.springfram

hive问题: pyhs2 load数据报错

问题描述 hive问题: pyhs2 load数据报错 Traceback (most recent call last): File "hive_pyhs2.py", line 23, in cur.execute("load data local inpath '/home/linqiaoying/e/hive/data/b.txt' overwrite into table student") File "build/bdist.linux-x86_

小弟初学mybatis ,查询数据报错

问题描述 小弟初学mybatis ,查询数据报错 Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException: ### Error querying database. Cause: java.lang.ArrayIndexOutOfBou

rror 1615 tate 000-jdbc定时批量插入数据报错

问题描述 jdbc定时批量插入数据报错 错误提示如下: Dec 19 2014 12:20:00 AM org.hibernate.util.JDBCExceptionReporter logExceptionsWARNING: SQL Error: 1615 SQLState: HY000Dec 19 2014 12:20:00 AM org.hibernate.util.JDBCExceptionReporter logExceptionsWARNING: SQL Error: 1615 S

spring mvc-springmvc获取json数据报错

问题描述 springmvc获取json数据报错 springmvc不通过bean获取json传过来数据的值,怎样写springMVC的控制层? 解决方案 你说得是什么意思呢?如果请求参数从前台传入后台是通过你的代码Json. stringify转化的JSON格式的数据的话,那么在后台收到的这个参数的本质类型是String,你使用时就需要使用JSON转换工具转成Java的对象. 解决方案二: 通不通过bean是什么意思?你只要response 的是json 格式就可以 . 解决方案三: 不通过b

delphi用dbExpress中的TSQLConnection组件连接oracle数据报错!

问题描述 delphi用dbExpress中的TSQLConnection组件连接oracle数据报错! http://zhidao.baidu.com/question/2051755277318156387.html?quesup2&oldq=1