當(dāng)前位置:首頁 > 安卓下載 > 系統(tǒng)工具 > WebView安卓版

點此糾錯

8
0% 0%

情介紹

WebView安卓版是Android操作系統(tǒng)中的一個組件,它允許Android應(yīng)用程序在應(yīng)用程序的用戶界面內(nèi)顯示網(wǎng)頁內(nèi)容。它充當(dāng)了一個Web瀏覽器引擎,負(fù)責(zé)渲染網(wǎng)頁、執(zhí)行JavaScript代碼和處理其他與Web相關(guān)的功能。在Android 7.0(Nougat)之前,WebView作為一個單獨的應(yīng)用程序捆綁在一起,并通過Google Play商店進(jìn)行更新。從Android 7.0開始,WebView成為一個系統(tǒng)組件,通過常規(guī)系統(tǒng)更新進(jìn)行更新。

許多Android應(yīng)用程序,特別是那些包含網(wǎng)頁內(nèi)容或基于Web的功能的應(yīng)用程序,依賴于WebView來顯示網(wǎng)頁或與Web服務(wù)進(jìn)行交互。通過利用WebView,開發(fā)人員可以無縫地在其應(yīng)用程序中嵌入網(wǎng)頁內(nèi)容,從而創(chuàng)建更加集成的用戶體驗。通過WebView顯示的Web內(nèi)容通常基于設(shè)備上默認(rèn)的Web瀏覽器使用的相同渲染引擎,例如Google Chrome或Android瀏覽器(在Chrome成為默認(rèn)瀏覽器之前使用的瀏覽器)。這樣可以確保開發(fā)人員在不同的應(yīng)用程序中提供一致的Web體驗,并確保與Web標(biāo)準(zhǔn)和技術(shù)的兼容性。

webview是什么

webview是一個可視化的組件,是作為原生APP的視覺部分??梢詢?nèi)嵌在移動端,實現(xiàn)前端的混合式開發(fā),大多數(shù)混合式開發(fā)框架都是基于WebView模式進(jìn)行二次開發(fā)的。比如:APIcloud、uni-app等等的框架。

一、webview入門知識

1、我們通常是用瀏覽器來瀏覽網(wǎng)頁,你很清楚的知道你正在使用瀏覽器,要么是PC客戶端,要么是手機(jī)上的app。但是webview是一個嵌入式的瀏覽器,是嵌入在原生應(yīng)用中的,你可能都意識不到你在用瀏覽器。

2、傳統(tǒng)瀏覽器分為兩個部分,UI(地址欄、導(dǎo)航欄)和瀏覽器引擎。webview就是原生應(yīng)用中的瀏覽器引擎。

3、webview只是一個可視化的組件,是作為原生APP的視覺部分。

4、用webview展示的內(nèi)容是不需要存儲在本地的,可以直接從服務(wù)器獲取。

5、這種靈活性打開了瀏覽器端的web應(yīng)用和希望展示在原生應(yīng)用中的web應(yīng)用代碼直接可重用的世界。

6、運行在webview中的JS代碼有能力調(diào)用原生的系統(tǒng)API,沒有傳統(tǒng)瀏覽器沙箱的限制。

7、沙箱的存在是因為,你永遠(yuǎn)不能完全信任加載的web內(nèi)容,所以不能允許它調(diào)用原生的系統(tǒng)API。而在webview中開發(fā)人員通??梢酝耆刂萍虞d的內(nèi)容,惡意代碼進(jìn)入并在設(shè)備上造成混亂的可能性很低。

8、在webview中,JS代碼可以跟原生應(yīng)用代碼相互通信,也可以調(diào)用原生API集成酷炫的系統(tǒng)級功能,如傳感器、存儲、日歷、聯(lián)系人等。

二、webview的用法

1、作為APP內(nèi)置瀏覽器,顯示鏈接的內(nèi)容。

2、用來顯示廣告。

3、完全承載APP內(nèi)的所有交互。從技術(shù)角度看這些仍是原生應(yīng)用,但它做的唯一原生操作就是托管webview,這種應(yīng)用被稱為混合應(yīng)用。從部署和更新的角度來看,混合應(yīng)用非常方便。

