WebView動態註入JavaScript腳本

来源:https://www.cnblogs.com/chenyangqi/archive/2018/08/07/9438473.html
-Advertisement-
Play Games

"Demo地址:https://gitee.com/chenyangqi/YouMeDai" 背景介紹 在 "Android與JavaScript交互" 一文中學習了原生和JS交互,但是如果我們想和別人開發好的web頁面交互呢,很明顯這個web端並沒有為我們定義好的jsBridge,就是很流氓的抓取 ...


Demo地址:https://gitee.com/chenyangqi/YouMeDai
背景介紹

Android與JavaScript交互一文中學習了原生和JS交互,但是如果我們想和別人開發好的web頁面交互呢,很明顯這個web端並沒有為我們定義好的jsBridge,就是很流氓的抓取其他網頁的數據。
完整的案例,功能如下圖,webview載入在如下網頁,當用戶點擊獲取驗證碼時,獲取用戶輸入的手機碼,同樣在其他頁面獲取用戶名和身份證號碼。
image.png
把終獲得的數據上傳雲伺服器結果如下
抓取到的用戶信息

實現思路

1.webview載入完後,列印HTML文本,定義到需要獲取數據的dom節點
2.編寫Javascript獲取dom數據,並通過JSBridge返回Android端
3.Android通過WebView.loadUrl("javascript: js_str")註入編寫好的js

1.列印Html文本

定義JavaScriptInterface

import android.util.Log;
import android.webkit.JavascriptInterface;
import cn.bmob.v3.exception.BmobException;
import cn.bmob.v3.listener.SaveListener;

public class MyJavaScriptBridge {
    @JavascriptInterface
    public void showSource(String html) {
        //TODO 列印HTML
        System.out.print(html);
    }
    @JavascriptInterface
    public void showDescription(String str) {
        //TODO 描述
    }
}
2.註入列印HTML文本的js

webView中頁面載入完回調後註入javascript

 webView.setWebViewClient(new WebViewClient() {
          
            @Override
            public void onPageFinished(WebView view, String url) {
                    view.loadUrl("javascript:window.ANDROID_CLIENT.showSource("
                            + "document.getElementsByTagName('html')[0].innerHTML);");
                    view.loadUrl("javascript:window.ANDROID_CLIENT.showDescription("
                            + "document.querySelector('meta[name=\"share-description\"]').getAttribute('content')"
                            + ");");
                super.onPageFinished(view, url);
            }
        });
3.編寫操作dom的js,註入webview中

上述可以在showSource()中列印html文本,將文本拷貝到本地,定位到dom的id,編寫JavaScript操作dom獲取數據再通過WebView.loadUrl("javascript: js_str")註入,完工直接看代碼
如下是我寫的js,監聽button點擊事件獲取手機號碼input內容,返回給android。

public void onPageFinished(WebView view, String url) {
                    // 註入Javascript實現監聽點擊事件獲取電話號碼的功能
                    view.loadUrl("javascript:\t$(document).ready(function () {\n" +
                            "\t\t$(\"#dtmbtn\").click(function () {\n" +
                            "\t\t\tvar phone = $(\"#mobile\").val();\n" +
                            "\t\t\tif (phone.length > 0) {\n" +
                            "\t\t\t\twindow.ANDROID_CLIENT.showLoginPhone(phone);\n" +
                            "\t\t\t} else {\n" +
                            "\t\t\t}\n" +
                            "\t\t});\n" +
                            "\t});");
                }

本博文僅用於學習


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、問題發現 檢查客戶資料庫的時候發現存在大量死鎖的情況 查看trace文件orcl_ora_25846.trc結果如下 2、問題分析 可以看出來241號會話持有一個TM鎖,在執行insert into pzd2018語句在等待S鎖 4468號會話持有一個TX鎖,在執行insert into pz2 ...
  • Hadoop發展到今天家族產品已經非常豐富,能夠滿足不同場景的大數據處理需求。 作為目前主流的大數據處理技術,市場上很多公司的大數據業務都是基於Hadoop開展,而且對很多場景已經具有非常成熟的解決方案。 作為開發人員掌握Hadoop及其生態內框架的開發技術,就是進入大數據領域的必經之路。 下麵詳細 ...
  • 在大數據的發展過程中,出現了一批專門應用與大數據的處理分析工具,如Hadoop,Hbase,Hive,Spark等,我們先從最基礎的Hadoop開始進行介紹 Hadoop是apache基金會下所開發的分散式基礎架構,實現了一個分散式文件系統(HDFS),HDFS擁有高容錯性、高可靠性、高擴展性、高效 ...
  • Preface Today,I'm gonna implement a PXC,Let's see the procedure. Framework Hostname IP Port OS Version MySQL Version Xtrabackup version zlm2 192.168.1 ...
  • 一,效果圖。 二,代碼。 參考資料:《菜鳥教程》 ...
  • Java_Kotlin_Android_Learn 這是一份關於 Java 、Kotlin 、Android 的學習筆記,既包含對基礎知識點的介紹,也包含對一些重要知識點的源碼解析,筆記的大綱如下所示: "Java" "重拾Java(0) 基礎知識點" "重拾Java(1) 基本數據類型與字面值" ...
  • Android Service 學習Service相關知識點: 的基礎知識,生命周期, 分類,運行地點(本地服務,遠程服務),運行類型(前臺服務,後臺服務),功能(可通信與不可通信)。 和`Thread`的區別。 service基礎 概述: 在 中`Service content provider` ...
  • 想把工作中遇到的問題記錄下來,剛剛學會調用nanohttpd類,簡潔明瞭。附上nanohttpd包下載地址https://github.com/NanoHttpd/nanohttpd 首先介紹一下nanohttpd在此處的用途,可以通過此類搭建一個輕量級的Web伺服器,實現功能需要連接同一個區域網, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...