【发布时间】:2014-03-31 15:47:39
【问题描述】:
我确定我一定只是遗漏了一些明显的东西,但这目前让我感到困惑。
我有一个扩展 BroadcastReceiver 的类,该类被设置为清单中的接收器,它确实正确捕获了接收到的短信意图。
package gull.sana.textit;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.SmsMessage;
import android.util.Log;
import android.widget.Toast;
public class SMSReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Log.d("SMSReceiver", "Intent received");
//---get the SMS message passed in---
Bundle bundle = intent.getExtras();
SmsMessage[] msgs = null;
String str = "";
if (bundle != null)
{
//---retrieve the SMS message received---
Object[] pdus = (Object[]) bundle.get("pdus");
msgs = new SmsMessage[pdus.length];
for (int i=0; i<msgs.length; i++){
msgs[i] = SmsMessage.createFromPdu((byte[])pdus[i]);
str += "SMS from " + msgs[i].getOriginatingAddress();
str += " :";
str += msgs[i].getMessageBody().toString();
str += "\n";
}
Log.d("SMS", str);
//---display the new SMS message---
Toast.makeText(context, str, Toast.LENGTH_SHORT).show();
}
}
}
现在,当我发送 SMS 消息时,我总是会收到第一条日志消息 Log.d("SMSReceiver", "Intent received");,并且我总是会收到 Toast,正如我所期望的那样,但是,我从来没有收到过 Log.d("SMS", str); p>
我做错了吗?为什么 Toast 出现了,而之前一行的日志却没有出现?
【问题讨论】:
-
您看到
Log语句中的任何一个吗?你确定它不存在吗?您是否从错误的设备中提取日志文件? -
您确定您没有过滤“SMSReceiver”而不仅仅是“SMS”吗?
-
是的,它绝对是正确的(而且只有安卓设备),我总是收到第一条日志消息,但从来没有第二条。肯定会输入 if 语句,因为 Toast 也总是出现。
-
我没有在 logcat 上设置过滤器,因为我可以看到来自手机的所有其他日志消息。
-
清理,再次编译,Log.d("SMSReceiver", str);并运行。如果不将此标记为我最喜欢的问题以查看答案:D