发送多部分短信,并在收到短信时检查发送(导致接收方不能接受)

时间:2014-01-02 21:38:52

标签: android sms broadcastreceiver

我提供以下代码,以便发送多部分短信并检查发送以回复发件人:
ExecuteCommandBroadCastReciver接收传入短信并最终回复发件人一个短信使用size >160字符并检查所有部分的已发送和交付状态

   public class ExecuteCommand extends BroadcastReceiver {
        @Override
        public void onReceive(Context context, Intent intent) {
            // TODO Auto-generated method stub
            ... 
            SendSMS s=new SendSMS(context);
            s.SendMultipartSMS(MsgBody,Number);
    }

和类SendSMS proivde BroadcastReceiver用于发送Intent以确定发送和传递的状态:

public class SendSMS {
    Context smscontext;
    private SmsManager smsManager;
    private BroadcastReceiver sentReceiver;
    int msgParts;

    public SendSMS(Context context) {
    smscontext = context;
}

public void SendMultipartSMS(String smsResult, String OriginatingAddress) {
    smsManager = SmsManager.getDefault();
    ArrayList<String> parts = smsManager.divideMessage(smsResult);
    msgParts = parts.size();
    final String SendNumber=OriginatingAddress;
    sentReceiver = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {

            boolean anyError = false;
            switch (getResultCode()) {
            case Activity.RESULT_OK:
                break;
            case SmsManager.RESULT_ERROR_GENERIC_FAILURE:
            case SmsManager.RESULT_ERROR_NO_SERVICE:
            case SmsManager.RESULT_ERROR_NULL_PDU:
            case SmsManager.RESULT_ERROR_RADIO_OFF:
                anyError = true;
                break;
            }
            msgParts--;
            if (msgParts == 0) {
                context.unregisterReceiver(sentReceiver);
                Log.d("smsresiver", "send ok");

                if (anyError) {
                    Toast.makeText(context, "sending sms fail",
                            Toast.LENGTH_SHORT).show();
                    } 
            }
        }
    };
    smscontext.registerReceiver(sentReceiver, new IntentFilter(
            "CTS_SMS_SEND_ACTION"));
       Intent mSendIntent = new Intent("CTS_SMS_SEND_ACTION");


    ArrayList<PendingIntent> sentIntents = new ArrayList<PendingIntent>();


    for (int i = 0; i < parts.size(); i++) {
        sentIntents.add(PendingIntent.getBroadcast(smscontext, 0, mSendIntent,
                0));
    }
    smsManager.sendMultipartTextMessage(
            OriginatingAddress, null, parts,
            sentIntents, null);
}

} 最后短信收到正确但发送回复短信卡receivercallnotallowedexception我认为这是由sentReceiver动态registerReceivering引起的

1 个答案:

答案 0 :(得分:2)

我的猜测是真的,问题是在另一个BroadcastReceiver(这里是ExecuteCommand)中注册新的Intent会导致receivercallnotallowedexception我将此问题解决为:

public class ExecuteCommand extends BroadcastReceiver {
       public void onReceive(Context context, Intent intent) {
                // TODO Auto-generated method stub
                if (intent.getAction()
                    .equals("android.provider.Telephony.SMS_RECEIVED")) {
                        //provide sending SMS in reply to send
                     }
                     else if (intent.getAction().equals("CTS_SMS_SEND_ACTION")) {
                        //check send and delivery of each SMS part  
                     }