当前位置: 首页 > 知识库问答 >
问题:

Android崩溃:nullpoint异常

呼延靖
2023-03-14

我正试图用PHP和MYSQL为android开发一个登录应用程序,但每次启动它都会崩溃。我读过类似的问题,但我仍然不能指出错误

Logcat报告

09-25 15:34:07.722: E/AndroidRuntime(2515): FATAL EXCEPTION: main
09-25 15:34:07.722: E/AndroidRuntime(2515): Process: com.learn2crack.tab, PID: 2515
09-25 15:34:07.722: E/AndroidRuntime(2515): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.learn2crack.tab/com.learn2crack.tab.Login}: java.lang.NullPointerException
09-25 15:34:07.722: E/AndroidRuntime(2515):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at android.app.ActivityThread.access$800(ActivityThread.java:135)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at android.os.Handler.dispatchMessage(Handler.java:102)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at android.os.Looper.loop(Looper.java:136)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at android.app.ActivityThread.main(ActivityThread.java:5017)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at java.lang.reflect.Method.invokeNative(Native Method)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at java.lang.reflect.Method.invoke(Method.java:515)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at dalvik.system.NativeStart.main(Native Method)
09-25 15:34:07.722: E/AndroidRuntime(2515): Caused by: java.lang.NullPointerException
09-25 15:34:07.722: E/AndroidRuntime(2515):     at com.learn2crack.tab.Login.onCreate(Login.java:76)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at android.app.Activity.performCreate(Activity.java:5231)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
09-25 15:34:07.722: E/AndroidRuntime(2515):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)

我的login.java包com.learn2crack.tab;

public class Login extends Activity implements OnClickListener {

    private EditText user, pass;
    private Button mSubmit, mRegister;

    // Progress Dialog
    private ProgressDialog pDialog;

    // JSON parser class
    JSONParser jsonParser = new JSONParser();

    // php login script location:


    private static final String LOGIN_URL = "http://10.0.2.2/webservice/login.php";


    private static final String TAG_SUCCESS = "success";
    private static final String TAG_MESSAGE = "message";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_login);

        // setup input fields
        user = (EditText) findViewById(R.id.username);
        pass = (EditText) findViewById(R.id.pword);

        // setup buttons
        mSubmit = (Button) findViewById(R.id.login);
        mRegister = (Button) findViewById(R.id.register);

        // register listeners
        mSubmit.setOnClickListener(this);
        mRegister.setOnClickListener(this);

    }

    @Override
    public void onClick(View v) {
        // TODO Auto-generated method stub
        switch (v.getId()) {
        case R.id.login:
            new AttemptLogin().execute();
            break;
        case R.id.register:
            Intent i = new Intent(this, Register.class);
            startActivity(i);
            break;

        default:
            break;
        }
    }

    class AttemptLogin extends AsyncTask<String, String, String> {

        @Override
        protected void onPreExecute() {
            super.onPreExecute();
            pDialog = new ProgressDialog(Login.this);
            pDialog.setMessage("Attempting login...");
            pDialog.setIndeterminate(false);
            pDialog.setCancelable(true);
            pDialog.show();
        }

        @Override
        protected String doInBackground(String... args) {
            // TODO Auto-generated method stub
            // Check for success tag
            int success;
            String username = user.getText().toString();
            String password = pass.getText().toString();
            try {
                // Building Parameters
                List<NameValuePair> params = new ArrayList<NameValuePair>();
                params.add(new BasicNameValuePair("username", username));
                params.add(new BasicNameValuePair("password", password));

                Log.d("request!", "starting");
                // getting product details by making HTTP request
                JSONObject json = jsonParser.makeHttpRequest(LOGIN_URL, "POST",
                        params);

                // check your log for json response
                Log.d("Login attempt", json.toString());

                // json success tag
                success = json.getInt(TAG_SUCCESS);
                if (success == 1) {
                    Log.d("Login Successful!", json.toString());
                    // save user data
                    SharedPreferences sp = PreferenceManager
                            .getDefaultSharedPreferences(Login.this);
                    Editor edit = sp.edit();
                    edit.putString("username", username);
                    edit.commit();

                    Intent i = new Intent(Login.this, MainActivity.class);
                    finish();
                    startActivity(i);
                    return json.getString(TAG_MESSAGE);
                } else {
                    Log.d("Login Failure!", json.getString(TAG_MESSAGE));
                    return json.getString(TAG_MESSAGE);
                }
            } catch (JSONException e) {
                e.printStackTrace();
            }

            return null;

        }

        protected void onPostExecute(String file_url) {
            // dismiss the dialog once product deleted
            pDialog.dismiss();
            if (file_url != null) {
                Toast.makeText(Login.this, file_url, Toast.LENGTH_LONG).show();
            }

        }

    }

}

