1. 使能javascript:

1 webView.getSettings().setJavaScriptEnabled( true );

2. 编写本地接口

1 2 3 4 5 final class InJavaScriptLocalObj { public void showSource(String html) { Log.d( "HTML" , html); } }


3. 向网页暴露本地接口

1 webView.addJavascriptInterface( new InJavaScriptLocalObj(), "local_obj" );


4. 编写自己的WebViewClient,并在onPageFinished中提取网页源码。

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 final class MyWebViewClient extends WebViewClient{ public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true ; } public void onPageStarted(WebView view, String url, Bitmap favicon) { Log.d( "WebView" , "onPageStarted" ); super .onPageStarted(view, url, favicon); } public void onPageFinished(WebView view, String url) { Log.d( "WebView" , "onPageFinished " ); view.loadUrl( "javascript:window.local_obj.showSource('<head>'+" + "document.getElementsByTagName('html')[0].innerHTML+'</head>');" ); super .onPageFinished(view, url); } }

组合在一起的代码为:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 package com.hi.briancol.htmlsource; import android.app.Activity; import android.graphics.Bitmap; import android.os.Bundle; import android.util.Log; import android.webkit.WebView; import android.webkit.WebViewClient; public class HtmlSource extends Activity { private WebView webView; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setContentView(R.layout.main); webView = (WebView)findViewById(R.id.webview); webView.getSettings().setJavaScriptEnabled( true ); webView.addJavascriptInterface( new InJavaScriptLocalObj(), "local_obj" ); webView.setWebViewClient( new MyWebViewClient()); webView.loadUrl( "http://www.cnblogs.com/hibraincol/" ); } final class MyWebViewClient extends WebViewClient{ public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true ; } public void onPageStarted(WebView view, String url, Bitmap favicon) { Log.d( "WebView" , "onPageStarted" ); super .onPageStarted(view, url, favicon); } public void onPageFinished(WebView view, String url) { Log.d( "WebView" , "onPageFinished " ); view.loadUrl( "javascript:window.local_obj.showSource('<head>'+" + "document.getElementsByTagName('html')[0].innerHTML+'</head>');" ); super .onPageFinished(view, url); } } final class InJavaScriptLocalObj { public void showSource(String html) { Log.d( "HTML" , html); } } }

关键之处在于:

view.loadUrl("javascript:window.local_obj.showSource('<head>'+document.getElementsByTagName('html')[0].innerHTML+'</head>');");

运行,可以看到在showSource(String html)中打印了网页源码。

更多相关文章

  1. android 客户端支付宝 php服务器端编写
  2. Android(安卓)TypedArray源码详解
  3. android微信纯图片分享和网页分享
  4. android源码编译的小小总结
  5. Android(安卓)AsyncTask源码解析
  6. Auto.js逆向分析-提取脚本文件(附源码)
  7. android eventbus
  8. [Android源码]Android源码之高仿飞鸽传书WIFI热点搜索与创建(一)
  9. Android(安卓)Volley库源码简析(Image Request部分)

随机推荐

  1. Android中EditText的inputType属性值
  2. Android中的布局属性
  3. Android一日游
  4. Android与JavaScript相互调用(Android和h
  5. android兼容huawei手机刘海屏解决方案
  6. 相对布局中一些常用属性
  7. Android中如何设置RadioButton在文字的右
  8. Android(安卓)相对布局 RelativeLayout
  9. Android(安卓)studio开发的常用知识(不定
  10. 如何安装apk文件在Android仿真器中