android jni 启动服务,Android下新增JNI过程中启动新增系统服务(addService)遇安全错误问题...

今天新增一个JNI的时候遇到一个调用用addService的时候发生异常的问题:

首先是在SystemService.java添加一个自己定义的binder service,代码如下:

try {

Slog.i(TAG, "Xxx Service");

ServiceManager.addService("xxx", new XxxService());

} catch (Throwable e) {

reportWtf("starting Xxx Service", e);

}

结果发现执行到这的时候发生异常: SystemServer: BOOT FAILURE starting Xxx Service。

查看系统log发现:

…………

01-03 02:26:15.040  3907  3907 I SystemServiceManager: Starting com.android.server.midi.MidiService$Lifecycle

01-03 02:26:15.054  3907  3907 I SystemServiceManager: Starting com.android.server.usb.UsbService$Lifecycle

01-03 02:26:15.171  3907  3907 I SystemServiceManager: Starting com.android.server.twilight.TwilightService

01-03 02:26:15.201  3907  3907 I SystemServiceManager: Starting com.android.server.job.JobSchedulerService

01-03 02:26:15.249  3907  3907 I SystemServiceManager: Starting com.android.server.backup.BackupManagerService$Lifecycle

01-03 02:26:15.327  3907  3907 I SystemServiceManager: Starting com.android.server.appwidget.AppWidgetService

01-03 02:26:15.422  3907  3907 I SystemServiceManager: Starting com.android.server.GestureLauncherService

01-03 02:26:15.433   261   261 E ServiceManager: add_service('xxx',54) uid=1000 - PERMISSION DENIED

01-03 02:26:15.436  3907  3907 E SystemServer:     at android.os.ServiceManagerProxy.addService(ServiceManagerNative.java:150)

01-03 02:26:15.436  3907  3907 E SystemServer:     at android.os.ServiceManager.addService(ServiceManager.java:72)

01-03 02:26:15.485  3907  3907 I SystemServiceManager: Starting com.android.server.dreams.DreamManagerService

01-03 02:26:15.504  3907  3907 I SystemServiceManager: Starting com.android.server.print.PrintManagerService

01-03 02:26:15.517  3907  3907 I SystemServiceManager: Starting com.android.server.restrictions.RestrictionsManagerService

01-03 02:26:15.523  3907  3907 I SystemServiceManager: Starting com.android.server.media.MediaSessionService

01-03 02:26:15.558  3907  3907 I SystemServiceManager: Starting com.android.server.trust.TrustManagerService

01-03 02:26:15.581  3907  3907 I SystemServiceManager: Starting com.android.server.fingerprint.FingerprintService

01-03 02:26:15.624  3907  3907 I SystemServiceManager: Starting com.android.server.pm.LauncherAppsService

01-03 02:26:15.632  3907  3907 I SystemServiceManager: Starting com.android.server.media.projection.MediaProjectionManagerService

01-03 02:26:15.687  3907  3907 I SystemServiceManager: Starting com.android.server.MmsServiceBroker

………………

解决方案:

1. 在/external/sepolicy/service.te中仿写添加:

type xxx_service, system_api_service, system_server_service, service_manager_type;2. 在

/external/sepolicy/service_contexts下仿写添加:

xxx u:object_r:xxx_service:s0

添加完成编译,问题便可解决。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值