0

есть много вопросов, связанных с этой темой. но я не могу заставить его работать на моем устройстве 4.2.1 на эмуляторе 5.0 он работает нормально .:Android BroadcastReceiver не срабатывает

здесь манифеста:

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

<uses-sdk 
    android:minSdkVersion="10" 
    android:targetSdkVersion="21" /> 

<uses-permission android:name="android.permission.INTERNET" /> 
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> 
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 

<application 
    android:allowBackup="true" 
    android:icon="@drawable/ic_launcher" 
    android:label="@string/app_name" 
    android:theme="@style/AppTheme" > 
    <receiver 
     android:name=".MyBroadcastReceiver" 
     android:enabled="true" 
     android:label="MyBroadcastReceiver" > 
     <intent-filter android:priority="1001" > 
      <action android:name="android.intent.action.BOOT_COMPLETED" /> 
     </intent-filter> 
    </receiver> 

    <activity 
     android:name=".MainActivity" 
     android:label="@string/app_name" > 
     <intent-filter> 
      <action android:name="android.intent.action.MAIN" /> 

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

    <service android:name=".PingService" > 
    </service> 
    <service android:name=".UpdateService" > 
    </service> 

    <receiver android:name=".OnBootReceiver" > 
     <intent-filter android:priority="1001" > 
      <action android:name="android.intent.action.BOOT_COMPLETED" /> 
     </intent-filter> 
    </receiver> 
</application> 
</manifest> 

Я попробовал его с 2-мя приемниками: ни один из них не работает. Вот один из приемников, которые должны написать логфайл для SD, который работает отлично от активности Launcher:

public class MyBroadcastReceiver extends BroadcastReceiver { 
// Restart service every 30 seconds 
private static final long REPEAT_TIME = 1000 * 10; 

@Override 
public void onReceive(Context context, Intent intent) { 
    Log.e("MyBroadcastReceiver", "BroadcastReceiver"); 
    appendLog("MyBroadcastReceiver BroadcastReceiver \n"); 
    AlarmManager service = (AlarmManager) context 
      .getSystemService(Context.ALARM_SERVICE); 
    Intent i = new Intent(context, UpdateService.class); 
    PendingIntent pending = PendingIntent.getBroadcast(context, 0, i, 
      PendingIntent.FLAG_CANCEL_CURRENT); 
    Calendar cal = Calendar.getInstance(); 

    cal.add(Calendar.SECOND, 30); 

    service.setInexactRepeating(AlarmManager.RTC_WAKEUP, 
      cal.getTimeInMillis(), REPEAT_TIME, pending); 

    Log.wtf("MyBroadcastReceiver", "Alarm went off"); 



} 

public static void appendLog(String text) { 
    File logFile = new File("sdcard/logfile.txt"); 
    if (!logFile.exists()) { 
     try { 
      logFile.createNewFile(); 
     } catch (IOException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
    } 
    try { 
     // BufferedWriter for performance, true to set append to file flag 
     BufferedWriter buf = new BufferedWriter(new FileWriter(logFile, 
       true)); 
     buf.append(text); 
     buf.newLine(); 
     buf.close(); 
    } catch (IOException e) { 
     // TODO Auto-generated catch block 
     e.printStackTrace(); 
    } 
} 
} 

Я не могу увидеть ошибку. Кто-нибудь делает? PS приложение запускается один раз, поэтому это: http://commonsware.com/blog/2011/07/05/boot-completed-regression.html покрыто.

спасибо,

+0

BOOT_COMPLETED это означает, что когда устройство перезагружается и готово к использованию. Надеюсь, вы понимаете, что это значит. –

+0

@ MurtazaHussain, конечно. Приведенный выше код должен предоставить файл журнала на SD-карте после завершения загрузки. – user1616685

+0

Однако он не работает. – user1616685

ответ

0

потребовалось много времени, ключ к проблеме был в Manifest.xml

здесь изменения получили его запуска (только блок приемника):

<receiver 
     android:name="com.example.bootService.MyBroadcastReceiver" 
     android:exported="true" 
     android:label="@string/app_name" > 
     <intent-filter> 
      <action android:name="android.intent.action.PACKAGE_REPLACED" /> 

      <data 
       android:path="com.example.bootService" 
       android:scheme="package" /> 
     </intent-filter> 
     <intent-filter> 
      <action android:name="android.intent.action.BOOT_COMPLETED" /> 
      <category android:name="android.intent.category.DEFAULT" /> 
     </intent-filter> 

    </receiver> 

важным было

<category android:name="android.intent.category.DEFAULT" /> 

тег

Смежные вопросы