我写了一个获取youtube视频网址并下载的程序
今天我做了这个:
1.从“/ get_video_info?video_id = ID”获取视频“令牌”,如:
http://www.youtube.com/get_video_info?video_id=jN0nWjvzeNc
2。通过“/ get_video?video_id = ID& t = TOKEN& fmt = FORMAT_ID”请求下载视频,如:
http://www.youtube.com/get_video?video_id=jN0nWjvzeNc&t=vjVQa1PpcFMgAK0HB1VRbinpVOwm29eGugPh3fBi6Dg%3D&fmt=18
但这不再适用了!
什么是新的下载URL?
由于
答案 0 :(得分:15)
其实我正在开发从youtube下载视频文件的类似项目。我发现Youtube可能会阻止get_video。因此,我使用从get_video_info检索到的视频信息而不是使用get_video。,并将其解压缩以获取视频文件网址。
在get_video_info中,有url_encoded_fmt_stream_map。对其进行编码后,您可以找到不同格式的每个视频的网址和签名值。所以文件网址就像[url value] +'& signature ='+ [sig value]。
此外,我发现以下使用与我相同的方法的主题。希望它可以帮到你。
如果您对如何下载YouTube视频文件感兴趣,我会编写一个小程序来演示该过程。你可以自由使用它。
答案 1 :(得分:10)
答案 2 :(得分:10)
您只需使用
即可直接获取流我制作了一个小脚本来在PHP中传输youtube视频。了解脚本如何获取视频文件。
<?php
@set_time_limit(0);
$id = $_GET['id']; //The youtube video ID
$type = $_GET['type']; //the MIME type of the video
parse_str(file_get_contents('http://www.youtube.com/get_video_info?video_id='.$id),$info);
$streams = explode(',',$info['url_encoded_fmt_stream_map']);
foreach($streams as $stream){
parse_str($stream,$real_stream);
$stype = $real_stream['type'];
if(strpos($real_stream['type'],';') !== false){
$tmp = explode(';',$real_stream['type']);
$stype = $tmp[0];
unset($tmp);
}
if($stype == $type && ($real_stream['quality'] == 'large' || $real_stream['quality'] == 'medium' || $real_stream['quality'] == 'small')){
header('Content-type: '.$stype);
header('Transfer-encoding: chunked');
@readfile($real_stream['url'].'&signature='.$real_stream['sig']); //Change here to do other things such as save the file to the filesystem etc.
ob_flush();
flush();
break;
}
}
?>
查看工作演示here。我希望这可以帮到你。
答案 3 :(得分:2)
上次我正在修复其中一个损坏的Chrome扩展程序以下载YouTube视频。我通过改变脚本部分来修复它。
(JavaScript)的
var links = new String();
var downlink = new String();
var has22 = new Boolean();
has22 = false;
var Marked = false;
var FMT_DATA = fmt_url_map;//This is html text that you have to grab. In case of extension it was readily available through:document.getElementsByTagName('script');
var StrSplitter1 = '%2C', StrSplitter2 = '%26', StrSplitter3 = '%3D';
if (FMT_DATA.indexOf(',') > -1) { //Found ,
StrSplitter1 = ',';
StrSplitter2 = (FMT_DATA.indexOf('&') > -1) ? '&' : '\\u0026';
StrSplitter3 = '=';
}
var videoURL = new Array();
var FMT_DATA_PACKET = new Array();
var FMT_DATA_PACKET = FMT_DATA.split(StrSplitter1);
for (var i = 0; i < FMT_DATA_PACKET.length; i++) {
var FMT_DATA_FRAME = FMT_DATA_PACKET[i].split(StrSplitter2);
var FMT_DATA_DUEO = new Array();
for (var j = 0; j < FMT_DATA_FRAME.length; j++) {
var pair = FMT_DATA_FRAME[j].split(StrSplitter3);
if (pair.length == 2) {
FMT_DATA_DUEO[pair[0]] = pair[1];
}
}
var url = (FMT_DATA_DUEO['url']) ? FMT_DATA_DUEO['url'] : null;
if (url == null) continue;
url = unescape(unescape(url)).replace(/\\\//g, '/').replace(/\\u0026/g, '&');
var itag = (FMT_DATA_DUEO['itag']) ? FMT_DATA_DUEO['itag'] : null;
var itag = (FMT_DATA_DUEO['itag']) ? FMT_DATA_DUEO['itag'] : null;
if (itag == null) continue;
var signature = (FMT_DATA_DUEO['sig']) ? FMT_DATA_DUEO['sig'] : null;
if (signature != null) {
url = url + "&signature=" + signature;
}
if (url.toLowerCase().indexOf('http') == 0) { // validate URL
if (itag == '5') {
links += '<a href="' + url + '&title=' + username + title + quality240 + '"style="text-decoration:none"><span class="yt-uix-button-menu-item" id="v240p">FLV (240p)</span></a>';
}
if (itag == '18') {
links += '<a href="' + url + '&title=' + username + title + quality360 + '"style="text-decoration:none"><span class="yt-uix-button-menu-item" id="v360p">MP4 (360p)</span></a>';
}
if (itag == '35') {
links += '<a href="' + url + '&title=' + username + title + quality480 + '"style="text-decoration:none"><span class="yt-uix-button-menu-item" id="v480p">FLV (480p)</span></a>';
}
if (itag == '22') {
links += '<a href="' + url + '&title=' + username + title + quality720 + '"style="text-decoration:none"><span class="yt-uix-button-menu-item" id="v720p">MP4 HD (720p)</span></a>';
}
if (itag == '37') {
links += ' <a href="' + url + '&title=' + username + title + quality1080 + '"style="text-decoration:none"><span class="yt-uix-button-menu-item" id="v1080p">MP4 HD (1080p)</span></a>';
}
if (itag == '38') {
links += '<a href="' + url + '&title=' + username + title + quality4k + '"style="text-decoration:none"><span class="yt-uix-button-menu-item" id="v4k">MP4 HD (4K)</span></a>';
}
FavVideo();
videoURL[itag] = url;
console.log(itag);
}
}
您可以从videoURL[itag]
数组获得单独的视频链接。
可以从here下载扩展程序。
我希望这会对某人有所帮助。这是有效的解决方案(截至2013年4月6日)
答案 4 :(得分:1)
在尝试了很多失败之后,这个github仓库帮助了我:
https://github.com/rg3/youtube-dl
仅以以下方式获取网址:
youtube-dl 'https://www.youtube.com/watch?v=bo_efYhYU2A' --get-url
下载mp4并另存为a.mp4,例如:
youtube-dl 'https://www.youtube.com/watch?v=bo_efYhYU2A' -f mp4 -o a.mp4
祝你好运。