Android - приемник SMS-вещания

Я пытаюсь получить эту программу, но до сих пор не повезло. Я не могу найти, где я поступаю неправильно. Я не уверен, что что-то не так с кодом или отладки.

Я пытаюсь получить уведомление о появлении нового SMS-сообщения.

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

package Technicaljar.SMSBroadcastReceiver;

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> 

Я отправляю SMS через Telnet, и я не вижу никаких сообщений о намерениях в logcat. Вот мой logcat с момента установки.

D/AndroidRuntime(  478): 
D/AndroidRuntime(  478): >>>>>>>>>>>>>> AndroidRuntime START <<<<<<<<<<<<<<
D/AndroidRuntime(  478): CheckJNI is ON
D/AndroidRuntime(  478): --- registering native functions ---
D/AndroidRuntime(  478): Shutting down VM
D/dalvikvm(  478): Debugger has detached; object registry had 1 entries
I/AndroidRuntime(  478): NOTE: attach of thread 'Binder Thread #3' failed
D/Mms:app (  220): getSmsNewMessageNotificationInfo: count=14, first addr=12345, thread_id=4
D/dalvikvm(  151): GC_EXPLICIT freed 391 objects / 22552 bytes in 65ms
D/dalvikvm(  220): GC_EXPLICIT freed 926 objects / 44840 bytes in 73ms

Итак, SMS, похоже, получен эмулятором, но похоже, что никакие намерения не срабатывают. Что я здесь делаю неправильно? После установки мне нужно как-то "запустить" этот ресивер? Потому что когда я устанавливаю, я получаю

 [2010-11-07 21:24:41 - SMSBroadcastReceiver] No Launcher activity found!
[2010-11-07 21:24:41 - SMSBroadcastReceiver] The launch will only sync the application package on the device!

Так что мне интересно, если что-то не так.

Ответ 1

android.provider.Telephony.SMS_RECEIVED имеет капитал T, а ваш в манифесте нет.

Обратите внимание, что это действие Intent не документировано.

Ответ 2

Я попробовал ваш код и нашел, что он не работает.

Мне пришлось изменить

if (intent.getAction() == SMS_RECEIVED) {

to

if (intent.getAction().equals(SMS_RECEIVED)) {

Теперь он работает. Это просто проблема с проверкой соответствия Java.

Ответ 3

intent.getAction().equals(SMS_RECEIVED)

Я пробовал это успешно.

Ответ 4

одна важная вещь, которую следует упомянуть в этом потоке, - описание aboud pdu
PDU - это блок "для описания протокола" , который является отраслевым форматом для SMS-сообщения. потому что SMSMessage читает/записывает их, вам не нужно их анализировать.
 Большое сообщение может быть разбито на многие, поэтому он представляет собой массив объектов.

Ответ 5

Также обратите внимание, что приложение Hangouts в настоящее время блокирует мой BroadcastReceiver от получения SMS-сообщений. Мне пришлось отключить функциональность SMS в приложении Hangouts (Настройки- > SMS- > Включить SMS-сообщение), прежде чем мой SMS BroadcastReceived начнет увольняться.

Изменить: Похоже, что некоторые приложения будут прерватьBroadcast() в намерении, которое не позволит другим приложениям получать намерение. Решение состоит в том, чтобы увеличить атрибут android:priority в теге intent-filter:

    <receiver android:name="com.company.application.SMSBroadcastReceiver" >
        <intent-filter android:priority="500">
            <action android:name="android.provider.Telephony.SMS_RECEIVED" />
        </intent-filter>
    </receiver>

Подробнее см. здесь: Включение поддержки SMS в Hangouts 2.0 нарушает BroadcastReceiver SMS_RECEIVED в моем приложении

Ответ 6

Наткнулся на это сегодня. Для тех, кто сейчас кодирует приемник SMS, используйте этот код вместо устаревшего в OP:

    SmsMessage[] msgs = Telephony.Sms.Intents.getMessagesFromIntent(intent);
    SmsMessage smsMessage = msgs[0];

Ответ 7

Для android 19+ вы можете получить его в Telephony.Sms.Intents.SMS_RECEIVED_ACTION). В классе Intent есть больше, что стоит посмотреть в

Ответ 8

android.provider.telephony.SMS_RECEIVED неверен, потому что Telephony является классом, и он должен быть капиталом, как в android.provider.telephony.SMS_RECEIVED

Ответ 9

Ваш широковещательный приемник должен указать android:exported="true" для приема трансляций, созданных вне вашего собственного приложения. Мой вещательный приемник определен в манифесте следующим образом:

<receiver
    android:name=".IncomingSmsBroadcastReceiver"
    android:enabled="true"
    android:exported="true" >
    <intent-filter>
        <action android:name="android.provider.Telephony.SMS_RECEIVED" />
    </intent-filter>
</receiver>

Как указано ниже, exported = "true" является значением по умолчанию, поэтому вы можете опустить эту строку. Я оставил его, чтобы комментарии обсуждения имели смысл.