我正在尝试使用此获取youtube下载链接
String data = getURL("http://www.youtube.com/get_video_info?video_id=" + id);
但是它总是返回一部分数据。例如,数据结尾类似于“...”,
expire%253D1391242316%2526ms%253Dau%2526fexp%253D900356%25252C902546%25252C936910%252...
我用了这段代码
public String getURL(String s){
InputStream is = null;
try{
URL r = new URL(s);
URLConnection rc = r.openConnection();
DataInputStream dis = new DataInputStream(rc.getInputStream());
List<Byte> l = new ArrayList<Byte>();
while(true){
try{
l.add(dis.readByte());
}catch(Exception e){
break;
}
}
byte[] b = new byte[l.size()];
for(int i = 0; i < l.size(); i++){
b[i] = l.get(i);
}
return new String(b,"UTF-8");
}catch(Exception e){
e.printStackTrace();
return null;
}
}
有谁为什么不能获得全部数据?
如果我仅通过此网址使用chrome,则可以下载
http://www.youtube.com/get_video_info?video_id=itGNQbJwRSk
它下载整个文件。但流媒体不能。
最佳答案
我真蠢!。这只是调试窗口值。
我记录了字符串长度,发现它与文件总长度相同。