
// 上传端
/**
* 向目标地址推送xls文件
* @Date 2019/4/29
*/
public function putXls()
{
// 目标接口
$url = "http://xxx"; // 初始化 cURL 会话, 如果提供url,CURLOPT_URL 选项将会被设置成这个值
$ch = curl_init($url); // 获取CURLFile实例
$xlsCurlFile = $this->makeCurlFile(base_path()."/public/tby.xls"); $data = array('xls' => $xlsCurlFile); // TRUE 时会发送 POST 请求,类型为:application/x-www-form-urlencoded,是 HTML 表单提交时最常见的一种。
curl_setopt($ch, CURLOPT_POST, 1); // 从 PHP 5.5.0 开始, @ 前缀已被废弃,文件可通过 CURLFile 发送。 设置 CURLOPT_SAFE_UPLOAD 为 TRUE 可禁用 @ 前缀发送文件,以增加安全性。
curl_setopt($ch, CURLOPT_POSTFIELDS, $data); // 执行给定的 cURL 会话
// 成功时返回 TRUE, 或者在失败时返回 FALSE。 然而,如果 设置了 CURLOPT_RETURNTRANSFER 选项,函数执行成功时会返回执行的结果,失败时返回 FALSE 。
$result = curl_exec($ch); if (curl_errno($ch)) {// 返回错误代码或在没有错误发生时返回 0 (零)。
// 返回错误信息,或者如果没有任何错误发生就返回 '' (空字符串)。
$result = curl_error($ch);
} // 关闭 cURL 会话
curl_close($ch);
} /**
* 根据文件路径获取一个CURLFile类实例
* @param string $file 文件路径
* @return CURLFile
* @Date 2019/4/29
*/
private function makeCurlFile(string $file)
{
/**
* .xls mime为 application/vnd.ms-excel
* .xlsx mime为 application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
* 可参考 https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Basics_of_HTTP/MIME_types/Complete_list_of_MIME_types
*
* 注意:也可以使用 finfo类动态获取,但需要装fileinfo扩展
* demo:
$result = new finfo();
if (is_resource($result) === true) {
return $result->file($filename, FILEINFO_MIME_TYPE);
}
return false;
*/
$mime = "application/vnd.ms-excel";
$info = pathinfo($file);
$name = $info['basename'];
$output = new CURLFile($file, $mime, $name);
return $output;
}
// 接收端
public function getFile()
{
// 保存的文件夹,需要注意所在用户组是否有写入权限
$uploads_dir = base_path()."/public/test";
$xlsFiles = $_FILES["xls"] ?? null;
if($xlsFiles){
if ($xlsFiles["error"] == UPLOAD_ERR_OK) {
$tmp_name = $xlsFiles["tmp_name"];
$name = $xlsFiles["name"];
move_uploaded_file($tmp_name, "$uploads_dir/$name");
}
// todo success
}else{
// todo fail
}
}
注意:需要打开php curl扩展
参考:
https://www.php.net/manual/zh/book.curl.php
https://www.php.net/manual/zh/class.curlfile.php