在webview中addJavascriptInterface,js调用java函数打包出现不响应,即使对混淆处理

Android应用中,当在Webview中使用addJavascriptInterface定义的Java函数,在调试状态下正常,但打包后JS调用不响应。尝试混淆配置、修改proguard_project.txt文件,通过保留特定类的公共成员方法,最终解决了问题。
摘要由CSDN通过智能技术生成

在webview中写的java的函数,js调用时在android打包时不响应,本人初入安卓,使用webview时,调试没问题,打包后调试出现问题,不管哪个版本,都不响应,网上搜了很多办法,按照那样的方法都没成功,最后自己瞎尝试,终于解决。

webview.addJavascriptInterface(new JavascriptInterface(this), "diao");  

webview.getSettings().setJavaScriptEnabled(true);

加入混淆并区别后还是无法响应,解决方案(对调试没问题,打包出问题):

proguard_project.txt里有这句话

# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface

好的,以下是一个简单的示例代码,演示如何在 Android 的 WebView 使用 JavaScript 调用 Java 方法: 1. 首先,在 Java 定义一个类,包含一个供 JavaScript 调用的方法: ```java public class JavaScriptInterface { private Context context; public JavaScriptInterface(Context context) { this.context = context; } @JavascriptInterface public void showToast(String message) { Toast.makeText(context, message, Toast.LENGTH_SHORT).show(); } } ``` 在这个类,我们定义了一个名为 `showToast` 的方法,用于在 Android 应用显示一条 Toast 消息。 2. 接下来,在 Activity 创建一个 WebView 实例,并将 JavaScript 接口对象传递给它: ```java WebView webView = findViewById(R.id.webview); webView.getSettings().setJavaScriptEnabled(true); webView.addJavascriptInterface(new JavaScriptInterface(this), "Android"); ``` 在这个代码,我们首先启用 WebViewJavaScript 功能,然后创建了一个 `JavaScriptInterface` 对象,并将其注册到 WebView 。我们还将这个接口对象命名为 `Android`,以后在 JavaScript 使用这个名称来调用它。 3. 最后,在 HTML 编写 JavaScript 代码,调用 Android 接口的方法: ```html <button onclick="showToast('Hello, Android!')">Show Toast</button> <script> function showToast(message) { Android.showToast(message); } </script> ``` 在这个代码,我们定义了一个按钮,当用户点击它时,将调用 `showToast` 方法。在 JavaScript ,我们使用 `Android.showToast` 来调用 Android 接口的方法。 这就是一个简单的示例,演示了如何在 Android 的 WebView 使用 JavaScript 调用 Java 方法。需要注意的是,这个方法需要在 Android 4.2 及以上版本才能使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值