Cordova源码深入分析-第五讲

2024-05-15 20:38

本文主要是介绍Cordova源码深入分析-第五讲,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一讲将主体流程和框架都已经介绍完了,

再次查看整个代码的时候,发现我还是有一些细节并没有列举出来,

例如之前只是介绍了addJavaScript一种方式实现通信,实际上还有另一种通信方式就是prompt方式,本讲再次介绍一下。

prompt有几个优势:

1.可以避免掉android 4.2以下,js安全问题

2.可以实现同步调用,直接返回值


下面开始分析代码逻辑:

重复的位置,不再累述。直接来到cordova.js中

define("cordova/android/nativeapiprovider", function(require, exports, module) {var nativeApi = this._cordovaNative || require('cordova/android/promptbasednativeapi');//这里其实如果没有定义_cordovaNative就会走prompt
var currentApi = nativeApi;module.exports = {get: function() { return currentApi; },setPreferPrompt: function(value) {currentApi = value ? require('cordova/android/promptbasednativeapi') : nativeApi;},// Used only by tests.set: function(value) {currentApi = value;}
};});

而在使用prompt方式的时候,方法都是一样的。

define("cordova/android/promptbasednativeapi", function(require, exports, module) {module.exports = {exec: function(bridgeSecret, service, action, callbackId, argsJson) {return prompt(argsJson, 'gap:'+JSON.stringify([bridgeSecret, service, action, callbackId]));//直接进入java端,代码片段1},setNativeToJsBridgeMode: function(bridgeSecret, value) {prompt(value, 'gap_bridge_mode:' + bridgeSecret);},retrieveJsMessages: function(bridgeSecret, fromOnlineEvent) {return prompt(+fromOnlineEvent, 'gap_poll:' + bridgeSecret);}
};});

代码段1:SystemWebChromeClient.java

    @Overridepublic boolean onJsPrompt(WebView view, String origin, String message, String defaultValue, final JsPromptResult result) {// Unlike the @JavascriptInterface bridge, this method is always called on the UI thread.String handledRet = parentEngine.bridge.promptOnJsPrompt(origin, message, defaultValue);//代码片段2if (handledRet != null) {result.confirm(handledRet);} else {dialogsHelper.showPrompt(message, defaultValue, new CordovaDialogsHelper.Result() {@Overridepublic void gotResult(boolean success, String value) {if (success) {result.confirm(value);} else {result.cancel();}}});}return true;}

代码片段2:CordovaBridge.java

    public String promptOnJsPrompt(String origin, String message, String defaultValue) {if (defaultValue != null && defaultValue.length() > 3 && defaultValue.startsWith("gap:")) {JSONArray array;try {array = new JSONArray(defaultValue.substring(4));int bridgeSecret = array.getInt(0);String service = array.getString(1);String action = array.getString(2);String callbackId = array.getString(3);String r = jsExec(bridgeSecret, service, action, callbackId, message);//执行与之前介绍的逻辑一样的流程中了return r == null ? "" : r;} catch (JSONException e) {e.printStackTrace();} catch (IllegalAccessException e) {e.printStackTrace();}return "";}// Sets the native->JS bridge mode.else if (defaultValue != null && defaultValue.startsWith("gap_bridge_mode:")) {try {int bridgeSecret = Integer.parseInt(defaultValue.substring(16));jsSetNativeToJsBridgeMode(bridgeSecret, Integer.parseInt(message));} catch (NumberFormatException e){e.printStackTrace();} catch (IllegalAccessException e) {e.printStackTrace();}return "";}// Polling for JavaScript messageselse if (defaultValue != null && defaultValue.startsWith("gap_poll:")) {int bridgeSecret = Integer.parseInt(defaultValue.substring(9));try {String r = jsRetrieveJsMessages(bridgeSecret, "1".equals(message));return r == null ? "" : r;} catch (IllegalAccessException e) {e.printStackTrace();}return "";}else if (defaultValue != null && defaultValue.startsWith("gap_init:")) {// Protect against random iframes being able to talk through the bridge.// Trust only pages which the app would have been allowed to navigate to anyway.if (pluginManager.shouldAllowBridgeAccess(origin)) {// Enable the bridgeint bridgeMode = Integer.parseInt(defaultValue.substring(9));jsMessageQueue.setBridgeMode(bridgeMode);// Tell JS the bridge secret.int secret = generateBridgeSecret();return ""+secret;} else {LOG.e(LOG_TAG, "gap_init called from restricted origin: " + origin);}return "";}return null;}
到这里整个流程又衔接上了,就不在废话了





这篇关于Cordova源码深入分析-第五讲的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/992868

相关文章

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显

kubelet组件的启动流程源码分析

概述 摘要: 本文将总结kubelet的作用以及原理,在有一定基础认识的前提下,通过阅读kubelet源码,对kubelet组件的启动流程进行分析。 正文 kubelet的作用 这里对kubelet的作用做一个简单总结。 节点管理 节点的注册 节点状态更新 容器管理(pod生命周期管理) 监听apiserver的容器事件 容器的创建、删除(CRI) 容器的网络的创建与删除

red5-server源码

red5-server源码:https://github.com/Red5/red5-server

TL-Tomcat中长连接的底层源码原理实现

长连接:浏览器告诉tomcat不要将请求关掉。  如果不是长连接,tomcat响应后会告诉浏览器把这个连接关掉。    tomcat中有一个缓冲区  如果发送大批量数据后 又不处理  那么会堆积缓冲区 后面的请求会越来越慢。