Android程序错误
我写了这个Android程序作为一个新闻源…它工作良好,直到-目前-关于focal.ie的文章。所以前6层楼的负荷很好,但其余的都没有,我绞尽脑汁想弄清楚原因。任何帮助都将不胜感激。这是密码。谢谢Android程序错误,android,html,android-webview,Android,Html,Android Webview,我写了这个Android程序作为一个新闻源…它工作良好,直到-目前-关于focal.ie的文章。所以前6层楼的负荷很好,但其余的都没有,我绞尽脑汁想弄清楚原因。任何帮助都将不胜感激。这是密码。谢谢 package com.news; import java.io.IOException; import org.jsoup.Jsoup; import org.jsoup.nodes.Document; import org.jsoup.nodes.Element; import org.js
package com.news;
import java.io.IOException;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;
import android.app.Activity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.webkit.WebView;
import android.webkit.WebViewClient;
public class NewsActivity extends Activity {
WebView mWebView;
String test2 = "<html><body><table border=0 width=10 height=10>";
Document docs;
Document writing;
String text(String link)
{
String full ="<html><body><table border=0 cellpadding=2 cellspacing=2><tr><td>";;
try {
writing = Jsoup.connect(link).get();
} catch (IOException e) {
e.printStackTrace();
}
Element heading = writing.select("h2").first();
Elements classname = writing.getElementsByClass("news");
Elements items = classname.select("p");
full = full + heading.text() + "<br>" + items.get(0).text() + "</td></tr>";
Elements imgs2 = writing.select("img[src$=.jpg]");
String picture = imgs2.get(1).absUrl("src");
String newImg = "<img src=\"" + picture + "\"/ width =100 >";
full = full + "<tr><td>" + newImg + "</td></tr>";
full = full + "<tr><td>";
for (int i = 1; i< items.size(); i++)
{
full = full + items.get(i).text();
}
full = full + "</td></tr></table></body></html>";
return full;
}
public void main(String... args)
{
try
{
docs = Jsoup.connect("http://www.dcu.ie/news/index.shtml").get();
}
catch (IOException e)
{
e.printStackTrace();
}
Elements imgs = docs.select("img[src$=.jpg]");
Elements txt = docs.select("h2");
Elements article = docs.getElementsByClass("date");
Elements links = article.select("a[href]");
for (int i = 1; i < imgs.size(); i++){
String url = imgs.get(i).absUrl("src");
String temp = links.get(i-1).absUrl("href");
String temp2 = "<a href=\"" + temp + "\"/>";
String newImg = temp2 + "<img src=\"" + url + "\"/ width =100 >";
test2 = test2 + "<tr>";
test2 = test2 + "<td>";
test2 = test2 + " " + newImg + " ";
test2 = test2 + "</td>";
test2 = test2 + "<td>";
test2 = test2 + " " + txt.get(i-1).text() + " " + temp2;
test2 = test2 + "</td>";
test2 = test2 + "</tr>";
}
test2 = test2 + "</table>";
test2 = test2 + "</html></body>";
}
public void onCreate(Bundle savedInstanceState) {
main();
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mWebView = (WebView) findViewById(R.id.webview);
mWebView.setWebViewClient(new NewsClient());
mWebView.getSettings().setJavaScriptEnabled(true);
mWebView.getSettings().setDomStorageEnabled(true);
mWebView.loadData(test2, "text/html", "utf-8");
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) {
mWebView.goBack();
return true;
}
return super.onKeyDown(keyCode, event);
}
private class NewsClient extends WebViewClient {
public boolean shouldOverrideUrlLoading(WebView view, String url) {
String newUrl = text(url);
view.loadData(newUrl, "text/html", "utf-8");
return true;
}
}
}
我的猜测是,丢失的结束锚标签导致了问题。我猜HTML解析器不喜欢空的锚标记:
String temp2 = "<a href=\"" + temp + "\"/>";
String newImg = temp2 + "<img src=\"" + url + "\"/ width =100 >";
test2 = test2 + "<tr>";
应该是:
String temp2 = "<a href=\"" + temp + "\" >";
String newImg = temp2 + "<img src=\"" + url + "\"/ width =100 >" + "</a>";
test2 = test2 + "<tr>";
test2 = test2 + temp2+ " " + txt.get(i-1).text() + " </a>";
你在logcat中有错误吗?
test2 = test2 + temp2+ " " + txt.get(i-1).text() + " </a>";