Не удалось получить SMS на Android (процесс плохой) - PullRequest
2 голосов
/ 27 октября 2011

Я перепробовал много (если не все ...) Получил SMS примеров, но он всегда заканчивался неудачей, прежде чем вызывается даже onReceive ().

CatLog:

10-26 20:05:30.990: INFO/System.out(2714): INFO: Received message
10-26 20:05:30.998: INFO/System.out(2714): INFO: Message body: Lmjgk
10-26 20:05:31.021: WARN/ActivityManager(1317): Unable to launch app org.apache.sms/10166 for broadcast Intent { act=android.provider.Telephony.SMS_RECEIVED (has extras) }: process is bad
10-26 20:05:31.021: WARN/ActivityManager(1317): finishReceiver called but none active

При реализации вместе с другим BroadcastReceiver android.intent.action.PHONE_STATE, последний вызывается и работает отлично, в то время как SMS не работает.создал пример приветствия и обновления манифеста и один файл для SMS BroadcastReceiver.

Манифест:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.byp.sms" android:versionCode="1" android:versionName="1.0">
<uses-sdk android:minSdkVersion="9" />

<application android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".HelloActivity" android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                    <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <receiver android:name="com.byp.sms.SMSReceiver">
            <intent-filter>
                <action android:name="android.provider.telephony.SMS_RECEIVED"></action>
            </intent-filter>
        </receiver>
</application>

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

BroadcastReceiver

    package com.byp.sms;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.util.Log;

public class SMSReceiver extends BroadcastReceiver {

    private static final String ACTION = "android.provider.Telephony.SMS_RECEIVED";

    @Override
    public void onReceive(Context context, Intent intent) {
        Log.d("SMSReceiver", "onReceive"); // <<=== It does not even get here....
        if (intent != null && intent.getAction() != null
                && ACTION.compareToIgnoreCase(intent.getAction()) == 0) {
            Object[] pduArray = (Object[]) intent.getExtras().get("pdus");
            Log.d("SMSReceiver", "SMSReceived " + pduArray.toString());
        }
        Log.d("SMSReceiver", "onReceive...Done");
      }
    }

Hello Activity: Без изменений в сгенерированном коде

package com.byp.sms;

import android.app.Activity;
import android.os.Bundle;

public class HelloActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
        public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }
}

Не помогло то, что я очистил все связанные приложения с устройства, удалил его, перезагрузил устройство и т. Д. И т. Д.

Любой совет илиСовет будет принята с благодарностью!

Спасибо

1 Ответ

3 голосов
/ 27 октября 2011

Вам нужно сделать Receiver статическим, если вы регистрируете его в файле AndroidManifest. и если приемник не статичен, то вам нужно зарегистрироваться через код. Пожалуйста, делайте выше, это покажет некоторый положительный результат.

...