【问题标题】:SMS_RECEIVED not working on Ice Cream Sandwich?SMS_RECEIVED 不能在冰淇淋三明治上工作?
【发布时间】:2012-01-09 08:05:42
【问题描述】:

我正在尝试使用 android.provider.Telephony.SMS_RECEIVED 来捕获传入的短信。

我构建了一个简单的应用程序,可以在 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());
    }
}

【问题讨论】:

  • 你用的是真机还是模拟器?
  • @rekire 都在 4.0 上。还尝试了 2.3 中的模拟器,并且有效。
  • 我已将接收器名称更改为一个不存在的类,但它仍然什么也不做(logcat 中没有错误)。所以我认为它甚至没有走那么远。所以要么它没有触发那个意图(不太可能),要么它没有使用我的应用程序(可能)
  • 没关系,我没看到马特说的和我说的基本一样...stackoverflow.com/a/8421369/520186
  • 看看这个答案。应该能解决你的问题。 stackoverflow.com/questions/7349173/…

标签: android sms android-intent android-4.0-ice-cream-sandwich


【解决方案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);
   }
}

我不能保证这会奏效,但我相信它会解决一些问题。如果您对事物有任何疑问,请在 cmets 中提问。我相信你说它甚至没有被调用是正确的,因为你的接收器没有注册任何东西。如果您希望它在后台运行,请考虑使用服务。我真的希望这对您的努力有所帮助并祝您好运!

【讨论】:

  • 谢谢马特,就是这样。抱歉,您没有得到赏金,直到它过期后才检查(其他承诺)
  • 一切都好,有趣的是,生活不仅仅是编程:0)
  • 静态注册的Receiver不需要动态注册。 This post@Gaurav 在上面的 cmets 中链接描述了这种情况下的实际问题。
【解决方案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"&lt;receiver android:name=".MyFirstApp"&gt;。这意味着您的接收者的全名是com.giggsey.MyFirstApp.MyFirstApp,但我相信它只是com.giggsey.MyFirstApp

    在您的清单中将com.giggsey.MyFirstAppcom.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());
        }
    }
    

    【讨论】:

    • 尝试使用 com.giggsey 作为包和完整路径(接收器中的 com.giggsey.MyFirstApp.MyFirstApp,但都不起作用:(
    【解决方案4】:

    如果你在背景中尝试“catch”,你可以看到this post

    "android.provider.Telephony.SMS_RECEIVED"Service 中工作得很好。否则只有在活动生命周期中你才能“抓住”它

    【讨论】:

    • 对不起,应该是具体的。 “否则只有在活动生命周期中你才能“抓住”它”——这部分是不正确的。只要注册组件在接收时处于活动状态,动态注册接收器就可以工作。但是,Receiver 不需要动态注册。在清单中静态注册它是有效的。在这种情况下的问题在@Gaurav 在他们对问题的评论中链接的this post 中进行了描述。
    • 没有。您的链接没有描述我的问题和解决方案。静态清单接收器不起作用。
    • “静态清单接收器不工作。” - 对不起,那不是真的。此外,无论您如何解决您的具体问题,在这种情况下,都是应用程序处于停止状态导致接收器无法工作。 OP 需要一个 Activity 在安装后至少运行一次以启用静态注册的接收器。
    • 我编辑了答案,所以只有有这个问题的人,使用它。感谢您的反馈
    • 您是说静态注册的接收器在 Lollipop 中不起作用吗?这也不是真的。甚至平台 SMS 应用程序也会注册其接收者in the manifest
    【解决方案5】:

    这可能对你有帮助..试试这个..在广播接收器类中

     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();
      }
      

      【讨论】:

      • Toast 调试,Android 开发的杀手锏
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2012-05-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-01-28
      • 2012-03-11
      • 2014-03-26
      相关资源
      最近更新 更多