API 28: BroadcastReceiver onReceive никогда не выполняется - PullRequest
0 голосов
/ 28 октября 2019

Мой onReceive никогда не выполняется. Я попробовал следующие руководства онлайн, в том числе с официального сайта. Я тестирую на виртуальном устройстве API 28. Я понимаю, что часть кода, связанного с GUI, может быть неправильной, но я должен по крайней мере получить правильный вывод журнала? Чего мне не хватает?

Манифест:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.example.receivesms">

<uses-permission android:name="android.permission.RECEIVE_SMS" />
<uses-permission android:name="android.permission.READ_SMS" />

<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:roundIcon="@mipmap/ic_launcher_round"
    android:supportsRtl="true"
    android:theme="@style/AppTheme"
    tools:ignore="GoogleAppIndexingWarning">

    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    <receiver
        android:name=".SMSReceiver"
        android:enabled="true"
        android:exported="true"
        android:permission="android.permission.BROADCAST_SMS">
        <intent-filter android:priority="100">
            <action android:name="android.provider.Telephony.SMS_RECEIVED" />
        </intent-filter>
    </receiver>
</application>

Приемник, первый Log.D даже не выполняет:

 public class SMSReceiver extends BroadcastReceiver {

    @Override
    public void onReceive(Context context, Intent intent) {
        Log.d("MESS", intent.getAction());
        Bundle bundle = intent.getExtras();
        if (bundle != null) {
            SmsMessage[] msgs;
            String message;
            Object[] pdus = (Object[]) bundle.get("pdus");
            msgs = new SmsMessage[pdus.length];
            for (int i=0; i<msgs.length;i++) {
                msgs[i] = SmsMessage.createFromPdu((byte[]) pdus[i], bundle.getString("format"));
                message = msgs[i].getMessageBody();
                Log.d("MESS", message);
                ((EditText) LayoutInflater.from(context).inflate(R.layout.activity_main, null)
                        .findViewById(R.id.editText)).append(msgs[i].getDisplayOriginatingAddress()
                        + "\n" + message + "\n");
            }
            abortBroadcast();
        }
    }
}

Основное:

 public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        requestSmsPermission();
    }

    private void requestSmsPermission() {
        String permission = Manifest.permission.READ_SMS;
        int grant = ContextCompat.checkSelfPermission(this, permission);
        if (grant != PackageManager.PERMISSION_GRANTED) {
            String[] permission_list = new String[1];
            permission_list[0] = permission;
            ActivityCompat.requestPermissions(this, permission_list, 1);
        } else {
            Toast.makeText(this, "Permission granted", Toast.LENGTH_SHORT).show();
            Log.d("", "Permission granted");
        }
    }

    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions,
                                           @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        if (requestCode == 1) {
            if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                requestSmsPermission();
            } else {
                Toast.makeText(this, "permission not granted", Toast.LENGTH_SHORT).show();
            }
        }

    }
}

Ответы [ 2 ]

1 голос
/ 28 октября 2019

Ваша настоящая проблема в РАЗРЕШЕНИИ SMS . Вы запрашиваете только READ_SMS разрешение от пользователя, а не RECEIVE_SMS разрешение. Вы также должны дать это разрешение для достижения этого.

Manifest.permission.RECEIVE_SMS

Попробуйте добавить это:

ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.READ_SMS, Manifest.permission.RECEIVE_SMS}, 1);

Это выглядит так:

private void requestSmsPermission() {
    String readSms = Manifest.permission.READ_SMS;
    String receiveSms = Manifest.permission.RECEIVE_SMS;

    int grant = ContextCompat.checkSelfPermission(this, readSms) + ContextCompat.checkSelfPermission(this, receiveSms);
    if (grant != PackageManager.PERMISSION_GRANTED) {
        ActivityCompat.requestPermissions(this, new String[]{readSms, receiveSms}, 1);
    } else {
        Toast.makeText(this, "Permission granted", Toast.LENGTH_SHORT).show();
        Log.d("", "Permission granted");
    }
}
0 голосов
/ 28 октября 2019

попытайтесь увеличить приоритет, чтобы ваше приложение сначала получило SMS, я бы установил его на максимум:

 <intent-filter android:priority="2147483647">
...