PHP 利用CURL(HTTP)实现服务器上传文件至另一服务器
// 上传端
/** * 向目标地址推送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