这次,实现在程序当中注册,而不是在Manifest中注册。因为,在Manifest中注册,监听器就会一直出于监听状态,而有些程序中的是不需要监听器一直处于监听状态的。在程序中注册,可以实现程序运行时,监听器运行,程序关闭后,监听器不再监听。
这次又被坑爹都是,我想着不用去Manifest注册了吧。。。好么,监听器不用注册了,可是居然要去注册发短信的权限。。。为了这个疏忽苦苦调了很久。。。。纠结。。。
两个按钮,一个绑定监听器,一个解绑监听器。绑定后,如果手机收到短消息,则会触发监听器的相关操作。解绑后,手机收到短消息不再会触发监听器的操作。
1.我先注册。。。
<uses-permission android:name="android.permission.RECEIVE_SMS"></uses-permission>
2.在包里新建一个SMSReceiver.java文件,在手机收到短消息后,它会收到消息,进行一些操作。。复写它的onReceive方法
@Override
public void onReceive(Context context, Intent intent) {
System.out.println("receive message");
//接受Intent对象当中的数据
Bundle bundle = intent.getExtras();
//在Bundle对象当中有一个属性名为pdus,这个属性的值是一个Object数组
Object[] myOBJpdus = (Object[]) bundle.get("pdus");
//创建一个SmsMessage类型的数组
SmsMessage[] messages = new SmsMessage[myOBJpdus.length];
System.out.println(messages.length);
for (int i = 0; i<myOBJpdus.length; i++)
{
//使用Object数组当中的对象创建SmsMessage对象
messages[i] = SmsMessage.createFromPdu((byte[]) myOBJpdus[i]);
//调用SmsMessage对象的getDisppalyMessageBody()方法,就可以得到消息的内容
System.out.println(messages[i].getDisplayMessageBody());
}
try {
Thread.sleep(30 * 1000);
System.out.println("-------------------------------");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
3.RegisterReceiverListener中实现以下操作。
复写onClick方法。
public void onClick(View v) {
//生成一个BroiadcastReceiver对象
smsReceiver = new SMSReceiver();
//生成一个IntentFilter对象
IntentFilter filter = new IntentFilter();
//为IntentFilter添加一个Action
filter.addAction(SMS_ACTION);
//将BroadcastReceiver对象注册到系统当中
BCActivity22.this.registerReceiver(smsReceiver, filter);
}

代码