2010-12-11 6 views
0

Androidでログインアプリケーションを作成していますが、データベースをエミュレータにプッシュしました。作成したアプリケーションを使用してデータベースを追加すると、エミュレータは動作を停止し、応答を停止します。私は何をすべきか?Androidでのログインアプリケーション

package com.android.sms.privacy; 

import java.util.Arrays; 
import java.util.Locale; 

import com.android.sms.privacy.DatabaseHelper; 

import android.app.Activity; 
import android.widget.EditText; 
import android.app.ProgressDialog; 
import android.os.Bundle; 
import android.widget.Button; 
import android.view.View; 
import android.content.ContentValues; 
import android.content.Intent; 
import android.database.Cursor; 
import android.database.sqlite.SQLiteDatabase; 
import android.util.Log; 
import android.widget.Toast; 



public class SMS extends Activity { 
// 
public static final String DEBUG_TAG = "FullDatabase Log"; 
    public static final int DB_version = 2; 
    //public static final String DB_name = "User.db"; 
    public static final String TABLE_NAME = "login"; 
    //public static final String TABLE_NAME = "tbl_temp"; 
    //public static final String DB_name = "User_temp"; 
    public static final String DBNAME = "login"; 
    public DatabaseHelper database_helper; 
    public SQLiteDatabase database; 
    public SQLiteDatabase database_rd; 
    /** Called when the activity is first created. */ 
    public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.createaccount); 
    Toast.makeText(this,"Before Bundled", 
    Toast.LENGTH_SHORT).show(); 
    createDataBase(); 
    //LogIn login = new LogIn(); 
    Button submit = (Button)findViewById(R.id.Button02); 
    Toast.makeText(this,"after Bundled", 
    Toast.LENGTH_SHORT).show(); 
    submit.setOnClickListener(new View.OnClickListener() 
    { 
        @Override 
        public void onClick(View v) { 
          // TODO Auto-generated method stub 

          Welcome createaccount = new Welcome(); 
          Toast.makeText(createaccount.getApplicationContext(), "In Helper executing onCreate1()", 
          Toast.LENGTH_SHORT).show(); 

          String[] success = insertRecords(); 
          if(success[0].equalsIgnoreCase("1")) 
          { 
          setContentView(R.layout.menu); 
          } 


        } 
      }); 
    //database.close(); 
    } 

// 



protected String[] insertRecords() { 
Toast.makeText(this,"In insertrecords", Toast.LENGTH_SHORT).show(); 
    //database.openDatabase(DB_name,database.create(factory), 
    //ACCESSIBILITY_SERVICE); 
    final EditText username = (EditText)findViewById(R.id.username); 
    final EditText password = (EditText)findViewById(R.id.password); 
    Long newUserID = 0l; 
    String user = username.getText().toString(); 
    String userpass = password.getText().toString(); 
    ContentValues values = new ContentValues(); 
    values.put("username",user); 
    values.put("password",userpass); 
    //StringBuilder info = new StringBuilder(); 
    String[] info = new String[10]; 
    database.beginTransaction(); 
    try 
    { 
    Toast.makeText(this,"Before calling inserting values", 
    Toast.LENGTH_SHORT).show(); 
    newUserID = database.insertOrThrow(TABLE_NAME, null, values); 
    Toast.makeText(this,"After calling inserting values", 
    Toast.LENGTH_SHORT).show(); 
    info[0] = newUserID.toString(); 
    info[1] = user; 
    info[2] = userpass; 
    System.out.println(newUserID); 
    Toast.makeText(this, newUserID.toString(), 
    Toast.LENGTH_SHORT).show(); 
    Cursor c = database_rd.query(TABLE_NAME, null, null, null, null, 
    null,null); 
    LogCursorInfo(c); 
    c.close(); 
    } 
    catch(Exception e) 
    { 
    //Transaction failed; 
    e.printStackTrace(); 
    } 
    finally 
    { 
    database.endTransaction(); 
    database.close(); 
    } 
    return info; 
    } 

