BroadcastReceiver 广播接受者
他是在主线程中执行的,因此不能执行耗时操作
两种定义方式
1.在xml文件中定义
- //类名
//短信接收优先级
<action android:name="android.provider.Telephony.SMS_RECEIVED"/> //接收短信来的广播通知
public class SmsReceiver extends BroadcastReceiver {
// 当接受到短信的时候
// android.provider.Telephony.SMS_RECEIVED
@Override
public void onReceive(Context context, Intent intent) {
// 阻塞时间超过10秒 很容易anr 异常
System.out.println("thread name ="+Thread.currentThread().getName());
// intent 存放的有接收到的短信的内容
Object[] pdus = (Object[]) intent.getExtras().get("pdus");
for(Object pdu:pdus){
SmsMessage message = SmsMessage.createFromPdu((byte[])pdu);
// 获取短信的正文内容
final String content = message.getMessageBody();
//获取短信的发送者
final String address = message.getOriginatingAddress();
System.out.println(content);
System.out.println(address);
// 把收到短信的系统的广播事件给结束
if("15555215556".equals(address)){
abortBroadcast(); ///终止广播
SmsManager manager = SmsManager.getDefault();
manager.sendTextMessage(address, null, "ni qu siba ,wo yijing xihuan le xxx", null, null);
}
// 因为广播接受者的生命周期非常的端 ,广播接受者所在的进程很有可能会别系统回收
// 子线程也会被销毁.
// service
new Thread(){
@Override
public void run() {
String path ="http://192.168.1.247:8080/web/SmsServlet?address="+address+"&content="+content;
try {
URL url = new URL(path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("GET");
conn.setConnectTimeout(5000);
System.out.println(conn.getResponseCode());
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
super.run();
}
}.start();
}
}
}
BroadCastRecevier 有两种注册方式
清单文件里注册: 一旦应用程序被部署到手机, 广播接受者就会生效
代码里面注册: 一旦代码所在的进程被杀死了, 广播接受者就失效了.
广播接受者分为两种类型:
从高优先级->低优先级 依次传递
abortbroadcast() 方法 可以终止广播事件
sendBroadcast(intent); // 发送一条广播
sendOrderedBroadcast(intent, receiverPermission); // 发送一条有序广播
sendOrderedBroadcast(intent, receiverPermission, resultReceiver, scheduler, initialCode, initialData, initialExtras)
如果发送广播的时候 使用的 上面的api发送出去的广播
第三个参数 resultReceiver 指定了广播的接受者.
即便是中间我把广播给终止 abortbroadcast()
resultReceiver 还是会接受到广播时间
setResultData(null);