可能之前一些android程序员自己做一个解析html网页的demo时,大部分都会想到利用jsoup或者是HttpURLConnection 解析,我也用过,这边我就举一个简单的例子,就不详细说了。
首先布局文件,为了不浪费时间,写一个jsoup与HttpURLConnection通用的layout.xml,见以下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<ScrollView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="10dp"
android:layout_marginLeft="10dp"
android:layout_marginRight="10dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:layout_marginRight="10dp"
android:layout_marginTop="10dp"
android:orientation="vertical">
<TextView
android:id="@+id/tv_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text=""
android:textStyle="bold"
android:layout_marginBottom="2dp"
android:textSize="@dimen/killer_text16"/>
<TextView
android:id="@+id/tv_content"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text=""
/>
</LinearLayout>
</ScrollView>
</LinearLayout>
很简单,ScrollView里面放两个TextView控件,一个显示标题,一个显示内容,分别加上id。
首先看下jsoup解析网页的做法,在此之前需要导入jsoup-1.7.2.jar到Libs目录下面,然后在Dependencies里面关联jar包。
代码如下:
package com.lai.activity;
import android.app.Activity;
import android.os.Bundle;
import android.text.Html;
import android.view.View;
import android.widget.TextView;
import com.lai.R;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.select.Elements;
import java.io.InputStream;
public class MainActivity extends Activity {
private TextView Title, Content;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.layout);
Content = (TextView) findViewById(R.id.tv_content);
Title = (TextView) findViewById(R.id.tv_title);
Document doc = Jsoup.connect("http://blog.csdn.net/u013836857").get();
//Elements
String coStr=doc.toString();
Elements title = doc.getElementsByTag("h4");//得到h4标签的内容
Elements span = doc.getElementsByTag("body");//得到body里面的内容
String head = title.text();
String content = span.text();
marketTitle.setText(head);
marketContent.setText(content);
}
}
非常简单,声明Document对象,利用对象.get() 就可以得到这个网页的全部内容,需要哪些部分都可以截取下来,在js中Document对象可以访问html整个网页的所有元素,这里就不说了。
下面来看下HttpURLConnection 的解析:
try {
URL url = new URL("http://blog.csdn.net/u013836857");
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setDoInput(true);
conn.setConnectTimeout(10000);
conn.setRequestMethod("GET");
conn.setRequestProperty("accept", "*/*");
conn.connect();
InputStream stream = conn.getInputStream();
byte[] data = new byte[1024];
int length = stream.read(data);
String str = new String(data, 0, length);
conn.disconnect();
System.out.println("html:"+str);
marketContent.setText(Html.fromHtml(str));
stream.close();
} catch (Exception ee) {
System.out.print("ee:" + ee.getMessage());
}
需要注意的地方:conn.setRequestProperty(“accept”, “/“); 这个属性是HttpURLConnection 通用的,必须要这么写,否则获取不到数据。
关于jsoup和HttpURLConnection 解析html就介绍这么多吧! 下面来看下真正要说的内容。
使用WebView加载HTML网页:
WebView是进行web网页显示的,我们可以直接在当前的Activity中显示在线的内容。
WebView使用WebKit进行渲染来显示网页,通过于此,我们可以进行实现网页后退,前进,放大,缩小或者搜索或者更多功能;
【注意】使用WebView,,因为用处到了网络,所以我们必须在AndroidManifset.xml文件中进行权限设置
<uses-permission android:name="android.permission.INTERNET" />
下面开始布局文件 webview.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_marginLeft="10dp"
android:layout_marginTop="10dp">
<TextView
android:id="@+id/btn_return"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:drawableLeft="@drawable/btn_login_return"
android:drawablePadding="2dp"
android:gravity="center_vertical"
android:text="返回"
android:textColor="@drawable/btn_click_selector"
android:textSize="@dimen/killer_text14" />
</RelativeLayout>
<WebView
android:id="@+id/webView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
>
</WebView>
</LinearLayout>
Activity代码:
package com.lai.activity;
import android.app.Activity;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.View;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.TextView;
import com.lai.R;
public class MarketActivity extends Activity {
private TextView btn_return;//返回按钮
private WebView marketWebView;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.webview);
btn_return = (TextView) findViewById(R.id.btn_return);
marketWebView= (WebView) findViewById(R.id.webView);
btn_return.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
onBackPressed();
}
});
//支持javascript
marketWebView.getSettings().setJavaScriptEnabled(true);
marketWebView.getSettings().setUseWideViewPort(true);
marketWebView.getSettings().setLoadWithOverviewMode(true);
//支持页面缩放
marketWebView.getSettings().setBuiltInZoomControls(true);
//提升渲染优先级
//marketWebView.getSettings().setRenderPriority(WebSettings.RenderPriority.HIGH);
//不加载网络中的图片资源
//marketWebView.getSettings().setBlockNetworkImage(true);
//HTML5 Cache
marketWebView.getSettings().setDomStorageEnabled(true);
marketWebView.getSettings().setAllowFileAccess(true);
marketWebView.getSettings().setAppCacheEnabled(true);
//优先从本地cache中载入,其次才是从网络中载入,即使内容已经过期
marketWebView.getSettings().setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);
marketWebView.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return super.shouldOverrideUrlLoading(view, url);
}
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
super.onPageStarted(view, url, favicon);
}
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
}
@Override
public boolean shouldOverrideKeyEvent(WebView view, KeyEvent event) {
//Android TV中可以在这里返回true,按键交由onKeyDown方法处理
return super.shouldOverrideKeyEvent(view, event);
}
@Override
public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
super.onReceivedError(view, errorCode, description, failingUrl);
}
});
marketWebView.loadUrl("http://blog.csdn.net/u013836857");
}
}
看下效果:
支持各种效果我都写出来了,由于代码量不多,demo的下载地址就不贴出来了,直接将布局文件和Activity复制进去就可以了,别忘记加网络权限。