h5和app原生通信的方法,什么是jsBridge,jsBridge 原理和步骤

H5 和 App 原生应用之间通信的方法

  1. url scheme
  2. jsBridge
    1. 也就是 javascript interface
    2. 原生应用通过注入 JavaScript 接口到 WebView 中,让 H5 页面可以调用原生方法,从而实现双向通信【本质还是利用了 android webview 提供了注入的方法】
  3. WebSocket
  4. Hybrid 框架的通信机制
  5. LocalStorage 或者 IndexedDB

什么是jsBridge

JSBridge 是一种机制,用于在 WebView 中的 JavaScript 和原生应用之间进行通信。它允许 JavaScript 代码调用原生应用的方法,并且允许原生应用调用 JavaScript 中的方法,实现了两者之间的双向通信。

jsBridge实现的详细步骤:

  1. 原生应用给webview注册接口:原生应用在加载 WebView 时,会提供一些接口供 JavaScript 调用。

    1. 调用 andorid webview 提供的原生方法,webview.addJavascriptInterface 给 webview注册一个接口,名字叫 NativeInterface【可以自定义这个名字,和前端对好就行】

    2. addJavascriptInterface 有两个参数

      1. Object obj:要添加的Java对象,它可以是Java代码中的任何对象(如活动,服务等)。

      2. String interfaceName:该Java对象在JavaScript代码中使用的名称【我们这里叫NativeInterface】【可以自定义这个名字,和前端对好就行】。

      3. NativeInterface 会被挂载到 js 的全局作用域,webview中前端可以使用 window.NativeInterface 访问

    3. // 注册 JSBridge 接口,命名为 NativeInterface
      // AndroidNativeInterface 这个也要自己定义
      // AndroidNativeInterface里面通常有一个 方法,供js调用
      webView.addJavascriptInterface(new AndroidNativeInterface(), "NativeInterface");class AndroidNativeInterface {// 接收来自 H5 页面的消息,并在原生应用中处理@JavascriptInterfacepublic void handleMessage(String message) {// 处理来自 H5 页面的消息// 这里可以执行一些原生操作,或者将数据传递给其他组件// 为了简单起见,我们只是打印接收到的消息System.out.println("Received message from H5: " + message);// 在这里可以执行一些原生操作,例如弹出一个 Toast// Toast.makeText(MainActivity.this, message, Toast.LENGTH_SHORT).show();// 接收到消息后,可以调用 H5 页面中定义的接口来传递数据给 H5 页面// webView.evaluateJavascript("JSBridge.receiveMessageFromNative('" + message + "')", null);}}
  2. Javascript 封装 jsBridge对象

    1. 通常是包括【给原生应用发送消息】和【接收原生应用发来的消息】

    2. var JSBridge = {// 调用原生应用的方法,参数为要传递给原生方法的数据callNativeMethod: function(data) {// 调用原生方法,并传递数据window.NativeInterface.handleMessage(data);},// 接收原生应用传递的数据,并处理receiveMessageFromNative: function(data) {// 处理接收到的数据onsole.log("Received data from native: " + data);}
      };
    3. 【原生应用】可以调用下面的 JSBridge.receiveMessageFromNative 给 webview 传递数据,具体语法如下

    4. webView.evaluateJavascript("JSBridge.receiveMessageFromNative('" + message + "')", null);
    5. webView.evaluateJavascript 也是 andorid webview 提供的原生方法,参数是我们 js 里面声明的 JSBridge 全局对象【JSBridge这个名字可以自定义,但是原生应用和 js 要统一】

  3. js 给【原生应用】发送消息

    1. 调用完这一句,就是调用原生应用的 handleMessage,handleMessage里面有响应方法
    2. //给原生应用发送消息, 传递对象数据 {name: 'test'}
      JSBridge.callNativeMethod({name: 'test'})
  4. 原生应用 给 js 发送消息

    1. 就是在 handleMessage 里面的这条语句, JSBridge.receiveMessageFromNative 给webview传递数据

    2. webView.evaluateJavascript("JSBridge.receiveMessageFromNative('" + message + "')", null);

完整代码如下,由chatgpt生成

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>JSBridge Demo</title><script>// 定义 JSBridge 对象,用于与原生应用通信var JSBridge = {// 调用原生应用的方法,参数为要传递给原生方法的数据callNativeMethod: function(data) {// 调用原生方法,并传递数据window.NativeInterface.handleMessage(data);},// 接收原生应用传递的数据,并处理receiveMessageFromNative: function(data) {// 处理接收到的数据console.log("Received data from native: " + data);}};</script>
</head>
<body><button onclick="JSBridge.callNativeMethod('Hello from H5!')">Call Native Method</button>
</body>
</html>
import android.os.Bundle;
import android.webkit.JavascriptInterface;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.webkit.WebViewClient;import androidx.appcompat.app.AppCompatActivity;public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);WebView webView = findViewById(R.id.webview);webView.setWebViewClient(new WebViewClient());webView.setWebChromeClient(new WebChromeClient());webView.getSettings().setJavaScriptEnabled(true);// 注册 JSBridge 接口,命名为 AndroidNativeInterfacewebView.addJavascriptInterface(new AndroidNativeInterface(), "NativeInterface");// 加载 H5 页面webView.loadUrl("file:///android_asset/index.html");}// 自定义的 Android 原生接口class AndroidNativeInterface {// 接收来自 H5 页面的消息,并在原生应用中处理@JavascriptInterfacepublic void handleMessage(String message) {// 处理来自 H5 页面的消息// 这里可以执行一些原生操作,或者将数据传递给其他组件// 为了简单起见,我们只是打印接收到的消息System.out.println("Received message from H5: " + message);// 在这里可以执行一些原生操作,例如弹出一个 Toast// Toast.makeText(MainActivity.this, message, Toast.LENGTH_SHORT).show();// 接收到消息后,可以调用 H5 页面中定义的接口来传递数据给 H5 页面// webView.evaluateJavascript("JSBridge.receiveMessageFromNative('" + message + "')", null);}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/708245.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Keepalived双机热备——Haproxy搭建web群集

