MissingWebViewPackageException:无法加载 WebView 提供程序:未安装 WebView

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 是唯一的解决方案还是我在这里做错了什么?对此的任何见解都会非常有帮助和赞赏。谢谢。