跨服務上傳文件Curl方式

在開發過程中有時會遇到從A服務器上傳文件、圖片到B服務器,這時可以用Curl發送http請求

上傳端:

  /**
     * 向目標地址推送xls文件
     * @Date 2020/1/13
     */
    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 xiaoxiaobai
     * @Date 2020/1/13
     */
    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"; //可以根據上傳的類型選擇mine
        $info = pathinfo($file);
        $name = $info['basename'];
        $output = new CURLFile($file, $mime, $name);
        return $output;
    }

2、接收端:

// 接收端
public function getFile()
{
    // 保存的文件夾,需要注意所在用戶組是否有寫入權限
    $uploads_dir = base_path()."/public/test";
    $xlsFiles = $_FILES["xls"] ?? null;  //其中xls是請求端傳的參數
    if($xlsFiles){
        if ($xlsFiles["error"] == UPLOAD_ERR_OK) {
            $tmp_name = $xlsFiles["tmp_name"];
            $name = $xlsFiles["name"];
            if (!file_exists($uploadpath)) {
                    @mkdir($uploadpath, 0777, true);
            }
            move_uploaded_file($tmp_name, "$uploads_dir/$name");
        }
        // todo success
    }else{
        // todo fail
    }
}

 

發佈了31 篇原創文章 · 獲贊 9 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章