PHP脚本

共有1个答案

桑坚
2023-03-14

使用一步一步的执行,并检查您的恢复。

@Override
protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_login);

    // setup input fields
    user = (EditText) findViewById(R.id.username);
    pass = (EditText) findViewById(R.id.pword);

    // setup buttons
    mSubmit = (Button) findViewById(R.id.login);
    mRegister = (Button) findViewById(R.id.register);

    // register listeners
    mSubmit.setOnClickListener(this);
    mRegister.setOnClickListener(this);

}

在OnCreate上切换断点。

检查:

// setup buttons
    mSubmit = (Button) findViewById(R.id.login);
    mRegister = (Button) findViewById(R.id.register);
 类似资料:
  • 本文向大家介绍详解Android中处理崩溃异常,包括了详解Android中处理崩溃异常的使用技巧和注意事项,需要的朋友参考一下 大家都知道,现在安装Android系统的手机版本和设备千差万别,在模拟器上运行良好的程序安装到某款手机上说不定就出现崩溃的现象,开发者个人不可能购买所有设备逐个调试,所以在程序发布出去之后,如果出现了崩溃现象,开发者应该及时获取在该设备上导致崩溃的信息,这对于下一个版本的

  • Project My Application11在运行Gradle时使用以下JDK位置:C:/Program Files/Android/Android Studio1/jre在不同进程上使用不同的JDK位置可能会导致Gradle生成多个守护进程,例如,在使用Android Studio时从终端执行Gradle任务。更多信息。。。 显示此错误后自动关闭而不显示任何错误。 尝试了jdk 8和13,并

  • 本文向大家介绍Android application捕获崩溃异常怎么办,包括了Android application捕获崩溃异常怎么办的使用技巧和注意事项,需要的朋友参考一下 Android application捕获崩溃异常怎么办? 通用 application 1、收集所有 avtivity 用于彻底退出应用 2、捕获崩溃异常,保存错误日志,并重启应用 以上就是本文的全部内容,希望对大家的学习

  • 我开发了一个使用原生C库的Android应用程序。我可以成功地用JNI编译整个程序,一切都很顺利。 然而,本机C库偶尔会崩溃(最常见的是SIGSEGV)。这反过来会导致我的应用程序崩溃,而不会对用户发出任何有意义的通知。我希望实现以下目标: 使用信号处理程序(sigaction)捕获本机代码中的信号,以防止随机崩溃 在 C 库中抛出 Java 可以捕获的异常 在 Java 中捕获异常,为用户生成有

  • 我是Android世界的新手(既是用户也是开发人员),我的Android应用程序在执行

  • 我正在尝试修复崩溃,例如: 1: 2: 三: 我已经复习了IndirectReferenceTable()的源代码https://android.googlesource.com/platform/art//kitkat dev/runtime/indirect\u reference\u表。cc),它似乎因为表溢出而崩溃。 据我所知,我正在正确删除所有本地引用。 问题是否可能与当地参考文献无关?

  • 基本上,当我单击小部件上的特定按钮时,我希望获取数据库中的下一条记录。该功能本身的工作很好,因为我在应用程序中使用它。但在小部件中,它崩溃了。我认为问题出在onReceive函数本身,尽管即使我只是设置onReceive来更新textview,它也会崩溃为NullPointerException。 公共静态字符串NEXT_RECORD=“NEXT_RECORD”; 以下是它的名称: Intent

  • 错误消息说 用户10093和当前进程都没有android.permission.ACCESS_NETWORK_STATE 我在清单中添加了“android.permission.ACCESS_NETWORK_STATE”: 为什么会发生这种情况?我如何修复它?我在模仿NexusOne-2.3.7API10 代码剪切: 整个错误日志: 04-27 22:26:13.781 1522-1522/com