JavaScript調(diào)用Android接口常見的3種方式
前言
在 Android 開發(fā)中,JavaScript(JS)調(diào)用原生 Android 接口主要通過 WebView 組件實(shí)現(xiàn)。以下是常見的 3 種核心方式及具體實(shí)現(xiàn)邏輯:
1. addJavascriptInterface 注入接口??
??原理??:通過 WebView 向 JS 暴露一個(gè) Java 對象,JS 可直接調(diào)用該對象中被 @JavascriptInterface 注解標(biāo)記的方法
??步驟??:
- ??定義接口類??:
public class WebAppInterface { Context mContext; WebAppInterface(Context c) { mContext = c; } @JavascriptInterface public void showToast(String msg) { Toast.makeText(mContext, msg, Toast.LENGTH_SHORT).show(); } } - ??注入接口到 WebView??:
webView.getSettings().setJavaScriptEnabled(true); webView.addJavascriptInterface(new WebAppInterface(this), "AndroidBridge");
- ??JS 調(diào)用??:
window.AndroidBridge.showToast("Hello from JS!");
??注意事項(xiàng)??:
- ??安全風(fēng)險(xiǎn)??:若未使用
@JavascriptInterface注解,可能導(dǎo)致任意方法被調(diào)用(如系統(tǒng)敏感 API) - ??API 版本??:需最低支持 API 17(Android 4.2)
??2. 攔截 WebChromeClient 對話框??
??原理??:通過重寫 WebChromeClient 的對話框回調(diào)方法(如 onJsPrompt),解析 JS 發(fā)送的指令
??步驟??:
- ??自定義 WebChromeClient??:
webView.setWebChromeClient(new WebChromeClient() { @Override public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, JsPromptResult result) { if (message.startsWith("native:")) { // 協(xié)議約定 handleNativeCall(message); // 解析并執(zhí)行原生邏輯 result.confirm("success"); // 返回結(jié)果給 JS return true; } return super.onJsPrompt(view, url, message, defaultValue, result); } }); - ??JS 調(diào)用??:
prompt("native:showToast", "{'msg':'Hello'}"); // 通過 prompt 發(fā)送指令
??適用場景??:
- 需要雙向通信(JS 可獲取原生返回值);
- 兼容低版本 Android(無需依賴
@JavascriptInterface)
??3. 攔截 URL Scheme??
??原理??:JS 觸發(fā)特定格式的 URL 請求(如 myapp://action?params),Android 通過 shouldOverrideUrlLoading 攔截并處理
??步驟??:
- ??自定義 WebViewClient??:
webView.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { if (url.startsWith("myapp://")) { // 協(xié)議約定 parseUrl(url); // 解析 URL 并執(zhí)行對應(yīng)邏輯 return true; // 阻止默認(rèn)加載 } return super.shouldOverrideUrlLoading(view, url); } }); - ??JS 調(diào)用??:
window.location.href = "myapp://showToast?msg=Hello"; // 或通過 iframe 觸發(fā)
??優(yōu)缺點(diǎn)??:
- ??優(yōu)點(diǎn)??:兼容性最好(支持所有 Android 版本);
- ??缺點(diǎn)??:僅支持單向調(diào)用(JS 無法直接獲取原生返回值)
??安全建議??
- ??輸入校驗(yàn)??:對 JS 傳遞的參數(shù)進(jìn)行嚴(yán)格校驗(yàn),防止注入攻擊
- ??最小權(quán)限原則??:僅暴露必要的接口方法,避免敏感操作(如文件讀寫)
- ??HTTPS 加密??:加載遠(yuǎn)程頁面時(shí)使用 HTTPS,避免中間人攻擊
總結(jié)
到此這篇關(guān)于JavaScript調(diào)用Android接口常見的3種方式的文章就介紹到這了,更多相關(guān)JS調(diào)用Android接口內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android實(shí)現(xiàn)跳動的小球加載動畫效果
Android中有各式各樣的加載動畫,大家多多少少都見過,比如用過美團(tuán)客戶端的用戶對美團(tuán)那個(gè)加載小人的動畫印象很深刻,一個(gè)可愛的小人在那拼命的跑。這樣的動畫實(shí)現(xiàn)其實(shí)還有很多,今天這里就來實(shí)現(xiàn)一個(gè)跳動的小球效果。有需要的可以參考借鑒。2016-08-08
Android編程之防止反編譯的實(shí)現(xiàn)方法
這篇文章主要介紹了Android編程之防止反編譯的實(shí)現(xiàn)方法,涉及Android針對運(yùn)行環(huán)境、簽名及程序相關(guān)信息的獲取與判定技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11
Android實(shí)現(xiàn)沉浸式狀態(tài)欄功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)沉浸式狀態(tài)欄功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10
Android xml實(shí)現(xiàn)animation的4種動畫效果實(shí)例代碼
在Android應(yīng)用程序,使用動畫效果,能帶給用戶更好的感覺,做動畫可以通過XML或Android代碼來實(shí)現(xiàn)。本文給大家介紹Android xml實(shí)現(xiàn)animation的4種動畫效果實(shí)例代碼,一起看看吧2016-05-05
Android仿京東淘寶自動無限循環(huán)輪播控件思路詳解
在App的開發(fā)中,很多的時(shí)候都需要實(shí)現(xiàn)類似京東淘寶一樣的自動無限輪播的廣告欄,這里小編寫了一個(gè),分享到腳本之家平臺供大家參考2017-04-04
淺談Android開發(fā)Webview的Loading使用效果
這篇文章主要為大家介紹了淺談Android開發(fā)Webview的Loading使用效果詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
Android后臺定時(shí)提醒功能實(shí)現(xiàn)
這篇文章主要介紹了Android后臺定時(shí)提醒功能,針對Service,AlarmManager的使用進(jìn)行詳細(xì)闡述,感興趣的小伙伴們可以參考一下2016-01-01

