通过XHR2在Youtube上上传视频

时间:2013-01-14 15:15:16

标签: youtube-api cors xmlhttprequest-level2

我的客户希望在用户在Youtube上上传视频时显示进度对话框。

我写了类似的东西:

    element = document.forms.uploadNewVideoForm.file;

    var fd = new FormData();
    console.log(element.files);
    fd.append('token', $scope.uploadData.token);
    fd.append('file', element.files[0]);

    var xhr = new XMLHttpRequest();
    xhr.upload.addEventListener("progress", $scope.uploadProgress, false);
    xhr.addEventListener("load", $scope.uploadComplete, false);
    xhr.addEventListener("error", $scope.uploadComplete, false);
    xhr.addEventListener("abort", $scope.uploadComplete, false);
    xhr.open("POST", $scope.uploadData.uploadUrl + '?nexturl=' + encodeURIComponent('http://local.app.com:8000/OK'));

    xhr.onreadystatechange = function ( response ) {};
    xhr.send(fd);

此代码启动完美,但在Youtube重定向到回调URL时失败。

POST http://uploads.gdata.youtube.com/action/FormDataUpload/<token here>?nexturl=http%3A%2F%2Flocal.app.com%3A8000%2FOK

302 Moved Temporarily 
Location: http://local.app.com:8000/OK

这里请求中断并调用错误回调。

1 个答案:

答案 0 :(得分:0)

查看以下samplesource code)。它将上传分为两部分:

  1. 上传元数据的CORS请求。
  2. 用于上传实际视频的表单POST。
  3. 不幸的是,上传页面还不支持CORS,所以这是你能做到的最好的。