0

動画を Wistia にアップロードするために PHP で cURL を使用しています。私のローカルサーバーではすべて正常に動作します。しかし、開発サーバーでは、ビデオがアップロードされていません。var_dump(curl_getinfo($ch)) を使用すると、content_typeがローカルと開発サーバーで異なることがわかります。私はそれについて混乱しています.誰かがこの問題を解決するのを手伝ってくれますか.

これが私のコードです:

public function video_upload($filePath)
{         
    $data = array(
        'api_password'  => '0XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX5',
        'file'          => '@'.$filePath,
    );

    $url = 'https://upload.wistia.com';    
    $ch  = curl_init();
    curl_setopt_array($ch, array(
        CURLOPT_URL            => $url,
        CURLOPT_POST           => true,
        CURLOPT_POSTFIELDS     => $data,
        CURLOPT_HEADER         => false,
        CURLOPT_RETURNTRANSFER => true,
    ));
    curl_setopt($ch, CURLINFO_HEADER_OUT, true);
    $response = curl_exec($ch);

    var_dump(curl_getinfo($ch));
    var_dump(curl_errno($ch));
    curl_close($ch);

    return $response;
}

ローカル サーバーで受信した応答:

array(27) {
    ["url"]=> string(26) "https://upload.wistia.com/"
    **["content_type"]=> string(30) "application/json;charset=utf-8"**
    ["http_code"]=> int(200)
    ["header_size"]=> int(688)
    ["request_size"]=> int(189)
    ["filetime"]=> int(-1)
    ["ssl_verify_result"]=> int(0)
    ["redirect_count"]=> int(0)
    ["total_time"]=> float(17.850026)
    ["namelookup_time"]=> float(0.252903)
    ["connect_time"]=> float(0.253271)
    ["pretransfer_time"]=> float(1.903306)
    ["size_upload"]=> float(279250)
    ["size_download"]=> float(417)
    ["speed_download"]=> float(23)
    ["speed_upload"]=> float(15644)
    ["download_content_length"]=> float(417)
    ["upload_content_length"]=> float(279250)
    ["starttransfer_time"]=> float(2.173591)
    ["redirect_time"]=> float(0)
    ["redirect_url"]=> string(0) ""
    ["primary_ip"]=> string(13) "162.209.95.19"
    ["certinfo"]=> array(0) { }
    ["primary_port"]=> int(443)
    ["local_ip"]=> string(13) "192.168.1.157"
    ["local_port"]=> int(54999)
    ["request_header"]=> string(189) "POST / HTTP/1.1 Host: upload.wistia.com Accept: */* Content-Length: 279250 Expect: 100-continue Content-Type: multipart/form-data; boundary=------------------------370a5719d6336ecc "
} int(0)

私の開発サーバーで受信した応答:

array(27) {
    ["url"]=> string(26) "https://upload.wistia.com/"
    **["content_type"]=> string(23) "text/html;charset=utf-8"**
    ["http_code"]=> int(500)
    ["header_size"]=> int(718)
    ["request_size"]=> int(186)
    ["filetime"]=> int(-1)
    ["ssl_verify_result"]=> int(0)
    ["redirect_count"]=> int(0)
    ["total_time"]=> float(0.437061)
    ["namelookup_time"]=> float(0.004766)
    ["connect_time"]=> float(0.023656)
    ["pretransfer_time"]=> float(0.194844)
    ["size_upload"]=> float(319)
    ["size_download"]=> float(30)
    ["speed_download"]=> float(68)
    ["speed_upload"]=> float(729)
    ["download_content_length"]=> float(30)
    ["upload_content_length"]=> float(319)
    ["starttransfer_time"]=> float(0.216544)
    ["redirect_time"]=> float(0)
    ["redirect_url"]=> string(0) ""
    ["primary_ip"]=> string(15) "162.242.168.223"
    ["certinfo"]=> array(0) { }
    ["primary_port"]=> int(443)
    ["local_ip"]=> string(14) "224.178.240.48"
    ["local_port"]=> int(55164)
    ["request_header"]=> string(186) "POST / HTTP/1.1 Host: upload.wistia.com Accept: */* Content-Length: 319 Expect: 100-continue Content-Type: multipart/form-data; boundary=----------------------------d45c07c28860 "
} int(0) 
4

3 に答える 3

0

動作しない理由を特定するのは難しいですが、サーバーからの応答には500http ステータス コードが含まれており、サーバーに問題があることを示しています。

あなたの側に何か問題がある可能性はありますが、サーバーからの情報がなければ、何が問題なのかを判断するのは非常に困難です。通常、500サーバーからの応答は、クライアント (あなた) のエラーではなく、サーバー (wistia) のエラーを示します。

詳細を取得するために wistia に情報を送信することをお勧めします。

于 2016-03-02T13:23:54.563 に答える
0

2 番目の応答でサーバーから 500 エラーが返されます。そのため、json ではありません。

于 2016-03-02T13:40:33.513 に答える