// 上傳端
/** * 向目標地址推送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 * @Author zishuang.lin * @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擴展php
參考:
https://www.php.net/manual/zh/book.curl.php
https://www.php.net/manual/zh/class.curlfile.php安全