<form action="" method="post" enctype="multipart/form-data">
<input type="file" name="upload">
<buttion>submit</button>
</form>
需要模拟的就是上面form表单。
-
正文的开始
// form.php
/**
* curl Post文件,php5以下版本可用
*
* @param $action (处理上传文件的url,form表单的action)
* @param $path (文件路径)
**/
function upload_file($action, $path){
$data = array(
// 需要注意的是,在路径前必须带上@,不然只会当做是简单的键值对
'pic' => '@'.realpath($path)
'name' => 'issac'
);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $action);
curl_setopt($ch, CURLOPT_POST, true );
curl_setopt($ch, CURLOPT_POSTFIELDS, $data); //该curl_setopt可以向header写键值对
curl_setopt($ch, CURLOPT_HEADER, false); // 不返回头信息
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$output = curl_exec($ch);
curl_close($ch);
return $output;
}
// 调用
upload_file('accrpt.php', '/files/img.png');
// accept.php
print_r($_FILES); // 输出上传到服务器的临时文件的信息
print_r($_POST); // name => issac
PS:上面例子只有在php5以下版本有效,换言之现在根本没有用 根本没有用 根本没有用 [手动摔桌子],而且现在网上充斥的全是这种过时的失效版本
@字符什么,现在根本没有用了,不要怀疑你自己,还有网上说只要加上:
curl_setopt($ch, CURLOPT_SAFE_UPLOAD, false);
就能起效,不用怀疑,这也是没有效的[手动摔桌子],这个选项已经弃用了,现在。
-
以下才是现在真实有效的做法:
用curlFile代替@,也不需要使用 CURLOPT_SAFE_UPLOAD
用
$data = array(
'pic'=>new CURLFile($path)
// 如果无效可以这样
// 'pic'=>curl_file_create($path)
);
替换
$data = array(
'pic'=>'@'.realpath($path)
);
PS: $path不要使用网络路径 (http://xxxx/files/img.png),要使用本地路径(/files/img.png)