- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在开发 Phonegap 应用程序,发现 Phonegap 最近已更新到 2.2,其中包含许多 Android 修复程序。所以我立即通过替换 xml、jar 和 JS 文件进行了更新。我的应用程序曾经运行良好。它使用自定义 Javascript 界面来添加附加功能。不幸的是,当升级到 2.2 时,我收到以下错误日志:
这是我在运行 4.0.4 的 Samsung Galaxy S2 上运行应用程序时遇到的错误。这是我正在使用的主要应用程序 Java 文件。
希望大家帮我找出问题所在。我对可能导致 JNI 错误的原因一无所知。
编辑: 我在 android 2.2 模拟器上尝试了相同的代码,这给了我一个更具描述性的错误:
10-31 13:02:12.945: I/dalvikvm(543): Could not find method android.webkit.WebView.<init>, referenced from method org.apache.cordova.CordovaWebView.<init>
10-31 13:02:12.945: W/dalvikvm(543): VFY: unable to resolve direct method 3298: Landroid/webkit/WebView;.<init> (Landroid/content/Context;Landroid/util/AttributeSet;IZ)V
10-31 13:02:12.945: D/dalvikvm(543): VFY: replacing opcode 0x70 at 0x0001
10-31 13:02:12.945: D/dalvikvm(543): VFY: dead code 0x0004-005b in Lorg/apache/cordova/CordovaWebView;.<init> (Landroid/content/Context;Landroid/util/AttributeSet;IZ)V
10-31 13:02:13.195: I/CordovaLog(543): Changing log level to DEBUG(3)
10-31 13:02:13.205: I/CordovaLog(543): Found preference for useBrowserHistory=false
10-31 13:02:13.205: D/CordovaLog(543): Found preference for useBrowserHistory=false
10-31 13:02:13.205: I/CordovaLog(543): Found preference for exit-on-suspend=false
10-31 13:02:13.205: D/CordovaLog(543): Found preference for exit-on-suspend=false
10-31 13:02:13.215: W/CordovaWebView(543): useBrowserHistory=false is deprecated as of Cordova 2.2.0 and will be removed six months after the 2.2.0 release. Please use the browser history and use history.back().
10-31 13:02:13.245: D/JsMessageQueue(543): Set native->JS mode to 2
10-31 13:02:13.245: I/CordovaWebView(543): Disabled addJavascriptInterface() bridge since Android version is old.
10-31 13:02:13.255: D/CordovaWebView(543): Origin to allow: http://127.0.0.1*
10-31 13:02:13.255: D/CordovaWebView(543): Unlimited access to network resources
10-31 13:02:13.265: D/CordovaWebView(543): Origin to allow: http://api.enkhuizenapp.nl
10-31 13:02:13.265: D/CordovaWebView(543): Origin to allow: .*
10-31 13:02:13.265: I/CordovaLog(543): Found log level DEBUG
10-31 13:02:13.265: I/CordovaLog(543): Changing log level to DEBUG(3)
10-31 13:02:13.265: I/CordovaLog(543): Found preference for useBrowserHistory=false
10-31 13:02:13.265: D/CordovaLog(543): Found preference for useBrowserHistory=false
10-31 13:02:13.265: I/CordovaLog(543): Found preference for exit-on-suspend=false
10-31 13:02:13.265: D/CordovaLog(543): Found preference for exit-on-suspend=false
10-31 13:02:13.265: W/CordovaWebView(543): useBrowserHistory=false is deprecated as of Cordova 2.2.0 and will be removed six months after the 2.2.0 release. Please use the browser history and use history.back().
10-31 13:02:13.285: D/JsMessageQueue(543): Set native->JS mode to 2
10-31 13:02:13.285: I/CordovaWebView(543): Disabled addJavascriptInterface() bridge since Android version is old.
10-31 13:02:13.285: D/CordovaWebView(543): >>> loadUrl(file:///android_asset/www/menu.html)
10-31 13:02:13.285: D/PluginManager(543): init()
10-31 13:02:13.296: D/CordovaWebView(543): >>> loadUrlNow()
10-31 13:02:13.296: D/CordovaWebView(543): >>> loadUrl(file:///android_asset/www/main.html)
10-31 13:02:13.296: D/PluginManager(543): init()
10-31 13:02:13.315: D/CordovaWebView(543): >>> loadUrlNow()
10-31 13:02:13.955: D/dalvikvm(543): GC_FOR_MALLOC freed 1775 objects / 133528 bytes in 76ms
10-31 13:02:14.765: D/Cordova(543): onPageFinished(file:///android_asset/www/menu.html)
10-31 13:02:15.365: D/Cordova(543): onPageFinished(file:///android_asset/www/main.html)
10-31 13:02:15.685: I/Database(543): sqlite returned: error code = 14, msg = cannot open file at source line 25467
10-31 13:02:15.945: D/CordovaLog(543): Falling back on PROMPT mode since _cordovaNative is missing.
10-31 13:02:15.955: D/CordovaLog(543): file:///android_asset/www/scripts/cordova-2.2.0.js: Line 1032 : Falling back on PROMPT mode since _cordovaNative is missing.
10-31 13:02:15.955: I/Web Console(543): Falling back on PROMPT mode since _cordovaNative is missing. at file:///android_asset/www/scripts/cordova-2.2.0.js:1032
10-31 13:02:16.065: D/AndroidRuntime(543): Shutting down VM
10-31 13:02:16.065: W/dalvikvm(543): threadid=1: thread exiting with uncaught exception (group=0x4001d800)
10-31 13:02:16.075: E/AndroidRuntime(543): FATAL EXCEPTION: main
10-31 13:02:16.075: E/AndroidRuntime(543): java.lang.NullPointerException
10-31 13:02:16.075: E/AndroidRuntime(543): at org.apache.cordova.api.Plugin.execute(Plugin.java:74)
10-31 13:02:16.075: E/AndroidRuntime(543): at org.apache.cordova.api.CordovaPlugin.execute(CordovaPlugin.java:61)
10-31 13:02:16.075: E/AndroidRuntime(543): at org.apache.cordova.api.PluginManager.exec(PluginManager.java:224)
10-31 13:02:16.075: E/AndroidRuntime(543): at org.apache.cordova.ExposedJsApi.exec(ExposedJsApi.java:43)
10-31 13:02:16.075: E/AndroidRuntime(543): at org.apache.cordova.CordovaChromeClient.onJsPrompt(CordovaChromeClient.java:213)
10-31 13:02:16.075: E/AndroidRuntime(543): at android.webkit.CallbackProxy.handleMessage(CallbackProxy.java:566)
10-31 13:02:16.075: E/AndroidRuntime(543): at android.os.Handler.dispatchMessage(Handler.java:99)
10-31 13:02:16.075: E/AndroidRuntime(543): at android.os.Looper.loop(Looper.java:123)
10-31 13:02:16.075: E/AndroidRuntime(543): at android.app.ActivityThread.main(ActivityThread.java:4627)
10-31 13:02:16.075: E/AndroidRuntime(543): at java.lang.reflect.Method.invokeNative(Native Method)
10-31 13:02:16.075: E/AndroidRuntime(543): at java.lang.reflect.Method.invoke(Method.java:521)
10-31 13:02:16.075: E/AndroidRuntime(543): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
10-31 13:02:16.075: E/AndroidRuntime(543): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
10-31 13:02:16.075: E/AndroidRuntime(543): at dalvik.system.NativeStart.main(Native Method)
提前致谢!
最佳答案
目前有一个针对此问题的解决方法,那就是您向 CordovaActivity 添加一个线程池:
private final ExecutorService threadPool = Executors.newCachedThreadPool();
当然,还要实现新添加的 getThreadPool() 方法。这是偶然添加的,希望能以某种方式封装在下一个版本中。
public ExecutorService getThreadPool()
{
return threadPool;
}
关于java - Android Phonegap 2.1 > 2.2 升级错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13194537/
我几乎不敢在这里问这个问题,因为它似乎应该很容易通过谷歌或 ravendb.net 获得。但是,我一直很难找到将我的 RavenDB 升级到新版本的正确方法。我目前正在运行 573 版并希望升级到 6
这周我需要升级当前版本的 DNN。我目前使用的是 2.1.1。我不想每件事都做两次,所以,我有几个问题。 是否有升级工具或某些脚本可以帮助我进行升级。 我最好安装 4.9 还是 5.0。这是生产。 如
将 Sugarcrm 从 6.2 升级到 6.3 版本时遇到问题。当我升级本地 Sugarcrm 安装时,它可以工作,但是当我开始升级我的 Sugarcrm 6.2 站点并上传升级包时,它不会上传。
有没有办法绕过 Meteor 的自动更新功能?我坚持 Downloading meteor-tool@1.3.0_3... \ 当我尝试运行现有项目,或创建一个新项目或只是运行“
我已将应用内集成到我的 Andorid 应用程序中,用于单个产品 productone。 为此,我在我的 Google Play 控制台中创建了不同的产品 ID,如下所示: 1。 productone
我在将 TeamCity 版本 2017.1.1 升级到 2017.1.2 时遇到问题。这个问题涉及 TeamCity 和 PostgreSQL 的工作。我的工作: 停止 teamcity 进程 /e
我寻找了这个问题的具体答案,但找不到——即使是在 WAMPSERVER 网站上也是如此。我确定我忽略了它。 我有 Wampserver 2.0、MySQL 5.0.51b、PHP 5.2.6 和 Ap
我使用 Ubuntu 软件中心默认的 Eclipse 3.7。 我想将 Eclipse 升级到 kepler 版本,所以我添加了 repository 我收到以下错误消息: Cannot comple
你好 我只想安装 mercurial,但对于它需要 python 2.6 的所有版本,我尝试使用 .rpm 文件,但我唯一得到的是很多充满错误的行,它告诉我:需要安装在 2.6 之前和 2.5 之后的
我完全知道 Gradle 网站上有一些页面说明了如何升级,但仅限于 4.x 及更高版本。 我正在尝试关注 tutorial制作一个简单的“我的第一个”Minecraft 模组。在其中,您被告知安装 f
我们想升级 Kerberos(服务器和客户端) 当前:1.6.3-133.27.1 目标:1.6.3-133.49.97.1 问题是如果我们用包管理器升级它,下面会发生什么? KDC 数据库 所有主要
背景 原计划 2019 年发布的 Vue3,又经过一年的再次打磨,终于于去年 9 月正式发布。随后,不少 UI 组件库都积极参与适配,去年 12 月,Element-plus(
我有一个版本为 2.3.4 的 grails 项目,我需要尽可能升级到最新版本。查看文档我意识到从 2.x 到 3.x 有巨大的变化。 问题是:从 2 到 3、从 3 到 4、从 4 到 5 逐步升级
我正在将 API 项目从 .net5 升级到 .net6 它以前工作,现在它崩溃 内部异常消息“抛出了‘Unity.Exceptions.InvalidRegistrationException’类型
我将我的项目从 expo 44 升级到 expo 45,现在我有无数这样的错误: The module 'MaterialIcons' can't be used as JSX component.
我已经升级了掌 Helm 模板(手动) 以前的片段depoloyment.yaml : apiVersion: apps/v1beta2 kind: Deployment metadata: na
我正在尝试将我的 Scala Play Framework 应用程序升级到 2.8,这涉及将 SBT 升级到 1.x。 在我的 build.propeties 我有 sbt.version=1.3.5
我想在我的 Windows 服务器上安装 PHPUnit 3.7。我遵循了各种说明 here并以 PHPUnit 3.4.1 结束。当我尝试使用以下方法再次安装它时: pear update chan
Microsoft.Net 4.5 即将推出,我想在 MS 发布最终版本时升级我的 clickonce 应用程序。 我的问题是:已经安装了 clickonce 应用程序(使用 .net 4.0)的用户
为了将 Angular 8 更新到 9,我正在按照官方文档升级。 这建议首先更新到最新版本的 angular 8,例如: ng update @angular/core@8 @angular/cli@
我是一名优秀的程序员,十分优秀!