Android——解析HTML网页

  可能之前一些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复制进去就可以了,别忘记加网络权限

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值