private void LogCursorInfo(Cursor c) { 
// TODO Auto-generated method stub 
Log.i(DEBUG_TAG, "*** Cursor Begin *** " + " Results:" + 
    c.getCount() + " Columns: " + c.getColumnCount()); 
        // Print column names 
        String rowHeaders = "|| "; 
        for (int i = 0; i < c.getColumnCount(); i++) { 
          rowHeaders = rowHeaders.concat(c.getColumnName(i) + " || "); 
        } 
        Log.i(DEBUG_TAG, "COLUMNS " + rowHeaders); 
        //Integer rows = c.getCount(); 
        //Toast.makeText(this, rows.toString(), Toast.LENGTH_SHORT).show(); 
        // Print records 
        c.moveToFirst(); 
        while (c.isAfterLast() == false) { 
          String rowResults = "|| "; 
          for (int i = 0; i < c.getColumnCount(); i++) { 
            rowResults = rowResults.concat(c.getString(i) + " || "); 
          } 
          Log.i(DEBUG_TAG, "Row " + c.getPosition() + ": " + rowResults); 
          Toast.makeText(this, rowResults.toString(), 
    Toast.LENGTH_SHORT).show(); 
          //Toast.makeText(this, "In LogCursorInfo", 

          c.moveToNext(); 
        } 
        Log.i(DEBUG_TAG, "*** Cursor End ***"); 
      } 
     void createDataBase() 
     { 
     if(Arrays.binarySearch(databaseList(), DBNAME)>=0) 
      { 
        deleteDatabase(DBNAME); 
      } 
      database_helper = new 
      DatabaseHelper(this.getApplicationContext()); 
      //database_helper.onCreate(database); 
      database = database_helper.getWritableDatabase(); 
      database.setLocale(Locale.getDefault()); // Set the local 
      database.setLockingEnabled(true); // SQLiteDatabase is made thread-safe by using locks around critical sections. 
      database_rd = database_helper.getReadableDatabase(); 
      Toast.makeText(this, "created database", 
    Toast.LENGTH_SHORT).show(); 
      /* 
      database = 
    openOrCreateDatabase(DB_name,SQLiteDatabase.CREATE_IF_NECESSARY, 
    null); 
      database.setLocale(Locale.getDefault()); // Set the local 
      database.setLockingEnabled(true); // SQLiteDatabase is made 
    thread-safe by using locks around critical sections. 
      database.setVersion(1); 
      database.execSQL(CREATE_USER_TABLE); 
      */ 
      } 
    } 

アプリケーションは、この時点で応答を停止:

submit.setOnClickListener(new View.OnClickListener() 
    { 
        @Override 
        public void onClick(View v) { 
          // TODO Auto-generated method stub 

          Welcome createaccount = new Welcome(); 
          Toast.makeText(createaccount.getApplicationContext(), "In Helper executing onCreate1()", 
          Toast.LENGTH_SHORT).show(); 

          String[] success = insertRecords(); 
          if(success[0].equalsIgnoreCase("1")) 
          { 
           setContentView(R.layout.menu); 
          } 


        } 
      }); 
+0

kyleそのコードのどの時点でアプリケーションが応答を停止していますか?これは1つの質問に対する多くのコードです。それを完全に読んでみて、問題を理解しようとするのはちょっと難しいです。あなたがそれをちょっと絞り込んでコードの一部だけを貼り付けることができればそれは素晴らしいことでしょう。 – Janusz

+0

アプリケーションが停止するコードを追加しました。 – sean

+0

adb logcatの出力を追加できますか? – ggomeze

答えて

1

私の推測の問題はここに

Welcome createaccount = new Welcome(); 

あなたが持っている調達アプリケーション・コンテキストを取得するためのApplicationクラスを拡張します。しかし、AndroidManifest.xmlファイルに登録することはできません。したがって、タグのandroid:name="Welcome"をマニフェストファイルに設定してください。

関連する問題