我正在尝试使用javascript制作基于浏览器的youtube视频上传器。
上传视频后进行身份验证后,对youtube服务器的POST请求永远不会结束,视频也不会上传。
这也发生在sample provided by google。
以下是我用来上传视频的功能:
$('#upload').click(function(){
$('#upload').attr('disabled', true);
var title = escapeXmlEntities($('#title').val());
var description = escapeXmlEntities($('#description').val());
var category = escapeXmlEntities($('#category option:selected').val());
var xmlBody = '<?xml version="1.0"?> <entry xmlns="http://www.w3.org/2005/Atom" xmlns:media="http://search.yahoo.com/mrss/" xmlns:yt="http://gdata.youtube.com/schemas/2007"> <media:group> <media:title type="plain">' + title + '</media:title> <media:description type="plain">' + description + '</media:description> <media:category scheme="http://gdata.youtube.com/schemas/2007/categories.cat">' + category + '</media:category> </media:group> </entry>';
showMsg("Submitting metadata of video to get upload token.");
$.ajax({
dataType: 'xml',
type: 'POST',
url: 'https://gdata.youtube.com/action/GetUploadToken',
contentType: 'application/atom+xml; charset=UTF-8',
processData: false,
headers: generateYouTubeApiHeaders(),
data: xmlBody,
success: function(responseXml) {
var xml = $(responseXml);
var nextUrl = window.location.href;
var submissionUrl = xml.find('url').text() + '?nexturl=' + encodeURIComponent(nextUrl);
var token = xml.find('token').text();
showMsg("Uploading Video...");
$('#form_upload').attr('action', submissionUrl);
$('<input>').attr({
type: 'hidden',
name: 'token',
value: token
}).appendTo('#form_upload');
$('#form_upload').submit();
},
error: function(jqXHR) {
showMsg('Metadata submission failed: ' + jqXHR.responseText);
$('#upload').removeAttr('disabled');
$('#upload').val('Upload');
}
});
});
以下是对youtube服务器发出的最后一个永不停止的POST请求的firebug屏幕截图。
此外,我想获得视频上传的进度,并使用javascript显示它,但我不知道如何实现它我googled并找到了很多方法,但没有什么是成功的。
答案 0 :(得分:2)
现在支持在YouTube Data API v3中使用CORS进行可恢复上传。
https://youtube-api-samples.googlecode.com/git/yt-upload-javascript/index.html(https://code.google.com/p/youtube-api-samples/source/browse/#git%2Fyt-upload-javascript上的源文件)显示上传流程的粗略但有效的示例,使用Google+登录按钮处理OAuth 2(您可以使用正常的OAuth如果您愿意,可以使用2个浏览器客户端流程和进度指示器。它还显示了如何在上传后轮询视频处理状态,并在处理后将结果视频嵌入到页面中。