将消息插入自定义数据库

时间:2013-05-06 21:43:54

标签: android database

这是我的database.java文件

 package com.example.mobile_computing_project;



import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;

public class Database_Helper extends SQLiteOpenHelper {

public Database_Helper(Context smsReceiver) {
    super(smsReceiver, dbName, null, 1);
    // TODO Auto-generated constructor stub
}
static final String dbName="MySms";
static final String Login_Table="Login_Authentication";
static final String colID="ID";
static  final String colUsername="Username";
static final String colPassword="Password";
static final String Sms_table = "Sms_Repository";
static final String number = "Cell_Num";
static final String message = "message_text";

@Override
public void onCreate(SQLiteDatabase db) {
// TODO Auto-generated method stub
db.execSQL("CREATE TABLE " + Login_Table + "(" + colID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + colUsername + " TEXT NOT NULL," + colPassword + " TEXT NOT NULL);");
db.execSQL("CREATE TABLE " + Sms_table + "(" + number + " TEXT NOT NULL, " + message + " TEXT NOT NULL);");
Log.w("Come aww man", "Database Table Created!!");


}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
db.execSQL("DROP TABLE IF EXISTS " + "Login_Authentication");
db.execSQL("DROP TABLE IF EXISTS " + "Sms_table");
onCreate(db);
}
public void insert_new_user(String username,String password)
{
    SQLiteDatabase db = this.getWritableDatabase();
    ContentValues cv = new ContentValues();
    cv.put(Database_Helper.colUsername,username);
    cv.put(Database_Helper.colPassword,password);
    db.insert(Login_Table, null, cv);
    db.close();
}
public void insert_text(String number, String text)
{
    SQLiteDatabase db = this.getWritableDatabase();
    ContentValues cv = new ContentValues();
    cv.put(Database_Helper.number,number);
    cv.put(Database_Helper.message,text);
    db.insert(Sms_table, null, cv);
    db.close();

}
public void delete(long id)
{
    SQLiteDatabase db = this.getWritableDatabase();
    db.delete(Login_Table, colID+"="+id, null);
}
public String getinfo() {
    // TODO Auto-generated method stub
    String[] columns  =  new String[]{ colID,colUsername,colPassword};
    SQLiteDatabase bm = this.getReadableDatabase();
    String res = " ";
    Cursor c = bm.query(Login_Table, columns, null, null, null, null, null);
    int irow = c.getColumnIndex(colID);
    int iuser = c.getColumnIndex(colUsername);
    int ipass = c.getColumnIndex(colPassword);
    for(c.moveToFirst(); !c.isAfterLast();c.moveToNext() )
    {
        res = res + c.getString(irow) + " " + c.getString(iuser) + " " + c.getString(ipass) + "\n" ;
    }

    return res;
}
public String get_texts() {
    // TODO Auto-generated method stub
    String[] columns  =  new String[]{ number,message};
    SQLiteDatabase bm = this.getReadableDatabase();
    String res = " ";
    Cursor c = bm.query(Sms_table, columns, null, null, null, null, null);
    int inum = c.getColumnIndex(number);
    int imessage = c.getColumnIndex(message);

    for(c.moveToFirst(); !c.isAfterLast();c.moveToNext() )
    {
        res = res + c.getString(inum) + " " + c.getString(imessage)+ "\n" ;
    }

    return res;
}
public void updating_the_table(long id, String user_updating) {
    // TODO Auto-generated method stub
    SQLiteDatabase db = this.getWritableDatabase();
    ContentValues cv_update = new ContentValues();

    cv_update.put(Database_Helper.colUsername, user_updating);
    long test = db.update(Login_Table, cv_update, colID+"="+id, null);
    db.close();

}
public String verify_user(String is_user)
{
    String verify = " ";
    String check = " ";
    SQLiteDatabase fg = this.getReadableDatabase();
    Cursor c = fg.query(Login_Table, null, null, null, null, null, null);
    int iuser = c.getColumnIndex(colUsername);
    for(c.moveToFirst() ; !c.isAfterLast();c.moveToNext())
    {
        verify = c.getString(iuser);
        if(is_user.equals(verify))
        {
            check = "Valid User!";
        }
    }
    return check;

}
}

这是文件SmSReceiver.java

package com.example.mobile_computing_project;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.gsm.SmsMessage;
import android.util.Log;
import android.widget.Toast;
import android.app.Activity;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.widget.TextView;

public class SmsReceiver extends BroadcastReceiver
{
@Override
public void onReceive(Context context, Intent intent) 
{
    //---get the SMS message passed in---
    Bundle bundle = intent.getExtras();        
    SmsMessage[] msgs = null;
    String str = "";            
    if (bundle != null)
    {
        //---retrieve the SMS message received---
        Object[] pdus = (Object[]) bundle.get("pdus");
        msgs = new SmsMessage[pdus.length];            
        for (int i=0; i<msgs.length; i++){
            msgs[i] = SmsMessage.createFromPdu((byte[])pdus[i]);  
            Database_Helper accessing_db = new Database_Helper(SmsReceiver.this);
               accessing_db.insert_text(msgs[i].getOriginatingAddress().toString(), msgs[i].getMessageBody().toString());
            accessing_db.close();
            Log.w("Ho gya!", "Welcome User jee!");
            Toast.makeText(context, "New User Has Been Created!!", Toast.LENGTH_SHORT).show();
            str += "SMS from " + msgs[i].getOriginatingAddress();                     
            str += " :";
            str += msgs[i].getMessageBody().toString();
            str += "\n";        
        }
        //---display the new SMS message---
        Toast.makeText(context, str, Toast.LENGTH_SHORT).show();
    }                       
}
}

我不知道为什么我的程序在线上给我错误:

Database_Helper accessing_db = new Database_Helper(SmsReceiver.this);

那是在SmsReceiver.java文件中 所有我想做的只是将数字和文本插入数据库表Sms_repository! Plz帮助!

1 个答案:

答案 0 :(得分:0)

您需要数据库类的上下文。使用onReceive参数中的上下文。

Database_Helper accessing_db = new Database_Helper(context);