SMS BroadcastReceiver 在一段时间后停止工作
SMS BroadcastReceiver stops working after sometime
我有一个应用程序,它在收到短信后会执行一些任务。我已经使用 BroadcastReceiver 实现了它。安装该应用程序后,它可以正常运行一段时间。
后来发现BroadcastReceiver的onReceive事件没有触发。为了排除故障,我重新启动了我的应用程序服务并将手机连接到 Android Studio Logcat。和之前一样,最初它检测到新的短信并且一切正常。当我在 30 分钟后发送短信时,没有触发 onReceive 事件。在 Logcat.
的 30 分钟内没有与我的应用程序相关的消息
BroadcastReceiver 服务似乎已终止。可能是什么原因。我该如何排除故障?我正在 Android 8.1.
中测试这个应用程序
下面是我的代码
清单文件
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.chickoo.whereareyou" >
<uses-permission android:name="android.permission.RECEIVE_SMS"/>
<uses-permission android:name="android.permission.SEND_SMS"/>
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app_name"
android:theme="@style/AppTheme.NoActionBar" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver
android:name="com.chickoo.whereareyou.IncomingSms"
android:enabled="true"
android:exported="true">
<intent-filter android:priority="1000">
<action android:name="android.provider.Telephony.SMS_RECEIVED" />
</intent-filter>
</receiver>
<service
android:name=".LocationUpdatesService"
android:enabled="true"
android:exported="true" />
</application>
</manifest>
广播接收器class文件
public class IncomingSms extends BroadcastReceiver {
public void onReceive(Context context, Intent intent) {
Log.i("SmsReceiver", "SMS Recd1");
final Bundle bundle = intent.getExtras();
try {
Log.i("SmsReceiver", "SMS Recd2");
if (bundle != null) {
Log.i("SmsReceiver", "SMS Recd3");
final Object[] pdusObj = (Object[]) bundle.get("pdus");
for (int i = 0; i < pdusObj.length; i++) {
SmsMessage currentMessage = SmsMessage.createFromPdu((byte[]) pdusObj[i]);
Log.i("SmsReceiver", "SMS Recd5");
String senderNum = currentMessage.getDisplayOriginatingAddress();
String message = currentMessage.getDisplayMessageBody();
Log.i("SmsReceiver", "senderNum: " + senderNum + "; message: " + message);
if (message.equals("WAY")) {
Log.i("SmsReceiver", "GPSlocn service to be stared");
Intent intent1 = new Intent(context, LocationUpdatesService.class);
intent1.putExtra("SENDNUM", senderNum);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
context.startForegroundService(intent1);
} else {
context.startService(intent1);
}
Log.i("SmsReceiver", "GPSlocn service started");
}
}
}
} catch (Exception e) {
Log.e("SmsReceiver", "Exception smsReceiver" +e);
}
}
}
问题是 EMUI、MIUI 等正在终止后台任务。将应用加入白名单后,现在可以正常使用了。
白名单只需转到 [miui 手机] 应用 >> 管理应用 >>[select 白名单应用] >> 省电 >> select“无限制”。
我有一个应用程序,它在收到短信后会执行一些任务。我已经使用 BroadcastReceiver 实现了它。安装该应用程序后,它可以正常运行一段时间。
后来发现BroadcastReceiver的onReceive事件没有触发。为了排除故障,我重新启动了我的应用程序服务并将手机连接到 Android Studio Logcat。和之前一样,最初它检测到新的短信并且一切正常。当我在 30 分钟后发送短信时,没有触发 onReceive 事件。在 Logcat.
的 30 分钟内没有与我的应用程序相关的消息BroadcastReceiver 服务似乎已终止。可能是什么原因。我该如何排除故障?我正在 Android 8.1.
中测试这个应用程序下面是我的代码
清单文件
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.chickoo.whereareyou" >
<uses-permission android:name="android.permission.RECEIVE_SMS"/>
<uses-permission android:name="android.permission.SEND_SMS"/>
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app_name"
android:theme="@style/AppTheme.NoActionBar" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver
android:name="com.chickoo.whereareyou.IncomingSms"
android:enabled="true"
android:exported="true">
<intent-filter android:priority="1000">
<action android:name="android.provider.Telephony.SMS_RECEIVED" />
</intent-filter>
</receiver>
<service
android:name=".LocationUpdatesService"
android:enabled="true"
android:exported="true" />
</application>
</manifest>
广播接收器class文件
public class IncomingSms extends BroadcastReceiver {
public void onReceive(Context context, Intent intent) {
Log.i("SmsReceiver", "SMS Recd1");
final Bundle bundle = intent.getExtras();
try {
Log.i("SmsReceiver", "SMS Recd2");
if (bundle != null) {
Log.i("SmsReceiver", "SMS Recd3");
final Object[] pdusObj = (Object[]) bundle.get("pdus");
for (int i = 0; i < pdusObj.length; i++) {
SmsMessage currentMessage = SmsMessage.createFromPdu((byte[]) pdusObj[i]);
Log.i("SmsReceiver", "SMS Recd5");
String senderNum = currentMessage.getDisplayOriginatingAddress();
String message = currentMessage.getDisplayMessageBody();
Log.i("SmsReceiver", "senderNum: " + senderNum + "; message: " + message);
if (message.equals("WAY")) {
Log.i("SmsReceiver", "GPSlocn service to be stared");
Intent intent1 = new Intent(context, LocationUpdatesService.class);
intent1.putExtra("SENDNUM", senderNum);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
context.startForegroundService(intent1);
} else {
context.startService(intent1);
}
Log.i("SmsReceiver", "GPSlocn service started");
}
}
}
} catch (Exception e) {
Log.e("SmsReceiver", "Exception smsReceiver" +e);
}
}
}
问题是 EMUI、MIUI 等正在终止后台任务。将应用加入白名单后,现在可以正常使用了。
白名单只需转到 [miui 手机] 应用 >> 管理应用 >>[select 白名单应用] >> 省电 >> select“无限制”。