Webview在启动时崩溃Android应用程序

时间:2013-08-19 19:39:30

标签: android webview

我在Android应用程序中使用webview,并且我试图在保存设置后第二次启动应用程序时自动启动它。设置断点后,我能够确定应用程序在WebActivity中的“mWebView.setWebChromeClient(new WebChromeClient()”行崩溃。我在调试器中找不到错误源。

WebActivity:

public class WebActivity extends Activity 
{

WebView mWebView;

@Override
public void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    final Activity mActivity = this;

    // Adds Progress bar Support
    this.getWindow().requestFeature(Window.FEATURE_PROGRESS);
    setContentView(R.layout.activity_web);


    // Makes Progress bar Visible
    getWindow().setFeatureInt( Window.FEATURE_PROGRESS, Window.PROGRESS_VISIBILITY_ON);

    mWebView = (WebView) findViewById( R.id.webview );

    mWebView.getSettings().setBuiltInZoomControls(true);
    mWebView.getSettings().setJavaScriptEnabled(true);
    mWebView.getSettings().setDomStorageEnabled(true);

    mWebView.setWebViewClient(new WebViewClient());
    mWebView.setWebChromeClient(new WebChromeClient() 
    {
        public void onProgressChanged(WebView view, int progress)  
        {
            //Make the bar disappear after URL is loaded, and changes string to Loading...
            findViewById(R.id.webview).setVisibility(View.GONE);
            mActivity.setTitle("Loading...");
            mActivity.setProgress(progress * 100); //Make the bar disappear after URL is loaded

            // Return the app name after finish loading
            if(progress == 100)
            {
                mActivity.setTitle(R.string.webtitle);
                findViewById(R.id.webview).setVisibility(View.VISIBLE);
            }
        }
    });
    Bundle b = getIntent().getExtras();
    mWebView.loadUrl("http://" + (b.getString("iptextfield")) + "/index.html");
    WebView wv = (WebView) findViewById(R.id.webview);
    wv.setWebViewClient(new WebViewClient() 
    {
    boolean toast_f = true;
       @Override
       public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) 
       {
           Context context = getApplicationContext();
           CharSequence text = "Loading...(this may take up to 60 seconds)";

           if (toast_f)
           {
               toast_f = false;
               int duration = Toast.LENGTH_LONG;
               Toast toast = Toast.makeText(context, text, duration);
               toast.setGravity(Gravity.CENTER|Gravity.CENTER,0,0);
               toast.show();
           }

           Bundle b = getIntent().getExtras();
           mWebView.loadUrl("http://" + (b.getString("iptextfield")) + "/index.html");
       }
    });
}

}

主要活动:

public class MainActivity extends Activity 
{

@Override
protected void onCreate(Bundle savedInstanceState) 
{
    super.onCreate(savedInstanceState);
    Intent intent;

    SharedPreferences sharedPref= getSharedPreferences("mypref", 0);
    String GetStatus = sharedPref.getString("DataSaved", "");

    if (GetStatus.equals("true")) 
    {
       intent = new Intent(this, WebActivity.class);
    } 
    else 
    {
       intent = new Intent(this, SetupActivity.class);
    }

    startActivity(intent);
    finish();
}

}

这是我在运行应用程序时遇到的logcat错误:

08-19 12:25:54.407: W/dalvikvm(15158): threadid=1: thread exiting with uncaught      exception (group=0x4202d438)
08-19 12:25:54.407: E/AndroidRuntime(15158): FATAL EXCEPTION: main
08-19 12:25:54.407: E/AndroidRuntime(15158): java.lang.RuntimeException: Unable to  start activity ComponentInfo{com.webpage.WebActivity}: java.lang.NullPointerException
08-19 12:25:54.407: E/AndroidRuntime(15158):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2073)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2098)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at android.app.ActivityThread.access$600(ActivityThread.java:138)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1204)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at android.os.Handler.dispatchMessage(Handler.java:99)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at android.os.Looper.loop(Looper.java:137)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at android.app.ActivityThread.main(ActivityThread.java:4911)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at java.lang.reflect.Method.invokeNative(Native Method)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at java.lang.reflect.Method.invoke(Method.java:511)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at dalvik.system.NativeStart.main(Native Method)
08-19 12:25:54.407: E/AndroidRuntime(15158): Caused by: java.lang.NullPointerException
08-19 12:25:54.407: E/AndroidRuntime(15158):    at com.webpage.WebActivity.onCreate(WebActivity.java:58)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at android.app.Activity.performCreate(Activity.java:5240)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1082)
08-19 12:25:54.407: E/AndroidRuntime(15158):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2037)
08-19 12:25:54.407: E/AndroidRuntime(15158):    ... 11 more

2 个答案:

答案 0 :(得分:1)

为了更完整的答案:

NullPointerException发生的行是58,恰好是

mWebView.loadUrl("http://"(b.getString("iptextfield")) + "/index.html"); 

乍一看,mWebViewb.getString()或b可能是null

mWebView之前已经使用过,因此不应该是null

b.getString()返回的字符串与另外两个字符串连接在一起,因此不会抛出NPE。

这样就留下了b本身。

这应该在MainActivity中有意义,您开始WebActivity但不向其Intent添加任何额外内容。

在开始下一个Activity之前,使用Intent#putExtra()为意图添加额外内容。

然后,正如@siik建议的那样,最好确保Bundle不为空:

if (b != null){
   mWebView.loadUrl("http://" + (b.getString("iptextfield")) + "/index.html");
}

你甚至可以再往前走一点,看看b是否真的包含你要找的钥匙。

if (b != null && b.containsKey ("iptextfield")){
      mWebView.loadUrl("http://" + (b.getString("iptextfield")) + "/index.html");
}

答案 1 :(得分:0)

您需要检查是否Bundle b = getIntent().getExtras(); 返回任何值,即not null