我正在尝试使用此
获取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
下载整个文件。但流不能。
答案 0 :(得分:0)
我记录了字符串长度,发现它与文件总长度相同。