4、作為原生應(yīng)用的擴(kuò)展。許多原生應(yīng)用會提供加載項或擴(kuò)展程序來擴(kuò)展其功能,由于web技術(shù)的簡單性和強(qiáng)大,這些加載項和擴(kuò)展通常以HTML、CSS、JS而不是C++、C#或其他來構(gòu)建。

三、webview的精髓

webview其實只是一個再應(yīng)用中設(shè)置好位置和大小的瀏覽器,而且不會放置任何花哨的UI。

在大多數(shù)情況下,除非你調(diào)用了原生API,否則不必在webview中專門測試web應(yīng)用。

WebView的幾個常見功能使用方法

android的WebView組件可以說是相當(dāng)?shù)膹?qiáng)大,現(xiàn)將項目中經(jīng)常用到的幾個功能總結(jié)如下:

一、背景設(shè)置

WebView.setBackgroundColor(0);//先設(shè)置背景色為transparent

WebView.setBackgroundResource(R.drawable.yourImage);//然后設(shè)置背景圖片

二、獲得WebView網(wǎng)頁加載初始化和完成事件

步驟:

1、創(chuàng)建一個自己的WebViewClient(繼承 WebViewClient 類)如WebViewClient

2、重載里面的 onPageFinished(WebView view, String url)方法,(webview加載完成會調(diào)用這個方法),這個方法放自己想要做的事情,在webview加載完成以后

