我一直在使用http://www.youtube-mp3.org/来获取“互联网广播”项目(下载文件流并输出)的mp3歌曲的下载链接。最近,http://www.youtube-mp3.org/似乎改变了它的工作流程。直到现在我能够获得正确的网址格式:
而r =时间戳 我把自己的时间戳作为时代。这没有.1527580295后缀,效果很好。 不幸的是,这似乎是必要的,因为没有后缀的链接会重定向回转换网站。
到目前为止,算法如上所述:
Youtube mp3 org linq acquiring explained
http://www.youtube-mp3.org/api/itemInfo/?video_id=#{video_id}&ac=www&r=#{Time.now.to_i}
有没有人知道如何获得后缀部分?
//嘿 我不是一个网络编程人员...但这是我肯定忽略的。谢谢!
将此添加到我的小型C#API中。
<!-- language: c# -->
const int AM = 65521;
int GetCCSufix(string a)
{
int c = 1, b = 0, d, e;
var chars = a.ToCharArray();
for(e =0; e< chars.Length; e ++)
{
d = chars[e];
c = (c + d) % AM;
b = (b + c) % AM;
}
return b << 16 | c;
}
效果很好;)
答案 0 :(得分:5)
我不知道这个后缀是什么意思,但是从youtube-mp3.org读取客户端javascript文件,你可以学习如何生成它。
var __AM=65521; // the largest prime less than 2^16...
function cc(a){
var c = 1, b = 0, d, e;
for(e = 0; e < a.length; e++){
d = a.charCodeAt(e);
c = (c+d)%__AM;
b = (b+c)%__AM;
}
return b<<16|c;
}
生成的媒体网址为:
"http://www.youtube-mp3.org/get?ab=128&video_id="+video_id+"&h="+info.h+"&r="+timeNow+"."+cc(video_id+timeNow)
与
var timeNow = Date.now().toString();