一、认识keepalived keepalived是一个开源的软件&#xff0c;用于实现高可用性和负载均衡。它主要用于在多个服务器之间提供故障转移和负载均衡的功能。keepalived可以监控服务器的状态&#xff0c;并在主服务器发生故障时自动将备份服务器切换为主服务器&#xff0c;以确保服…

高压高能碳陶瓷无感电阻的制作以及应用?

由于现有需求&#xff0c;许多现代电子电路和设备都会经历瞬态脉冲和浪涌。这反过来又导致需要“设计”瞬态浪涌保护&#xff0c;尤其是在电机控制器等电路中。当电机启动时&#xff0c;此时消耗的电流过大&#xff0c;可能导致电阻器故障。同样&#xff0c;如果电容器用于电机…

揭示IP风险画像的作用与价值

在当今数字化时代&#xff0c;互联网的快速发展为企业和个人带来了巨大的机遇&#xff0c;同时也带来了各种安全风险和威胁。随着网络攻击手段的不断升级和演变&#xff0c;传统的安全防御手段已经无法满足对抗复杂多变的网络威胁的需求。IP风险画像作为一种新型的网络安全解决…

2024.2.28 网络

思维导图 整理面试题 1、什么是回调函数 答&#xff1a;将函数作为参数传到另一个函数里面&#xff0c;当那个函数执行完之后&#xff0c;再执行传进去的这个函数。这个过程就叫做回调。 2、结构体和共用体的区别 答&#xff1a;结构体的每个成员都会分配内存&#xff0c;…

加密与安全_深入了解哈希算法

文章目录 Pre概述哈希碰撞常用的哈希算法Codejava.security.MessageDigestMD5SHA-1SHA-256MessageDigest支持算法 哈希算法的用途彩虹表攻击基本原理攻击过程 防御彩虹表攻击基本原理用途 小结 Pre PKI - 01 散列(Hash)函数 概述 哈希算法&#xff08;Hash&#xff09;又称摘…

c# 异常处理

异常类 .NET Framework 类库中的所有异常都派生于 Exception 类&#xff0c;异常包括系统异常和应用异常。 默认所有系统异常派生于 System.SystemException&#xff0c;所有的应用程序异常派生于 System.ApplicationException。 系统异常一般不可预测&#xff0c;比如内存堆…

python中版本,操作系统等问题汇总

1. linux源码部署到windows 1.1ModuleNotFoundError: No module named pwd 这个问题&#xff0c;是因为源码是给linux的。这里在windows中&#xff0c;没有该命令。 解决方法之一&#xff0c;在相应的环境目录中&#xff0c;如图中<MetaGPTenv>虚拟环境中&#xff0c;在…

nginx(三)实现反向代理客户端 IP透传

正常情况下&#xff0c;客户端去访问代理服务器&#xff0c;然后代理服务器再取访问真实服务器&#xff0c;在真实服务器上&#xff0c;只能显示代理服务器的ip地址&#xff0c;而不显示客户端的ip地址&#xff0c;如果想让客户端的ip地址也能在真实服务端看见&#xff0c;这一…

