Ham*_*han 6 android android-webview
最近我的应用程序得到了更新。更新包括在启动时加载 webview 的对话框。上线后,我的 firebase 控制台因未安装 webview 而加载崩溃。事故报告称
Caused by android.webkit.WebViewFactory$MissingWebViewPackageException: Failed to load WebView provider: No WebView installed
at android.webkit.WebViewFactory.getWebViewContextAndSetProvider(WebViewFactory.java:339)
at android.webkit.WebViewFactory.getProviderClass(WebViewFactory.java:402)
at android.webkit.WebViewFactory.getProvider(WebViewFactory.java:252)
at android.webkit.WebView.getFactory(WebView.java:2551)
at android.webkit.WebView.ensureProviderCreated(WebView.java:2545)
at android.webkit.WebView.setOverScrollMode(WebView.java:2613)
at android.view.View.<init>(View.java:5441)
at android.view.View.<init>(View.java:5632)
at android.view.ViewGroup.<init>(ViewGroup.java:677)
at android.widget.AbsoluteLayout.<init>(AbsoluteLayout.java:56)
at android.webkit.WebView.<init>(WebView.java:410)
at android.webkit.WebView.<init>(WebView.java:353)
at android.webkit.WebView.<init>(WebView.java:336)
at android.webkit.WebView.<init>(WebView.java:323)
at java.lang.reflect.Constructor.newInstance0(Constructor.java)
at java.lang.reflect.Constructor.newInstance(Constructor.java:343)
at android.view.LayoutInflater.createView(LayoutInflater.java:854)
at android.view.LayoutInflater.createView(LayoutInflater.java:776)
at com.android.internal.policy.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:58)
at android.view.LayoutInflater.onCreateView(LayoutInflater.java:930)
at android.view.LayoutInflater.onCreateView(LayoutInflater.java:950)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:1004)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:961)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:1123)
at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1084)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:1126)
at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:1084)
at android.view.LayoutInflater.inflate(LayoutInflater.java:682)
at android.view.LayoutInflater.inflate(LayoutInflater.java:534)
at android.view.LayoutInflater.inflate(LayoutInflater.java:481)
at android.support.v7.app.AppCompatDelegateImpl.setContentView(AppCompatDelegateImpl.java:469)
at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:140)
at com.myapp.ui.DialogActivity.onCreate(DialogActivity.kt:18)
at android.app.Activity.performCreate(Activity.java:7981)
at android.app.Activity.performCreate(Activity.java:7970)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1307)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3422)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3594)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2146)
at android.os.Handler.dispatchMessage(Handler.java:107)
at android.os.Looper.loop(Looper.java:237)
at android.app.ActivityThread.main(ActivityThread.java:7762)
at java.lang.reflect.Method.invoke(Method.java)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1047)
Run Code Online (Sandbox Code Playgroud)
这DialogActivity是在启动时加载的。应用程序以前可以通过 WebView 顺利运行,WebView 是从应用程序菜单内部启动的,并且以前从未崩溃过。现在,随着 WebView 在启动时的新更新,应用程序会崩溃并显示此日志。
我在谷歌上搜索了这个问题,并遇到了许多其他 stackoverflow 和谷歌问题跟踪器的答案,这些答案都说这种情况发生在WebView操作系统更新时膨胀/初始化时,对此无能为力,只有尝试捕获才能避免应用程序崩溃。
参考资料: android 无法加载 WebView 提供程序:未安装 WebView https://groups.google.com/forum/#!topic/google-admob-ads-sdk/k94v72E NameNotFoundException webview
所以我的问题是,在 Firebase 控制台的 5 天内,此崩溃已出现 33 次,这真的是由于操作系统更新了 WebView 造成的吗?为什么它的出现频率这么高?据报道,此次崩溃发生在 10 台 Android 10 和 1 台 Android 5.0.1 设备上,Android 10 设备均为三星手机,包括:Galaxy Note10 Lite、Galaxy S20 5G、Galaxy S20 ultra 5G、Galaxy S10。Android 5.0.1 设备是华为 P8 Lite。然而,华为设备的崩溃情况略有不同
Caused by android.content.pm.PackageManager$NameNotFoundException: com.google.android.webview
at android.app.ApplicationPackageManager.getPackageInfo(ApplicationPackageManager.java:120)
at android.webkit.WebViewFactory.getFactoryClass(WebViewFactory.java:137)
at android.webkit.WebViewFactory.getProvider(WebViewFactory.java:105)
at android.webkit.WebView.getFactory(WebView.java:2192)
at android.webkit.WebView.ensureProviderCreated(WebView.java:2187)
at android.webkit.WebView.setOverScrollMode(WebView.java:2246)
at android.view.View.<init>(View.java:3591)
at android.view.View.<init>(View.java:3685)
at android.view.ViewGroup.<init>(ViewGroup.java:491)
at android.widget.AbsoluteLayout.<init>(AbsoluteLayout.java:55)
at android.webkit.WebView.<init>(WebView.java:538)
at android.webkit.WebView.<init>(WebView.java:483)
at android.webkit.WebView.<init>(WebView.java:466)
at android.webkit.WebView.<init>(WebView.java:453)
at java.lang.reflect.Constructor.newInstance(Constructor.java)
at java.lang.reflect.Constructor.newInstance(Constructor.java:288)
at android.view.LayoutInflater.createView(LayoutInflater.java:626)
at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:55)
at com.android.internal.policy.impl.HwPhoneLayoutInflater.onCreateView(HwPhoneLayoutInflater.java:75)
at android.view.LayoutInflater.onCreateView(LayoutInflater.java:701)
at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:760)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:825)
at android.view.LayoutInflater.rInflate(LayoutInflater.java:828)
at android.view.LayoutInflater.inflate(LayoutInflater.java:523)
at android.view.LayoutInflater.inflate(LayoutInflater.java:425)
at android.view.LayoutInflater.inflate(LayoutInflater.java:368)
at android.support.v7.app.AppCompatDelegateImpl.setContentView(AppCompatDelegateImpl.java:469)
at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:140)
at com.myapp.ui.DialogActivity.onCreate(DialogActivity.kt:18)
at android.app.Activity.performCreate(Activity.java:6013)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1108)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2359)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2466)
at android.app.ActivityThread.access$1200(ActivityThread.java:152)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1341)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5538)
at java.lang.reflect.Method.invoke(Method.java)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:960)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)
Run Code Online (Sandbox Code Playgroud)
但从一些stackoverflow的答案来看,这背后的原因也是一样的。
try catch 是唯一的解决方案还是我在这里做错了什么?对此的任何见解都会非常有帮助和赞赏。谢谢。
| 归档时间: |
|
| 查看次数: |
2171 次 |
| 最近记录: |