我正在尝试使用此获取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

它下载整个文件。但流媒体不能。

最佳答案

我真蠢!。这只是调试窗口值。

我记录了字符串长度,发现它与文件总长度相同。

10-07 19:20
查看更多