2013-04-10 3 views
0

У меня есть следующий код, который работает до того, как я добавил код для сохранения полученного SMS.Ошибка приложения при получении сообщения

package com.example.smsTest; 

import android.content.BroadcastReceiver; 
import android.content.Context; 
import android.content.Intent; 
import android.os.Bundle; 
import android.telephony.SmsMessage; 
import android.widget.Toast; 

public class SmsReceiver extends BroadcastReceiver { 
    private SQLiteAdapter mySQLiteAdapter; 
@Override 
public void onReceive(Context context, Intent intent) { 
    Message message = null; 

     Bundle extras = intent.getExtras(); 
     if (extras == null) 
     return; 

     Object[] pdus = (Object[]) extras.get("pdus"); 
     for (int i = 0; i < pdus.length; i++) { 
      SmsMessage SMessage = SmsMessage.createFromPdu((byte[]) pdus[i]); 
      String sender = SMessage.getOriginatingAddress(); 
      String body = SMessage.getMessageBody().toString(); 

      message = mySQLiteAdapter.createMessage(body); 

      // A custom Intent that will used as another Broadcast 
     Intent in = new Intent("SmsMessage.intent.MAIN"). 
     putExtra("get_msg", sender+":"+body); 

     // To display a Toast whenever there is an SMS. 
     Toast.makeText(context,body,Toast.LENGTH_LONG).show(); 

     //You can place your check conditions here(on the SMS or the sender)    
     //and then send another broadcast 
     context.sendBroadcast(in); 

     // This is used to abort the broadcast and can be used to silently 
     // process incoming message and prevent it from further being 
     // broadcasted. Avoid this, as this is not the way to program an app. 
     this.abortBroadcast(); 
     } 
    } 
} 

Код, который я добавил эту причину этой аварии являются следующие:

private SQLiteAdapter mySQLiteAdapter; 
Message message = null; 
message = mySQLiteAdapter.createMessage(body); 

Вот код функции createMessage:

public Message createMessage(String message) { 
    String[] columns = new String[]{KEY_ID, KEY_CONTENT}; 

    ContentValues values = new ContentValues(); 
    values.put(KEY_CONTENT, message); 
    long insertId = sqLiteDatabase.insert(MYDATABASE_TABLE, null, 
    values); 
    Cursor cursor = sqLiteDatabase.query(MYDATABASE_TABLE, 
      columns, KEY_ID + " = " + insertId, null, 
    null, null, null); 
    cursor.moveToFirst(); 
    Message newMessage = cursorToMessage(cursor); 
    cursor.close(); 
    return newMessage; 
} 

Я не знаю, где ошибка родом из.

+3

Отслеживать трассировку logcat, а также метод cursorToMessage – Pragnani

+0

Прокомментируйте этот код Toast.makeText (context, body, Toast.LENGTH_LONG) .show(); , потому что вы используете Фоновый сервис, вы не можете общаться с Ui в фоновом режиме –

+0

Вы добавляете соответствующие разрешения? –

ответ

2

Похоже, что вы не создаете экземпляр mySQLiteAdapter. Перед доступом к нему необходимо создать экземпляр.

+0

Спасибо. Но после добавления желаемого кода следующим образом: mySQLiteAdapter = новый SQLiteAdapter (SmsReceiver); mySQLiteAdapter.openToRead(); '. Ошибка: «SmsReceiver не может быть разрешен переменной». – jaypabs

+0

Попробуйте SQLiteAdapter (SmsReceiver.this) или SQLiteAdapter (YourActivity) – BobTheBuilder

+1

@jaypabs использует контекст в конструкторе 'mySQLiteAdapter = новый SQLiteAdapter (контекст);' – Pragnani

0

Прокомментируйте эту строку коды,

Toast.makeText(context,body,Toast.LENGTH_LONG).show(); 

Я думаю, что это будет работать, я столкнулась с той же проблемой с работой пользовательского интерфейса на фоне услугах, пожалуйста, commnent кода, или Заменить Log.d() для регистрации информации

Смежные вопросы