3、關(guān)聯(lián)你自己的webviewclient 與 webview 通過 這個方法:webView.setWebViewClient( new WebViewClient();

如果需要監(jiān)視加載進(jìn)度的,需要創(chuàng)建一個自己的WebChromeClient類,并重載方法onProgressChanged,再

布局文件:

要注意的是,其中的webView的一系列用法,比如 webView.getSettings()。setJavaScriptEnabled(true);設(shè)置可以使用javscript;

等等,具體參考API

而進(jìn)度條的使用是在new出一個setWebChromeClient后,可以在內(nèi)部類中寫onProgressChanged事件

總結(jié):在WebView的設(shè)計中,不是什么事都要WebView類干的,有些雜事是分給其他人的,這樣WebView專心干好自己的解析、渲染工作就行了。
WebViewClient就是幫助WebView處理各種通知、請求事件的,具體來說包括:

onLoadResource

onPageStart

onPageFinish

onReceiveError

onReceivedHttpAuthRequest

WebChromeClient是輔助WebView處理Javascript的對話框,網(wǎng)站圖標(biāo),網(wǎng)站title,加載進(jìn)度等

onCloseWindow(關(guān)閉WebView)

onCreateWindow()

onJsAlert (WebView上alert是彈不出來東西的,需要定制你的WebChromeClient處理彈出)

onJsPrompt

onJsConfirm

onProgressChanged

onReceivedIcon

onReceivedTitle

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持3322。

Android WebView的具體實現(xiàn)與Chromium渲染引擎啟動過程

這里以Android 8.0的源碼為來說明,是先找到WebView的真正的構(gòu)造函數(shù):

這個構(gòu)造函數(shù)會調(diào)用另外一個成員函數(shù)ensureProviderCreated()確保Chromium動態(tài)庫已經(jīng)加載。在Chromium動態(tài)庫已經(jīng)加載的情況下,WebView類的成員函數(shù)ensureProviderCreated還會創(chuàng)建一個WebViewProvider對象,并且保存在成員變量mProvider中。這個WebViewProvider其實才是真正用來實現(xiàn)WebView的功能的幕后大佬。上訴那些Android WebView主要的方式基本都是通過mProvider來實現(xiàn)的,例如loadUrl(String url)等方法。

有了這個mProvider之后,WebView類的構(gòu)造函數(shù)就會繼續(xù)調(diào)用mProvider.init(javaScriptInterfaces, privatepowsing)啟動網(wǎng)頁渲染引擎。對于基于Chromium實現(xiàn)的WebView來說,它使用的WebViewProvider是一個WebViewChromium對象。當(dāng)這個WebViewChromium對象的成員函數(shù)init被調(diào)用的時候,它就會啟動Chromium的網(wǎng)頁渲染引擎。

所以,我們接下來看一下ensureProviderCreated的實現(xiàn):

WebView類的成員函數(shù)ensureProviderCreated首先調(diào)用成員函數(shù)checkThread確保它是在WebView的創(chuàng)建線程中調(diào)用的,接下來又會判斷成員變量mProvider的值是否為null。如果為null,就表示它還沒有當(dāng)前創(chuàng)建的WebView創(chuàng)建過Provider。在這種情況下,它首先會調(diào)用成員函數(shù)getFactory獲得一個WebViewFactory。有了這個WebViewFactory之后,就可以調(diào)用它的成員函數(shù)createWebView創(chuàng)建一個WebViewProvider。

接下來我們再看一下getFactory()方法以及它的實現(xiàn):

getFactory返回的WebView Factory是通過調(diào)用WebViewFactory類的靜態(tài)成員函數(shù)getProvider獲得的,getProvider首先是判斷靜態(tài)成員變量sProviderInstance的值是否等于null。如果等于null,那么就說明當(dāng)前的App進(jìn)程還沒有加載過Chromium動態(tài)庫。在這種情況下,就需要加載Chromium動態(tài)庫,并且創(chuàng)建一個WebView Factory,保存在靜態(tài)成員變量sProviderInstance。接下來我們就先分析Chromium動態(tài)庫的加載過程,然后再分析WebView Factory的創(chuàng)建過程。

加載Chromium動態(tài)庫是通過調(diào)用WebViewFactory類的靜態(tài)成員函數(shù)loadNativeLipary實現(xiàn)的:

loadNativeLipary首先會調(diào)用成員函數(shù)getWebViewNativeLiparyPaths獲得要加載的Chromium動態(tài)庫的文件路徑,然后再調(diào)用另外一個靜態(tài)成員函數(shù)nativeLoadWithRelroFile對它進(jìn)行加載。在加載的時候,會指定一個Chromium GNURELRO Section文件。這個Chromium GNURELRO Section文件是系統(tǒng)啟動時候,通過啟動一個臨時進(jìn)程生成的。其中靜態(tài)成員函數(shù)nativeLoadWithRelroFile是一個JNI方法,它由C++層的函數(shù)LoadWithRelroFile實現(xiàn):

LoadWithRelroFile判斷自己是32位還是64位的實現(xiàn),然后從參數(shù)lib32和lib64中選擇對應(yīng)的Chromium動態(tài)庫進(jìn)行加載。

這個加載過程是通過調(diào)用另外一個函數(shù)DoLoadWithRelroFile實現(xiàn)的:

函數(shù)DoLoadWithRelroFile的實現(xiàn)是通過Linker導(dǎo)出的函數(shù)androiddlopenext在Zyogote進(jìn)程保留的地址空間中加載Chromium動態(tài)庫的。注意,App進(jìn)程是Zygote進(jìn)程fork出來的,因此它同樣會獲得Zygote進(jìn)程預(yù)留的地址空間。不過,函數(shù)DoLoadWithRelroFile會將告訴函數(shù)androiddlopenext在加載Chromium動態(tài)庫的時候,將參數(shù)relro描述的Chromium GNURELRO Section文件內(nèi)存映射到內(nèi)存來,并且代替掉已經(jīng)加載的Chromium動態(tài)庫的GNURELRO Section。這是通過將指定一個ANDROIDDLEXTUSERELRO標(biāo)志實現(xiàn)的。之所以可以這樣做,是因為參數(shù)relro描述的Chromium GNURELRO Section文件對應(yīng)的Chromium動態(tài)庫的加載地址與當(dāng)前App進(jìn)程加載的Chromium動態(tài)庫的地址一致。只要兩個相同的動態(tài)庫在兩個不同的進(jìn)程中的加載地址一致,它們的鏈接和重定位信息就是完全一致的,因此就可以通過文件內(nèi)存映射的方式進(jìn)行共享。共享之后,就可以達(dá)到節(jié)省內(nèi)存的目的了。

這一步執(zhí)行完成之后,App進(jìn)程就加載完成Chromium動態(tài)庫了?;氐角懊娣治龅腤ebViewFactory類的靜態(tài)成員函數(shù)getProvider,它接下來繼續(xù)創(chuàng)建一個WebViewFactory。這個WebViewFactory以后就可以用來創(chuàng)建WebViewProvider。

WebViewFactory類的靜態(tài)成員函數(shù)getProvider首先要確定要創(chuàng)建的WebView Factory的類型。這個類型是通過調(diào)用另外一個靜態(tài)成員函數(shù)getFactoryClass獲得的:

從這里可以看到,WebViewFactory類的靜態(tài)成員函數(shù)getFactoryClass返回的WebView Factory的類型為com.android.webview.chromium.WebViewChromiumFactoryProviderForO。這個com.android.webview.chromium.WebViewChromiumFactoryProviderForO類是由前面提到的WebView Package提供的。這意味著WebViewFactory類的靜態(tài)成員函數(shù)getProvider創(chuàng)建的WebView Factory是一個WebViewChromiumFactoryProvider對象:

WebViewChromiumFactoryProvider類的構(gòu)造函數(shù)會調(diào)用AwpowserProcess類的靜態(tài)成員函數(shù)loadLipary對前面加載的Chromium動態(tài)庫進(jìn)行初始化:

AwpowserProcess類的靜態(tài)成員函數(shù)loadLipary又調(diào)用LiparyLoader類的靜態(tài)成員函數(shù)loadNow對前面加載的Chromium動態(tài)庫進(jìn)行初始化:

LiparyLoader類的靜態(tài)成員函數(shù)loadNow又調(diào)用另外一個重載版本的靜態(tài)成員函數(shù)loadNow對前面加載的Chromium動態(tài)庫進(jìn)行初始化:

LiparyLoader類重載版本的靜態(tài)成員函數(shù)loadNow又調(diào)用另外一個靜態(tài)成員函數(shù)loadAlreadyLocked對前面加載的Chromium動態(tài)庫進(jìn)行初始化:

由于并不是所有的系統(tǒng)都支持在加載動態(tài)庫時,以文件內(nèi)存映射的方式代替它的GNURELRO Section,因此Chromium自己提供了一個Linker。通過這個Linker加載動態(tài)庫時,能夠以文件內(nèi)存映射的方式代替要加載的動態(tài)庫的GNURELRO Section,也就是實現(xiàn)前面提到的函數(shù)androiddlopenext的功能。在高于Android 5.0中,由于系統(tǒng)已經(jīng)提供了函數(shù)androiddlopenext,因此,Chromium就不會使用自己的Linker加載動態(tài)庫,而是使用Android系統(tǒng)提供的Linker來加載動態(tài)庫。通過調(diào)用System類的靜態(tài)成員函數(shù)loadLipary即可以使用系統(tǒng)提供的Linker來加載動態(tài)庫。LiparyLoader類的靜態(tài)成員函數(shù)loadAlreadyLocked要加載的動態(tài)庫由NativeLiparies類的靜態(tài)成員變量LIpARIES指定:

從這里可以知道,LiparyLoader類的靜態(tài)成員函數(shù)loadAlreadyLocked要加載的動態(tài)庫就是Chromium動態(tài)庫。這個Chromium動態(tài)庫前面已經(jīng)加載過了,因此這里通過調(diào)用System類的靜態(tài)成員函數(shù)loadLipary再加載時,僅僅是只會觸發(fā)它導(dǎo)出的函數(shù)JNIOnLoad被調(diào)用,而不會重新被加載。Chromium動態(tài)庫導(dǎo)出的JNIOnLoad被調(diào)用的時候,Chromium動態(tài)庫就會執(zhí)行初始化工作:

其中的一個初始化操作是給Chromium的Content層設(shè)置一個類型為AwMainDelegate的Main Delegate。這個AwMainDelegate實現(xiàn)在Chromium的androidwebview模塊中。Android WebView是通過Chromium的androidwebview模塊加載和渲染網(wǎng)頁的。Chromium加載和渲染網(wǎng)頁的功能又是實現(xiàn)在Content層的,因此,Chromium的androidwebview模塊又要通過Content層實現(xiàn)加載和渲染網(wǎng)頁功能。這樣,Chromium的androidwebview模塊就可以設(shè)置一個Main Delegate給Content層,以便它們可以互相通信。給Chromium的Content層設(shè)置一個Main Delegate是通過調(diào)用函數(shù)SetContentMainDelegate實現(xiàn)的:

從前面的分析可以知道,參數(shù)delegate指向的是一個AwMainDelegate對象,這個AwMainDelegate對象會被函數(shù)SetContentMainDelegate保存在全局變量gcontentmain_delegate中。這一步執(zhí)行完成后,Chromium動態(tài)庫就在App進(jìn)程中加載完畢,并且也已經(jīng)完成了初始化工作。與此同時,系統(tǒng)也為App進(jìn)程創(chuàng)建了一個類型為WebViewChromiumFactoryProvider的WebViewFactory。回到前面分析的WebView類的成員函數(shù)ensureProviderCreated中,這時候就它會通過調(diào)用上述類型為WebViewChromiumFactoryProvider的WebViewFactory的成員函數(shù)createWebView為當(dāng)前創(chuàng)建的WebView創(chuàng)建一個WebView Provider:

WebViewChromiumFactoryProvider類的成員函數(shù)createWebView創(chuàng)建的是一個類型為WebViewChromium的WebView Provider。這個WebView Provider將會返回給WebView類的成員函數(shù)ensureProviderCreated。WebView類的成員函數(shù)ensureProviderCreated再將該WebView Provider保存在成員變量mProvider中。這樣,正在創(chuàng)建的WebView就獲得了一個類型為WebViewChromium的WebView Provider。以后通過這個WebView Provider,就可以通過Chromium來加載和渲染網(wǎng)頁了。

應(yīng)用截圖

您喜歡

安卓系統(tǒng)自帶app推薦
安卓系統(tǒng)自帶app推薦
每次不小心刪掉了安卓系統(tǒng)自帶app找不回來怎么辦呢?今天小編就為大家精心整理了一些安卓手機(jī)自帶軟件,不管你是華為手機(jī)還是小米手機(jī),亦或者榮耀、oppo、vivo等等,這里都有相關(guān)手機(jī)系統(tǒng)軟件,可以滿足大量用戶的需求,而手機(jī)里面就自帶了很多系統(tǒng)軟件,不一定都是你習(xí)慣、喜歡的軟件,想換的話也可以在這里看看手機(jī)系統(tǒng)軟件大全,感興趣的朋友可以下載試試哦!

網(wǎng)友評論

5人參與互動,3條評論
第3樓中國–廣東–深圳網(wǎng)友發(fā)表于: 2024-11-11 14:04:08
提示不是64位的
0蓋樓(回復(fù))
第2樓山東省臨沂市網(wǎng)友發(fā)表于: 2024-06-19 11:49:48
更新成功了,小米手機(jī)先關(guān)閉miui優(yōu)化再更新
0蓋樓(回復(fù))
第1樓河南省許昌市網(wǎng)友發(fā)表于: 2024-04-23 00:11:35
怎么提示解折失敗
0蓋樓(回復(fù))
管理員 回復(fù)發(fā)表于: 2024-04-23 17:57:03
小伙伴該軟件運行需要設(shè)備搭載谷歌框架哦!
1蓋樓(回復(fù))
(您的評論需要經(jīng)過審核才能顯示)

需要授予該應(yīng)用的權(quán)限

訪問網(wǎng)絡(luò)
訪問網(wǎng)絡(luò)連接,可能產(chǎn)生GPRS流量
-------------------------------------
獲取網(wǎng)絡(luò)狀態(tài)
獲取網(wǎng)絡(luò)信息狀態(tài),如當(dāng)前的網(wǎng)絡(luò)連接是否有效
-------------------------------------