0

これは、データベースからデータを読み取るためのコードです。ここでは、値を受け取り、「Toast」クラスを使用して出力しています。

public void onClickLogin(View btnLogin)
{
    String email,password;
    String[] cols = new String[] {DataBase_Server.EMAIL, DataBase_Server.PASS};
    EditText edtPassword = (EditText) findViewById(R.id.edtPassword);
    EditText edtLoginId = (EditText) findViewById(R.id.btnLogin);
    DataBase_Server database=new DataBase_Server(login.this);
    SQLiteDatabase db=database.getReadableDatabase();
    Cursor c=db.query(DataBase_Server.TABLE, null, null, null, null, null, null);
    //startManagingCursor(c);
    c.moveToFirst();
    email=c.getString(c.getColumnIndex(DataBase_Server.EMAIL));
    password=c.getString(c.getColumnIndex(DataBase_Server.PASS));
    Toast.makeText(this,email+" hello "+password, Toast.LENGTH_SHORT).show();
}

コードに構文エラーはありませんが、アプリの実行中にログイン ボタンをクリックすると、強制的に閉じるダイアログ ボックスが表示され、最終的にアプリが終了し、「logcat」に「スタックを開けません」などの例外が表示されますファイル……アクセスが拒否されました」など

ログキャット:

09-20 01:28:55.524: E/AndroidRuntime(378): java.lang.IllegalStateException: Could not execute method of the activity
09-20 01:28:55.524: E/AndroidRuntime(378):  at android.view.View$1.onClick(View.java:2031)
09-20 01:28:55.524: E/AndroidRuntime(378):  at android.view.View.performClick(View.java:2364)
09-20 01:28:55.564: E/dalvikvm(378): Unable to open stack trace file '/data/anr/traces.txt': Permission denied
09-20 01:45:58.265: E/AndroidRuntime(408): Uncaught handler: thread main exiting due to uncaught exception
09-20 01:45:58.295: E/AndroidRuntime(408): java.lang.IllegalStateException: Could not execute method of the activity
09-20 01:45:58.295: E/AndroidRuntime(408):  at android.view.View$1.onClick(View.java:2031)
09-20 01:45:58.295: E/AndroidRuntime(408):  at android.view.View.performClick(View.java:2364)
09-20 01:45:58.295: E/AndroidRuntime(408):  at android.view.View.onTouchEvent(View.java:4179)
09-20 01:45:58.295: E/AndroidRuntime(408):  at android.widget.TextView.onTouchEvent(TextView.java:6541)
09-20 01:45:58.295: E/AndroidRuntime(408):  at android.view.View.dispatchTouchEvent(View.java:3709)
09-20 01:45:58.295: E/AndroidRuntime(408):  at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
  09-20 01:45:58.295: E/AndroidRuntime(408):    at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
    09-20 01:45:58.295: E/AndroidRuntime(408):  at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
     09-20 01:45:58.295: E/AndroidRuntime(408):     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
      09-20 01:45:58.295: E/AndroidRuntime(408):    at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1659)
    09-20 01:45:58.295: E/AndroidRuntime(408):  at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1107)
     09-20 01:45:58.295: E/AndroidRuntime(408):     at android.app.Activity.dispatchTouchEvent(Activity.java:2061)
      09-20 01:45:58.295: E/AndroidRuntime(408):    at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1643)
    09-20 01:45:58.295: E/AndroidRuntime(408):  at android.view.ViewRoot.handleMessage(ViewRoot.java:1691)
     09-20 01:45:58.295: E/AndroidRuntime(408):     at android.os.Handler.dispatchMessage(Handler.java:99)
    09-20 01:45:58.295: E/AndroidRuntime(408):  at android.os.Looper.loop(Looper.java:123)
    09-20 01:45:58.295: E/AndroidRuntime(408):  at android.app.ActivityThread.main(ActivityThread.java:4363)
   09-20 01:45:58.295: E/AndroidRuntime(408):   at java.lang.reflect.Method.invokeNative(Native Method)
    09-20 01:45:58.295: E/AndroidRuntime(408):  at java.lang.reflect.Method.invoke(Method.java:521)
  09-20 01:45:58.295: E/AndroidRuntime(408):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
  09-20 01:45:58.295: E/AndroidRuntime(408):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
   09-20 01:45:58.295: E/AndroidRuntime(408):   at  dalvik.system.NativeStart.main(Native Method)
     09-20 01:45:58.295: E/AndroidRuntime(408): Caused by: java.lang.reflect.InvocationTargetException
  09-20 01:45:58.295: E/AndroidRuntime(408):    at com.example.curbrain.login.onClickLogin(login.java:36)
   09-20 01:45:58.295: E/AndroidRuntime(408):   at java.lang.reflect.Method.invokeNative(Native Method)
  09-20 01:45:58.295: E/AndroidRuntime(408):    at java.lang.reflect.Method.invoke(Method.java:521)
   09-20 01:45:58.295: E/AndroidRuntime(408):   at android.view.View$1.onClick(View.java:2026)
     09-20 01:45:58.295: E/AndroidRuntime(408):     ... 21 more
   09-20 01:45:58.295: E/AndroidRuntime(408): Caused by: java.lang.ClassCastException: android.widget.Button
   09-20 01:45:58.295: E/AndroidRuntime(408):   ... 25 more
    09-20 01:45:58.325: E/dalvikvm(408): Unable to open stack trace file '/data/anr/traces.txt': Permission denied

XML コード :

android:onClick="onClickLogin"
4

2 に答える 2

2

XML ログイン EditText を参照しようとしていますが、実際にはボタンの ID を使用しています。

 EditText edtLoginId = (EditText) findViewById(R.id.btnLogin); 

したがって、返されたビュー (ボタン) を EditText にキャストすることはできません。

その ID はボタン用ですR.id.btnLogin。XML で正しい ID を確認してください。

LogCat でそれを説明する行は次のとおりです。

 09-20 01:45:58.295: E/AndroidRuntime(408): Caused by: java.lang.ClassCastException: android.widget.Button
于 2012-09-19T20:25:33.383 に答える
1

タイプミスがあります。次の間に大文字と小文字の違いがあります。

android:onClick="onClickLogin"

と:

public void OnClickLogin(View btnLogin)

メソッドを小文字の「o」に変更します。

public void onClickLogin(View btnLogin)

このタイプミスを修正するために質問を更新したようですが、コードに含まれているかどうかを確認しましたか?

于 2012-09-19T20:25:10.237 に答える