8

我可以授权。

我的页面上有 2 个这样的按钮:

<input type="file" id="fileToSend"/>
<input type="button" onclick="upload()" value="Upload" id="btnSend"/>

当我单击“上传”按钮时,我想将所选文件上传到 youtube。我调用这样的函数:

function upload() {
    var fileStream;
    var video = document.getElementById("fileToSend");
    var file = video.files[0];
    console.log(file);
    console.log("Nombre: " + file.name);
    var r = new FileReader();
    r.onload = function () {
        console.log("fileStream creado");
        fileStream = r.result;
        //console.log("FileStream: " + fileStream);
    };

    console.log("Creando fileStream..");
    r.readAsBinaryString(file);


    gapi.client.load('youtube', 'v3',
        function() {
            var request = gapi.client.youtube.videos.insert({
                part: 'snippet, status',
                resource: {
                    snippet: {
                        title: 'Video Test Title 5',
                        description: 'Video Test Description',
                        tags: ['Tag 1', 'Tag 2'],
                        categoryId: "22"
                    },
                    status: {
                        privacyStatus: "private"
                    }
                }
            }, fileStream);
            request.execute(function (response) {
                console.log("executing..");
                var result = response.result;
                console.log(response);
                if (result) {
                    console.log("execute completed");
                    document.write(result);
                }
            });
        });
}

问题是我在响应对象“mediaBodyRequired”上出现错误,就像我没有正确发送 fileStream。

4

2 回答 2

5

您是否有理由不能只使用 YouTube 上传小部件?
https://developers.google.com/youtube/youtube_upload_widget

无论如何,直接来自 API 参考
https://developers.google.com/youtube/v3/docs/videos/insert

badRequest  mediaBodyRequired   The request does not include the video content.

另一个资源:
https ://developers.google.com/api-client-library/javascript/samples/samples

于 2013-07-22T17:17:50.583 回答
1

使用 v3 插入有两个选项。该请求必须:

  1. 将媒体文件作为正文,排除发送任何其他 POST 参数,或
  2. 分两部分使用多部分形式编码。一部分是要上传的文件,另一部分是类似于文件的 JSON blob,其中包含您要发送的任何参数。

我从来没有使用官方的 JavaScript 客户端完成这项工作,但写了一个非常详细的解释,说明如何使用常规 XmlHttpRequest 工作:http: //lithostech.com/2013/10/upload-google-youtube-api-v3-科尔斯/

这是第一种方法的示例,其中文件本身是整个请求正文:

// where videoFile is a http://www.w3.org/TR/FileAPI/#dfn-file
var invocation = new XMLHttpRequest();
invocation.setRequestHeader('Authorization', 'Bearer ' + token);
invocation.open('POST', "https://www.googleapis.com/upload/youtube/v3/videos?part=snippet", true);
invocation.send(videoFile);
于 2013-11-14T22:16:55.347 回答