BroadcastReceiver与Notification的结合使用实现短信完全自主接收

本文介绍了一种方法,即在接收到短信后,通过自定义通知的方式展示短信内容,并在用户点击通知时直接跳转至短信显示界面。具体实现包括创建短信通知、设置通知详情及点击事件响应。

本文主要实现接收到短信后,屏蔽系统Notification,自己建立所接短信的Notification,并且点击该通知,进入显示短信界面(自己设置)。

现将代码贴下

package com.lusgarden.texts.sms;

import com.lusgarden.texts.activity.R;
import com.lusgarden.texts.activity.SMSActivity;
mport android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.SmsManager;
import android.telephony.SmsMessage;
import android.widget.Toast;


public class SMSReceiver extends BroadcastReceiver {
private Context context;
public static int NOTIFICATION_ID = 21321; 
private SmsMessage[] msg = null ; 
private static final String strACT = "android.provider.Telephony.SMS_RECEIVED";
SmsManager smsMgr = SmsManager.getDefault();

public void onReceive(Context context, Intent intent) {
this.context = context;
if (intent.getAction().equals(strACT)) {
StringBuilder sb = new StringBuilder();
Bundle bundle = intent.getExtras();
if (bundle != null) {
Object[] pdus = (Object[]) bundle.get("pdus");
msg = new SmsMessage[pdus.length];
for (int i = 0; i < pdus.length; i++) {
msg[i] = SmsMessage.createFromPdu((byte[]) pdus[i]);
}
for (SmsMessage currMsg : msg) {
sb.append("From:");
sb.append(currMsg.getDisplayOriginatingAddress());
sb.append("\nMessage:");
sb.append(currMsg.getDisplayMessageBody());
}
}
abortBroadcast();
Toast.makeText(context, sb.toString(), Toast.LENGTH_LONG).show();
/**
* call an intent to start the activity DisplayMessage with variable
* message data.
*/


/*
* Intent i = new Intent(context, SMSActivity.class);
* i.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); i.putExtra("message",
* sb.toString()); context.startActivity(i);
*/
showNotification() ;
}
}
 
private void showNotification() {
NotificationManager notificationManager = (NotificationManager) context
.getSystemService(android.content.Context.NOTIFICATION_SERVICE);
Notification notification = new Notification(R.drawable.icon,
"您有新短消息,请注意查收", System.currentTimeMillis());
PendingIntent contentIntent = PendingIntent.getActivity(context, 0,
new Intent(context, SMSActivity.class), 0);
notification.setLatestEventInfo(context, msg[0].getDisplayOriginatingAddress(), 
msg[0].getDisplayMessageBody(), contentIntent);
notificationManager.notify(NOTIFICATION_ID, notification);
}
}

Android 中,当 App 被杀死后,是否能通过 `BroadcastReceiver` 接收消息,取决于广播接收器的注册方式及其所依赖的系统机制。对于结合 UDP 使用的情况,需要综合考虑广播接收器的生命周期、App 的进程状态以及网络通信的独立性。 ### BroadcastReceiver UDP 结合使用时的行为 如果 `BroadcastReceiver` 是**静态注册**的,并且其 `onReceive()` 方法中启动了用于监听 UDP 数据包的服务(如一个基于 `DatagramSocket` 的后台服务),则即使 App 被用户或系统强制杀死,该服务仍可能继续运行并接收 UDP 消息[^2]。这是因为静态注册的广播接收器可以在 App 进程被销毁后依然响应系统广播,并触发相关逻辑,例如重新启动服务。 示例代码如下: ```java public class UdpBroadcastReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { if (intent.getAction().equals("com.example.udp.START_UDP_SERVICE")) { Intent serviceIntent = new Intent(context, UdpService.class); context.startService(serviceIntent); } } } ``` 在 `AndroidManifest.xml` 中声明: ```xml <receiver android:name=".UdpBroadcastReceiver"> <intent-filter> <action android:name="com.example.udp.START_UDP_SERVICE" /> </intent-filter> </receiver> ``` 只要该服务是通过 `startService()` 或 `startForegroundService()` 启动的,并且没有被系统主动终止,它就可以持续监听 UDP 数据包,即使主 App 已被关闭。 ### 系统限制对 UDP 监听的影响 然而,部分 OEM 厂商(如华为、小米等)在其定制系统中引入了严格的后台进程管理策略,可能会阻止非白名单应用的后台服务长时间运行。这种情况下,即使广播接收器成功启动了 UDP 服务,也可能会在一段时间后被系统强制停止,从而导致无法继续接收 UDP 消息[^4]。 此外,`BroadcastReceiver` 的 `onReceive()` 方法执行时间不应超过 10 秒,否则会触发 ANR(Application Not Responding)异常。因此,在广播接收器中启动 UDP 监听任务时,应避免直接进行耗时操作,而是将实际工作交给 Service 或线程处理[^1]。 ### 动态注册的 BroadcastReceiver 无法持久化 若 `BroadcastReceiver` 是**动态注册**的,则一旦 App 被杀死,其注册的广播接收器也随之失效,UDP 服务也将随之终止。这意味着在这种模式下,App 被杀死后将无法继续接收 UDP 消息[^2]。 ### 总结 综上所述,`BroadcastReceiver` UDP 结合使用时,能否在 App 被杀死后继续接收消息,主要取决于以下因素: - 广播接收器是否为静态注册; - 是否通过广播接收器启动了一个持久化的后台服务; - 手机厂商是否允许该服务长期运行于后台; - `onReceive()` 方法是否合理地调度任务而非直接执行耗时操作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值