Android启动前台服务(ForegroundService)适配

打印 上一主题 下一主题

主题 1483|帖子 1483|积分 4449

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
从 Android 10(API 级别 29)开始,Google 引入了 foregroundServiceType 属性,用于声明前台服务的用途。如果你的应用需要在 Android 10 或更高版本中调用 startForeground() 方法,则必须在 AndroidManifest.xml 文件中为对应的 <service> 元素指定 foregroundServiceType 属性。
以下是详细的解释息争决方法:

问题分析


  • 错误原因

    • 在 Android 10 及以上版本中,系统要求开发者明确声明前台服务的范例(例如位置、媒体播放等),以提高透明度和用户隐私保护。
    • 如果未在 AndroidManifest.xml 中为服务声明 foregroundServiceType 属性,调用 startForeground() 时会抛出异常。

  • foregroundServiceType 的作用

    • 它用于形貌前台服务的具体用途,帮助系统更好地管理资源和关照用户。
    • 常见的范例包括:

      • location:用于获取位置信息。
      • mediaPlayback:用于播放音频或视频。
      • camera:用于访问摄像头。
      • microphone:用于录音。
      • dataSync:用于后台数据同步。
      • phoneCall:用于电话通话。
      • connectedDevice:用于与外部设备通讯。


  • 影响范围

    • 该要求仅适用于 Android 10 及以上版本。如果应用的目标 SDK 版本(targetSdkVersion)低于 29,则不受此限制。


办理步骤

1. 修改 AndroidManifest.xml

在 AndroidManifest.xml 文件中,为 <service> 元素添加 foregroundServiceType 属性,并根据服务的现实用途选择符合的范例。
示例代码:
  1. <service
  2.     android:name=".MyForegroundService"
  3.     android:foregroundServiceType="location" />
复制代码
2. 支持多个范例

如果服务需要同时支持多种范例,可以使用按位或运算符(|)组合多个范例。例如:
  1. <service
  2.     android:name=".MyForegroundService"
  3.     android:foregroundServiceType="location|camera" />
复制代码
3. 动态适配差别版本

如果应用需要兼容 Android 10 以下版本,可以在代码中动态查抄 API 级别,并仅在必要时设置 foregroundServiceType。
示例代码:
  1. if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
  2.     startForeground(1, notification, ServiceInfo.FOREGROUND_SERVICE_TYPE_LOCATION);
  3. } else {
  4.     startForeground(1, notification);
  5. }
复制代码

4. 添加前台服务权限

在 AndroidManifest.xml 中加入前台服务权限。
示例代码:
  1. <uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>
复制代码

完整示例代码

1. AndroidManifest.xml

  1. <manifest xmlns:android="http://schemas.android.com/apk/res/android"    package="com.example.myapp">            <uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>
  2.     <application>        <!-- 声明前台服务 -->        <service            android:name=".MyForegroundService"            android:foregroundServiceType="location" />    </application></manifest>
复制代码
2. 前台服务实现

  1. public class MyForegroundService extends Service {
  2.     @Override
  3.     public void onCreate() {
  4.         super.onCreate();
  5.         // 创建通知渠道(仅适用于 Android 8.0 及以上版本)
  6.         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
  7.             NotificationChannel channel = new NotificationChannel(
  8.                     "channel_id",
  9.                     "Foreground Service Channel",
  10.                     NotificationManager.IMPORTANCE_LOW
  11.             );
  12.             NotificationManager manager = getSystemService(NotificationManager.class);
  13.             if (manager != null) {
  14.                 manager.createNotificationChannel(channel);
  15.             }
  16.         }
  17.         // 构建通知
  18.         Notification notification = new NotificationCompat.Builder(this, "channel_id")
  19.                 .setContentTitle("Service Running")
  20.                 .setContentText("Your service is running in the foreground")
  21.                 .setSmallIcon(R.drawable.ic_notification) // 替换为实际的图标资源
  22.                 .setPriority(NotificationCompat.PRIORITY_LOW)
  23.                 .build();
  24.         // 启动前台服务
  25.         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
  26.             startForeground(1, notification, ServiceInfo.FOREGROUND_SERVICE_TYPE_LOCATION);
  27.         } else {
  28.             startForeground(1, notification);
  29.         }
  30.     }
  31.     @Override
  32.     public int onStartCommand(Intent intent, int flags, int startId) {
  33.         // 执行服务的逻辑
  34.         return START_STICKY;
  35.     }
  36.     @Override
  37.     public IBinder onBind(Intent intent) {
  38.         return null;
  39.     }
  40. }
复制代码

注意事项


  • 权限声明

    • 如果服务涉及敏感操作(如位置或摄像头),需要在 AndroidManifest.xml 中声明相应的权限。例如:
      1. <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
      复制代码

  • 用户授权

    • 某些权限(如位置、摄像头)需要用户明确授予权限。确保在运行时哀求这些权限。

  • 关照内容

    • 确保关照的内容完整且符合要求,避免因无效关照导致崩溃。

  • 目标 SDK 版本

    • 如果你的应用目标 SDK 版本为 29 或更高,请务必遵照上述规则。
    • 如果目标 SDK 版本低于 29,则无需声明 foregroundServiceType。


总结

通过在 AndroidManifest.xml 中为服务添加 foregroundServiceType 属性,并在代码中正确调用 startForeground(),你可以办理 To call Service.startForeground(), the <service> element of manifest file must have the foregroundServiceType attribute specified 的问题。确保根据服务的现实用途选择符合的范例,并遵照 Android 的最佳实践。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

梦见你的名字

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表