Приемник SMS Broadcast работает в режиме отладки только с эмулятором - PullRequest
3 голосов
/ 25 декабря 2011

У меня есть приложение, которое пытается перехватить SMS-сообщения от определенного отправителя, а затем начинает новое действие. При работе в Eclipse с использованием Debug As и использованием эмулятора моего BroadcastReceiver он отлично работает, он достигает ожидаемых точек останова. Когда я использую «Запуск от имени» в Eclipse для запуска в эмуляторе, SMS-сообщения никогда не перехватываются. Похоже, что BroadcastReceiver никогда не вызывается из-за отсутствия выходов журнала. СМС также не попадают при запуске на моем телефоне. Есть идеи, почему это работает так, а не иначе?

У меня очень мало приложений на телефоне, и я знаю только одно приложение, которое ловит текстовые сообщения - это встроенное приложение для обмена сообщениями.

<receiver android:name=".sms.ConfirmationResponder">
  <intent-filter android:priority="100">
    <action android:name="android.provider.Telephony.SMS_RECEIVED" />
  </intent-filter>
</receiver>

...

<uses-permission android:name="android.permission.READ_SMS" />
<uses-permission android:name="android.permission.WRITE_SMS" />
<uses-permission android:name="android.permission.SEND_SMS" />
<uses-permission android:name="android.permission.RECEIVE_SMS" />

Приемник:

public class ConfirmationResponder extends BroadcastReceiver
{
    @Override
    public void onReceive(Context context, Intent intent)
    {
        Log.i("SMS", "############################ Confirmation being read");
        // More stuff after this but I don't even get the log message
    }
}

Ответы [ 2 ]

2 голосов
/ 11 января 2012

Вот моя программа:

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.SmsMessage;
import android.util.Log;

public class SMSBroadcastReceiver extends BroadcastReceiver {

        private static final String SMS_RECEIVED = "android.provider.Telephony.SMS_RECEIVED";
        private static final String TAG = "SMSBroadcastReceiver";

        @Override
        public void onReceive(Context context, Intent intent) {
             Log.i(TAG, "Intent recieved: " + intent.getAction());

                if (intent.getAction() == SMS_RECEIVED) {
                    Bundle bundle = intent.getExtras();
                    if (bundle != null) {
                        Object[] pdus = (Object[])bundle.get("pdus");
                        final SmsMessage[] messages = new SmsMessage[pdus.length];
                        for (int i = 0; i < pdus.length; i++) {
                            messages[i] = SmsMessage.createFromPdu((byte[])pdus[i]);
                        }
                        if (messages.length > -1) {
                            Log.i(TAG, "Message recieved: " + messages[0].getMessageBody());
                        }
                    }
                }
           }
    }

И файл манифеста:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="Technicaljar.SMSBroadcastReceiver"
      android:versionCode="1"
      android:versionName="1.0">
    <application android:icon="@drawable/icon" android:label="@string/app_name" android:debuggable="true" >
        <receiver android:name=".SMSBroadcastReceiver">
            <intent-filter>
                <action android:name="android.provider.Telephony.SMS_RECEIVED"></action>
            </intent-filter>
        </receiver>

    </application>
    <uses-sdk android:minSdkVersion="7" />
    <uses-permission android:name="android.permission.INTERNET"></uses-permission>
    <uses-permission android:name="android.permission.RECEIVE_SMS"></uses-permission>
</manifest> 

Надеюсь, это поможет

0 голосов
/ 11 января 2012

Я думаю, что это работает, но затмение не подключено к устройству в режиме «Запуск от имени» и не отображает информацию logcat.

...