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

在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
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
#   public *;
#}

如果你在proguard.cfg中使用:

-keep public class <Package Name>.ActivityName$JavascriptInterface {

public *;

}

结果是不响应的。你需将proguard_project.txt修改为:

# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers  class <Package Name>.ActivityName$JavascriptInterface{
#   public *;
#}

(或去掉proguard_project.txt中的那段关于webview的代码(不推荐去掉)),这样就能成功了。


本文分享,错误之处请别怪,只是如实记录自己解决了问题的方法,可能不适用于你。在找问题期间浪费了不少时间,希望能帮到你。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的示例代码,演示如何在 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、付费专栏及课程。

余额充值