我正在编写一个可下载YouTube视频的应用,但我遇到了一些问题。
您可能知道,youtuube中的每个视频链接都包含指向该视频的直接链接。 当页面使用flash flayer(而不是html5左右)时,它存储在flash对象中(在flashvar attr中)。 我的应用程序解析该flash对象并从中提取那些直接链接(每个可用视频质量的一个链接)。
我通过下载视频的html代码(例如http://www.youtube.com/watch?v=VIDEOID)并解析它来获取flash对象的html代码。
我使用asynctask来下载html代码(非移动版),这是我的下载代码:
HttpClient client = new DefaultHttpClient();
client.getParams().setParameter(CoreProtocolPNames.USER_AGENT, "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:8.0.1)");
HttpGet request = new HttpGet(url);
HttpResponse response = client.execute(request);
String html = "";
InputStream in = response.getEntity().getContent();
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
StringBuilder str = new StringBuilder();
String line = null;
while((line = reader.readLine()) != null)
{
str.append(line);
}
in.close();
html = str.toString();
return html;
现在我遇到了一个问题:
上面的代码不会下载whloe html代码。下载的html字符串在中间某处被切断,我没有得到flash对象的一部分。此功能适用于其他网站!
我做错了吗?
谢谢:)
答案 0 :(得分:0)
String html = client.execute(request, new BasicResponseHandler());