java - Android : Unable to start activity componentInfo 致命异常

标签 java android android-intent nullpointerexception

<分区>

我正在尝试使用 Parse.com 库开发我的应用程序。 当用户登录到他的帐户时,他会转到主要 Activity 。他第一次这样做,没关系。但是如果他注销然后再次登录,当他进入主要 Activity 时会显示错误。

我正在使用滑动菜单,如果用户已登录,它会显示选项:设置和注销。或者,显示登录和注册。

也许错误是在我设置这些 View 的可见性时出现的。 这是 logCat。

04-17 17:28:03.155: E/AndroidRuntime(14343): FATAL EXCEPTION: main
04-17 17:28:03.155: E/AndroidRuntime(14343): java.lang.RuntimeException: Unable to start activity ComponentInfo{br.com.fitness.legacy.personal/br.com.activities.fitness.legacy.TelaPrincipalLogado}: android.os.NetworkOnMainThreadException
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1968)
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1993)
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.app.ActivityThread.access$600(ActivityThread.java:127)
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1159)
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.os.Handler.dispatchMessage(Handler.java:99)
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.os.Looper.loop(Looper.java:137)
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.app.ActivityThread.main(ActivityThread.java:4507)
04-17 17:28:03.155: E/AndroidRuntime(14343): at java.lang.reflect.Method.invokeNative(Native Method)
04-17 17:28:03.155: E/AndroidRuntime(14343): at java.lang.reflect.Method.invoke(Method.java:511)
04-17 17:28:03.155: E/AndroidRuntime(14343): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
04-17 17:28:03.155: E/AndroidRuntime(14343): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
04-17 17:28:03.155: E/AndroidRuntime(14343): at dalvik.system.NativeStart.main(Native Method)
04-17 17:28:03.155: E/AndroidRuntime(14343): Caused by: android.os.NetworkOnMainThreadException
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099)
04-17 17:28:03.155: E/AndroidRuntime(14343): at org.apache.harmony.xnet.provider.jsse.OpenSSLSocketImpl.close(OpenSSLSocketImpl.java:922)
04-17 17:28:03.155: E/AndroidRuntime(14343): at org.apache.http.impl.SocketHttpClientConnection.close(SocketHttpClientConnection.java:205)
04-17 17:28:03.155: E/AndroidRuntime(14343): at org.apache.http.impl.conn.DefaultClientConnection.close(DefaultClientConnection.java:161)
04-17 17:28:03.155: E/AndroidRuntime(14343): at org.apache.http.impl.conn.tsccm.AbstractConnPool.closeConnection(AbstractConnPool.java:320)
04-17 17:28:03.155: E/AndroidRuntime(14343): at org.apache.http.impl.conn.tsccm.AbstractConnPool.shutdown(AbstractConnPool.java:296)
04-17 17:28:03.155: E/AndroidRuntime(14343): at org.apache.http.impl.conn.tsccm.ConnPoolByRoute.shutdown(ConnPoolByRoute.java:670)
04-17 17:28:03.155: E/AndroidRuntime(14343): at org.apache.http.impl.conn.tsccm.ThreadSafeClientConnManager.shutdown(ThreadSafeClientConnManager.java:257)
04-17 17:28:03.155: E/AndroidRuntime(14343): at com.parse.ParseRequest.initialize(ParseRequest.java:106)
04-17 17:28:03.155: E/AndroidRuntime(14343): at com.parse.Parse.initialize(Parse.java:108)
04-17 17:28:03.155: E/AndroidRuntime(14343): at br.com.activities.fitness.legacy.TelaPrincipalLogado.onCreate(TelaPrincipalLogado.java:65)
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.app.Activity.performCreate(Activity.java:4465)
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1052)
04-17 17:28:03.155: E/AndroidRuntime(14343): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1932)
04-17 17:28:03.155: E/AndroidRuntime(14343): ... 11 more

抱歉我的英语不好:/

更新:

我意识到我已经在使用线程进行登录、注销和注册。因为 lib 为我提供了以下方法:

ParseUser.logInInBackground(usuario, senha, new LogInCallback() {
              public void done(ParseUser user, ParseException e) {
                if (user != null) {
                    Intent it = new Intent(getApplicationContext(), TelaPrincipal.class);
                    finish();
                    startActivity(it);
                } else {
                    Log.e("Erro no login", e.getMessage()); 
                    Toast.makeText(getBaseContext(), getString(R.string.tente_novamente), Toast.LENGTH_LONG).show();
                }


              }
            });

报名方式

ParseUser user = new ParseUser();
            user.setUsername(usuario);
            user.setPassword(senha);
            user.setEmail(email);

            user.signUpInBackground(new SignUpCallback() {
                  public void done(ParseException e) {
                    if (e == null) {
                            startActivity(new Intent(getApplicationContext(), TelaPrincipal.class)); 
                    } else {
                        Log.e("Erro no Cadastro", e.getMessage());
                        textViewErro.setText(getString(R.string.tente_novamente));
                        textViewErro.setVisibility(View.VISIBLE);
                    }
                  }
                });

所以,如果 lib 对我做这些事情,就会抛出一个线程。我需要做什么?当用户第一次登录或注册时,一切运行正常。但是,如果他注销并再次登录,则会出现异常。我不知道我必须做什么;/

最佳答案

它是由 android.os.NetworkOnMainThreadException 引起的。您不能在 android 的主 UI 线程上执行任何网络操作。您需要在后台线程上执行任何网络操作。最简单的方法很可能是 AsyncTask .您应该阅读有关线程的文档 here .

关于java - Android : Unable to start activity componentInfo 致命异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23143094/

相关文章:

java - 如何通过选择微调项目来更改应用程序语言?

android - 如何在 Kotlin 中关闭 Android 应用程序

java - java中的输入参数

java - 如何在jtextfields中显示netbeans中jtable中单击的每个数据

java - Android - 如何简化十的倍数?

android - 在 iOS 上带有 expo 的 react-native statusBar

java - 在工厂中动态调用正确的实现

java - Swing:函数的执行顺序

android - 广播接收器返回的结果

android - 从新的照片应用程序中挑选图像