Android O 中的 WebView 崩溃

Posted

技术标签:

【中文标题】Android O 中的 WebView 崩溃【英文标题】:WebView crash in Android O 【发布时间】:2018-02-26 13:07:51 【问题描述】:

这个问题不重复,我知道如何修复项目中的NPE,这个NPE发生在native method

如你所见,我得到:

原因:java.lang.NullPointerException 在 android.content.res.AssetManager.addAssetPathNative(Native Method)

android 8.0.0 中测试我的应用程序以膨胀 WebView 后,我遇到了以下错误。

    FATAL EXCEPTION: main
Process: com.example.shpoorvatan.myapplication, PID: 17952
java.lang.RuntimeException: Unable to start activity ComponentInfocom.example.shpoorvatan.myapplication/com.example.shpoorvatan.myapplication.MainActivity: android.view.InflateException: Binary XML file line #8: Binary XML file line #8: Error inflating class android.webkit.WebView
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2817)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892)
    at android.app.ActivityThread.-wrap11(Unknown Source:0)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1593)
    at android.os.Handler.dispatchMessage(Handler.java:105)
    at android.os.Looper.loop(Looper.java:164)
    at android.app.ActivityThread.main(ActivityThread.java:6541)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)
 Caused by: android.view.InflateException: Binary XML file line #8: Binary XML file line #8: Error inflating class android.webkit.WebView
 Caused by: android.view.InflateException: Binary XML file line #8: Error inflating class android.webkit.WebView
 Caused by: java.lang.reflect.InvocationTargetException
    at java.lang.reflect.Constructor.newInstance0(Native Method)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:334)
    at android.view.LayoutInflater.createView(LayoutInflater.java:647)
    at com.android.internal.policy.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:58)
    at android.view.LayoutInflater.onCreateView(LayoutInflater.java:720)
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:788)
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:730)
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:863)
    at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:824)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:515)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:423)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:374)
    at android.support.v7.app.AppCompatDelegateImplV9.setContentView(AppCompatDelegateImplV9.java:289)
    at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:139)
    at com.example.shpoorvatan.myapplication.MainActivity.onCreate(MainActivity.java:12)
    at android.app.Activity.performCreate(Activity.java:6975)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1213)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2770)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892)
    at android.app.ActivityThread.-wrap11(Unknown Source:0)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1593)
    at android.os.Handler.dispatchMessage(Handler.java:105)
    at android.os.Looper.loop(Looper.java:164)
    at android.app.ActivityThread.main(ActivityThread.java:6541)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)
 Caused by: java.lang.NullPointerException
    at android.content.res.AssetManager.addAssetPathNative(Native Method)
    at android.content.res.AssetManager.addAssetPathInternal(AssetManager.java:689)
    at android.content.res.AssetManager.addAssetPathAsSharedLibrary(AssetManager.java:684)
    at android.webkit.WebViewFactory.getProviderClass(WebViewFactory.java:407)
    at android.webkit.WebViewFactory.getProvider(WebViewFactory.java:211)
    at android.webkit.WebView.getFactory(WebView.java:2467)
    at android.webkit.WebView.ensureProviderCreated(WebView.java:2462)
    at android.webkit.WebView.setOverScrollMode(WebView.java:2527)
    at android.view.View.<init>(View.java:4536)
    at android.view.View.<init>(View.java:4668)
    at android.view.ViewGroup.<init>(ViewGroup.java:597)
    at android.widget.AbsoluteLayout.<init>(AbsoluteLayout.java:55)
    at android.webkit.WebView.<init>(WebView.java:636)
    at android.webkit.WebView.<init>(WebView.java:581)
    at android.webkit.WebView.<init>(WebView.java:564)
    at android.webkit.WebView.<init>(WebView.java:551)
        ... 27 more

我创建了一个新的示例应用程序,布局中只有一个WebView,但它存在问题,所以这不是我的应用程序的问题。

我没有找到任何解决此问题的方法。

提前致谢

PS:这是我的布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_
    android:layout_
    tools:context="com.example.shpoorvatan.myapplication.MainActivity">

    <WebView
        android:id="@+id/webView"
        android:layout_
        android:layout_/>

</LinearLayout>

java类:

public class MainActivity extends AppCompatActivity 

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        WebView webView = (WebView) findViewById(R.id.webView);
        webView.loadUrl("https://www.google.com/");
    

清单文件:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.shpoorvatan.myapplication">

    <uses-permission android:name="android.permission.INTERNET" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

PS-2:此应用程序在其他 android 版本中运行良好。

PS-3:你想面对这个问题吗?创建一个示例项目并在xml 代码中添加一个WebView,然后在android 8 上运行

PS-4:相关但不一样的问题:android-O : app crash with webview

答案:

正如我所见,所有带有webView 的应用程序(甚至是法律信息等系统部分)在打开webView 页面后都崩溃了,更新webView 问题已得到解决。

【问题讨论】:

也分享你的java代码和问题 @NileshRathod 查看我的更新 @Marcin 这不是 NPE 问题,我已经用原生方法解决了 ***.com/questions/45419123/… 我遇到了同样的问题。还没有答案:( 【参考方案1】:
    WebView webView = (WebView) findViewById(R.id.webView);
    WebSettings webSettings = webView.getSettings();
    webSettings.setjavascriptEnabled(true);
    webView.setWebViewClient(new WebViewClient() 


        @Override
        public void onPageStarted(WebView view, String url, Bitmap favicon) 
        //Do some like progress bar loading here.

        

        @Override
        public void onPageFinished(WebView view, String url) 

        webView.loadUrl(sourceURL);

        
    );

我刚刚测试了它,它工作正常。请试试这个。

【讨论】:

我已经添加了我的代码,我的 NPE 在本机方法中而不是在我的应用程序中【参考方案2】:

可能与我遇到的相同:https://developer.android.com/preview/features/security-behav

注意从 Android 8 开始,WebView 不能跨进程共享的部分

【讨论】:

以上是关于Android O 中的 WebView 崩溃的主要内容,如果未能解决你的问题,请参考以下文章

java.io.IOException 导致的 WebView 崩溃:关闭失败:EIO(I/O 错误)libcore.io.IoUtils.close(IoUtils.java:41)

ListView 或 CustomScrollView 中的 Flutter WebView - 在 Android 上因高度而崩溃

Android:WebView 中的 Twitter - 通过回调返回 Activity

通过Android WebView中的javascript检测点击HTML按钮

Android系统 WebView是啥?有啥用?

android应用程序在webview url更改时崩溃