Excel数据表定制分组排序

实例需求&#xff1a;某学校体育活动统计表如下图左侧表格所示&#xff0c;数据按照班级排列&#xff0c;现在需要根据如下规格对表格进行排序 “幼儿”班级排列在表格最后按照“次数”降序排列“幼儿”班级同样按“次数”降序排列 排序结果如下图中右侧表格所示。 示例代码…

基于springboot+vue的保险信息网站(源码+论文)

文章目录 文章目录 前言 一、功能设计 二、功能实现 2.1 前台功能设计 2.1.1 网站首页 2.1.2 保险产品列表 2.1.3 留言板界面 2.1.4 产品查询界面 2.2后台管理设计 2.2.1 系统用户登录管理 三、库表设计 四、论文 前言 随着互联网的不断发展&#xff0c;现在人们获…

mybatis基础操作(二)

事务管理 获取sqlSession时&#xff0c;默认开启事务&#xff0c;SqlSessionFactory类实例在调用openSession时不设置或者设置为false&#xff0c;此情况下&#xff0c;操作完成后&#xff0c;需要手动提交。 手动提交与回滚事务 public void insertStudent() {// 会话链接S…

Apache Bench(ab )压力测试

目录 参数说明示例1&#xff1a;压力测试示例2&#xff1a;测试post接口post数据文件该如何编写&#xff1f; apr_pollset_poll: The timeout specified has expired (70007)apr_socket_recv: Connection reset by peer (104)参考 参数说明 官方文档参考这里。 ab -c 100 -n …

元学习(Meta Learning)

在这篇文章中&#xff0c;我将介绍如何存储每个机器学习训练和测试过程的元数据&#xff0c;为元学习算法铺平道路。 一、元学习任务介绍 元学习是利用以前获得的和分类的学习过程的元数据来处理机器学习算法以前没有遇到过的新的学习任务。元学习的任务就是学会学习。 深度…

解决vscode内置视图npm脚本操作报权限问题

项目背景 当我们使用 vscode 运行NPM脚本时却爆红了&#xff0c;提示系统上禁止运行脚本。 解决思路 竟然提示权限不够&#xff0c;那么咱们就从系统权限出发&#xff0c;vscode右键以管理员身份运行 在集成终端中输入一下命令 # get-executionpolicy是PowerShell中的命令,用…

人工智能水印技术入门:工具与技巧

近几个月来&#xff0c;我们看到了多起关于“深度伪造 (deepfakes)”或人工智能生成内容的新闻报道&#xff1a;从 泰勒斯威夫特的图片、汤姆汉克斯的视频 到 美国总统乔拜登的录音。这些深度伪造内容被用于各种目的&#xff0c;如销售产品、未经授权操纵人物形象、钓鱼获取私人…

学不动系列-eslint

ESLint 介绍在最简单的项目使用eslint,包括eslint的vscode插件的使用&#xff0c;自动化格式代码&#xff0c;自动化修复代码&#xff0c;和webpack&#xff0c;vite的配合使用 单独使用 第一步&#xff1a;构建一个空项目 npm init -y 在根目录新建文件./src/app.js&#…

[spark] RDD 编程指南(翻译)

Overview 从高层次来看&#xff0c;每个 Spark 应用程序都包含一个driver program&#xff0c;该程序运行用户的main方法并在集群上执行各种并行操作。 Spark 提供的主要抽象是 resilient distributed dataset&#xff08;RDD)&#xff0c;它是跨集群节点分区的元素集合&…

SpringBoot之Session新增、删除、获取配置与使用

SpringBoot之Session新增、删除、获取配置与使用 文章目录 SpringBoot之Session新增、删除、获取配置与使用1. SpringBoot版本2. 定义增删查Session的类3. 定义Session的监听器4. 使用 自定义根据sessionId进行session的新增、删除、获取操作 1. SpringBoot版本 <parent>…

详解单例模式(Java语言实现)

1. 概念 保证类只有一个实例&#xff0c;让类自身负责保存它的唯一实例&#xff0c;并且类提供一个访问该实例的方法。 2. 单线程下的单例模式 public class Singleton {private static Singleton instance;private Singleton(){} //private构造方法&#xff0c;其他类无…

XGB-14:DMatrix的文本输入格式

简要描述XGBoost的文本输入格式。然而&#xff0c;对于具有支持的语言环境&#xff08;如Python或R&#xff09;的用户&#xff0c;建议使用该生态系统中的数据解析器。例如&#xff0c;可以使用sklearn.datasets.load_svmlight_file()。 基本输入格式 XGBoost目前支持两种文…