【问题标题】:SMS_RECEIVED onReceive android 2.3.5 not triggeringSMS_RECEIVED onReceive android 2.3.5 未触发
【发布时间】:2012-01-10 12:12:56
【问题描述】:

我最近一直对这个问题感到困惑,在 2.3.5 之前,这似乎工作正常(在我同事的设备上)。但是在我的身上,它现在永远不会触发。

我已经剥离了代码并制作了一个非常简单的测试应用程序来查看发生了什么。基本上 onReceive 代码似乎永远不会触发,即使 adb/logcat 似乎确实显示了 BroadcastReveiver 的寄存器确实发生了。

这是我已经使用的简单代码:

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

<uses-sdk android:minSdkVersion="9" />

<application
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name" >
    <activity
        android:label="@string/app_name"
        android:name=".TestSMSReceiveActivity" >
        <intent-filter >
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <receiver android:name=".mysmstestcall">
    <intent-filter>
        <action android:name="android.provider.Telephony.SMS_RECEIVED"></action>
    </intent-filter>
</receiver>
</application>
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<uses-permission android:name="android.permission.RECEIVE_SMS"></uses-permission>
</manifest>

然后:

package com.broadcasttech.testsmsreceive;

import android.app.Activity;
import android.content.BroadcastReceiver;
import android.content.IntentFilter;
import android.os.Bundle;
import android.util.Log;

public class TestSMSReceiveActivity extends Activity {
private BroadcastReceiver receiver;
private static final String TAG = "TestSMSApp";

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    Log.i(TAG, " App has started up");
    IntentFilter filter = new IntentFilter();
    filter.addAction("android.provider.Telephony.SMS_RECEIVED");
    Log.i(TAG, " Filter SMS_RECEIVED has been added");
    //Extends BroadcastReceiver
    receiver = new mysmstestcall();
    registerReceiver(receiver,filter);
    Log.i(TAG, " registerReceiver sorted");
}

//Also, to save headaches later
@Override
protected void onDestroy() {
  Log.i(TAG, " unregistering Receiver");
  unregisterReceiver(receiver);
  Log.i(TAG, " done");
}
}

最后

package com.broadcasttech.testsmsreceive;

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

public class mysmstestcall extends BroadcastReceiver {

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

@Override
public void onReceive(Context context, Intent intent) {
     Log.i(TAG, "Intent recieved: " + intent.getAction());
     if (intent.getAction() == SMS_RECEIVED) {
         //any action you want here..
         Log.i(TAG, "SMS received has triggered");
     }
}
}

所以这是一个相当简单的应用程序,应该只记录并告诉我何时触发 BroadcastReceiver,但它根本不会触发。

任何人都可以提出什么问题吗?我检查了各种教程,检查了我知道 IceCreamSandwich 是不同的,但也尝试合并这些修复程序,这也没有任何区别。

提前致谢!

【问题讨论】:

  • 您的清单缺少捕获 SMS 接收广播所需的 uses-permission。除此之外,您是否从 Android Market(或其他地方)安装了任何 SMS 应用程序 - 其中一些会阻止其他应用程序(只是为了大便和咯咯笑)通过在非常高的优先级并取消广播意图。
  • 糟糕,那是编辑删除使用权限。我已经纠正了这一点,感谢您的提醒(我的应用程序确实有它,所以这不是关键)。但是,我确实安装了“Handcent SMS”,所以我想知道这是否可以进行有序广播。有没有办法解决这个问题?
  • 卸载 Handcent 并再次测试。如果 Handcent SMS 的开发人员正在做愚蠢和不负责任的事情,则注册是先到先得(在两个接收者注册相同优先级的情况下 - 如果我没记错的话)。如果出现这种情况,您始终可以在您的应用程序中显示用户安装了可能干扰此应用程序运行的恶意软件(即 Handcent)的警告。
  • 应用程序不太可能更改系统级广播的顺序。它无法模仿它,因此它无法改变它。系统级广播受到保护,无法复制。如果一个应用程序可以阻止另一个应用程序接收广播,那么在框架中这将是一个巨大的问题,而且很可能并非如此。
  • 您在 Jens 上一针见血。我没有卸载 Handcent(现在我想起来了,我还有一些其他的通过 SMS 的远程控制软件也可以做到这一点)。所以我只是将我的应用更改为使用: 果然,它运行良好。

标签: java android broadcastreceiver telephony android-2.3-gingerbread


【解决方案1】:

主要问题是“mysmstestcall”中的这一行是错误的:

if (intent.getAction() == SMS_RECEIVED)

应该改成这样:

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

【讨论】:

    【解决方案2】:

    您有两个接收器是有原因的吗?你有一个程序化监听器,你有一个XML监听器

    程序化

    filter.addAction("android.provider.Telephony.SMS_RECEIVED");
    Log.i(TAG, " Filter SMS_RECEIVED has been added");
    //Extends BroadcastReceiver
    receiver = new mysmstestcall();
    

    XML 监听器

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

    你确定要这两个吗?如果您有两个,您将收到相同的广播 2 次...

    至于我看到的另一个ISSUE就是这一行

    if (intent.getAction() == SMS_RECEIVED)
    

    在比较字符串时,您不要像这样比较它们,您会得到这样的结果:

    if (intent.getAction().equalsIgnoreCase(SMS_RECEIVED))
    

    【讨论】:

    • 这是因为在较新的操作系统发布(IceCreamSandwich)等中,建议这样做。 AFAIK 它不会两次注册同一个实体,因此不会引起两次警报。
    【解决方案3】:

    我有过一次。可能是网络的问题。这些是我的question and answer。您可以添加发送意图并捕获结果代码。就我而言,它是RESULT_ERROR_GENERIC_FAILURE。我试图找到其他解决方案几个月但没有运气,所以我接受了,即使我不想:-(

    【讨论】:

      【解决方案4】:
      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 SmsBroadcastReceiver extends BroadcastReceiver{
          public static final String SMS_BUNDLE = "pdus";
          @Override
          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]);
      
                      String smsBody = smsMessage.getMessageBody().toString();
                      String address = smsMessage.getOriginatingAddress();
      
                      smsMessageStr += "SMS From: " + address + "\n";
                      smsMessageStr += smsBody + "\n";
                  }
                  Toast.makeText(context, "A new message is added to the SMS List!!!\n"+smsMessageStr, Toast.LENGTH_SHORT).show();
      
                  //this will update the UI with message
                  InboxMain inst = InboxMain.instance();
                  inst.updateList(smsMessageStr);
      
          }
      
      }
      }
      
      
      manifest::
      <receiver android:name=".SmsBroadcastReceiver" android:permission="android.permission.BROADCAST_SMS" android:exported="true">
          <intent-filter android:priority="2147483647" >
              <action android:name="android.provider.Telephony.SMS_RECEIVED" />
          </intent-filter>
       </receiver>
      
      permission::
      <uses-permission android:name="android.permission.SEND_SMS"></uses-permission>
      <uses-permission android:name="android.permission.RECEIVE_SMS"></uses-permission>
      <uses-permission android:name="android.permission.VIBRATE"/>
      <uses-permission android:name="android.permission.WRITE_SMS" />
          <uses-permission android:name="android.permission.READ_SMS" />
          <uses-permission android:name="android.permission.RECEIVE_SMS" />
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多