SMS BroadcastReceiver在一段时间后停止工作 [英] SMS BroadcastReceiver stops working after sometime

查看:64
本文介绍了SMS BroadcastReceiver在一段时间后停止工作的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个应用程序,一旦收到短信,它就会执行一些任务。我已经使用BroadcastReceiver实现了它。安装该应用程序后,它会在一段时间内正常工作。

I have an app which does some task once it receives a SMS. I have implemented it using BroadcastReceiver. After installing the app, it works fine for sometime.

此后,我注意到BroadcastReceiver的onReceive事件未触发。为了进行故障排除,我重新启动了我的应用程序服务,并将移动设备连接到Android Studio Logcat。如前所述,最初它检测到新的SMS,并且一切正常。 30分钟后我发送短信时,未触发onReceive事件。在Logcat的30分钟内,没有与我的应用相关的消息。

Afterwards, I notice that onReceive event of BroadcastReceiver is not triggered. To troubleshoot, I restarted my app service and connected the mobile to Android Studio Logcat. As earlier, initially it detected new SMS and everything worked fine. When I sent SMS after 30 mins, onReceive event was not triggered. There was no messages related to my app during that 30 mins in Logcat.

看起来像BroadcastReceiver服务被杀死了。可能是什么原因。我该如何解决?我正在Android 8.1中测试此应用。

Looks like BroadcastReceiver service is killed. What could be the reason. How can I troubleshoot? I am testing this app in 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>

广播接收器类文件

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等正在杀死后台任务。将应用列入白名单后,现在可以正常使用了。

The issue was the the EMUI, MIUI etc were killing the background tasks. After whitelisting the app, it works fine now.

这篇关于SMS BroadcastReceiver在一段时间后停止工作的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