Подтвердить что ты не робот

SMS_RECEIVED не работает над сэндвичем с мороженым?

Я пытаюсь использовать android.provider.Telephony.SMS_RECEIVED, чтобы поймать входящие SMS.

Я создал простое приложение, которое работает на 2.x, но когда я пытаюсь использовать его на эмуляторе или устройстве 4.0, он не работает.

Любые идеи?

манифеста:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.giggsey.MyFirstApp" android:versionCode="1"
android:versionName="1.0">
<application android:icon="@drawable/ic_launcher" android:label="@string/app_name">


    <receiver android:name=".MyFirstApp">
        <intent-filter>
            <action android:name="android.provider.Telephony.SMS_RECEIVED"></action>
        </intent-filter>
    </receiver>
</application>
<uses-sdk android:minSdkVersion="9" />


<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<uses-permission android:name="android.permission.RECEIVE_SMS"></uses-permission>
</manifest>

MyFirstApp.java

public class MyFirstApp extends BroadcastReceiver {

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

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

Ответ 1

Убедитесь, что вы фактически создаете и регистрируете получателя в Activity или Service, иначе он не будет вызван (я считаю).

Очень простой пример:

public class MyActivity extends Activity {

    private BroadcastReceiver receiver;

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        IntentFilter filter = new IntentFilter();
        filter.addAction("android.provider.Telephony.SMS_RECEIVED");
        //Extends BroadcastReceiver
        receiver = new MyFirstApp();
        registerReceiver(receiver,filter);
    }


   //Also, to save headaches later
   @Override
   protected void onDestroy() {
        unregisterReceiver(receiver);
   }
}

Я не могу обещать, что это сработает, но я верю, что это исправит некоторые вещи. Если у вас есть вопросы о вещах, просто спросите в комментариях. Я считаю, что вы правильно говорите, что его даже не звонят, потому что ваш получатель ни на что не зарегистрирован. Если вы хотите, чтобы он работал в фоновом режиме, подумайте об использовании службы. Я действительно надеюсь, что это поможет и удачи в ваших усилиях!

Ответ 2

Вам просто нужно экспортировать значение true для приемника.

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

Ответ 3

Я думаю, ваша ошибка в том, что вы используете имя класса в имени своего пакета.

В вашем манифесте вы написали package="com.giggsey.MyFirstApp", а также <receiver android:name=".MyFirstApp"> в своем приемнике. Это означает, что полное имя вашего ресивера com.giggsey.MyFirstApp.MyFirstApp, но я считаю, что это просто com.giggsey.MyFirstApp.

Exchange com.giggsey.MyFirstApp в вашем манифесте с com.giggsey, который будет работать, если я прав.

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
         package="com.giggsey" android:versionCode="1" android:versionName="1.0">
[...]

А также это:

package com.giggsey;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.util.Log;

public class MyFirstApp extends BroadcastReceiver {
    private static final String TAG = "MyFirstApp";

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

Ответ 4

если вы попробуете "поймать" в backgroung, вы можете увидеть этот пост.

"android.provider.Telephony.SMS_RECEIVED" отлично работает с Сервис. иначе только во время жизненного цикла деятельности вы можете "поймать" его

Ответ 5

Это может помочь вам... попробуйте это.. В классе приемника brodcast

 public static final String SMS_BUNDLE = "pdus";


public void onReceive(Context context, Intent intent)
{

     Bundle intentExtras = intent.getExtras();
        if (intentExtras != null) {
            Object[] sms = (Object[]) intentExtras.get(SMS_BUNDLE);
            String smsMessageStr = "";
            for (int i = 0; i < sms.length; ++i) {
                SmsMessage smsMessage = SmsMessage.createFromPdu((byte[]) sms[i]);

                smsBody = smsMessage.getMessageBody().toString();
                address = smsMessage.getOriginatingAddress();

                smsMessageStr += "SMS From: " + address + "\n";
                smsMessageStr += smsBody + "\n";
            }
            Toast.makeText(context, smsMessageStr, Toast.LENGTH_SHORT).show();
    }

Ответ 6

в поле "Принять", пожалуйста, попробуйте добавить следующую строку

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

if (intent.getAction() == SMS_RECEIVED) {
    //any action you want here..
    Toast.makeText(MyClass.this, "SMS RECEIVED",Toast.LENGTH_LONG).show();
}