How can I prevent my Android app/service from being "killed" from a task manager?
It is very important that my service stay running until someone with a password stops the service from my UI screen. My app runs great but it is designed to be turned on/off by parents (with a password) on their kids phones. I have managed to make everything work but the problem I'm having is that if the kid uses a task manager to kill my service then my app is useless. I would be grateful to anyone who knows a way to either
1) monitor the service and start it back up automatically if its "killed" or 2) prevent someone from being able to kill it except from the activity (administration screen) that launched开发者_StackOverflow the service. Or both?
I'm sorry if I'm not very clear in describing the problem, I'm a beginner. I've made great progress so far but I am stuck at this last hurdle.
You can use API method: startForeground()
. Here is the explanation of it:
A started service can use the startForeground(int, Notification) API to put the service in a foreground state, where the system considers it to be something the user is actively aware of and thus not a candidate for killing when low on memory. (It is still theoretically possible for the service to be killed under extreme memory pressure from the current foreground application, but in practice this should not be a concern.)
Here you can find an example how to use this.
As for the question, you cannot prevent a service from being killed. It can be killed by the system. Even system services can be killed. If this happens they are restarted. You may use the same approach.
You can write a helper app to receive android broadcast "android.intent.action.PACKAGE_RESTARTED",when your app got killed,your helper will receive that broadcast and you can restart your app or whatever.
That's how 'Smart App Protector Free' do.
The bad thing is users must install two apps instead of one.
There isn't a way to prevent this directly, without a rooted device. The SDK helpfully prevents these kinds of issues.
You can do the "truly evil" trick and have two services in two application. Each service monitors the other, and restarts it if it stops. This is kludgy, but in most cases even the fastest fingered kid couldn't kill both applications.
For anyone who is still searching for an answer - this one may be correct:
you can not: make a service unkillable, if running on low Memory the System will always kill your service. BUT
you can: Tell the System to restart your service when it is killed. Look at this piece of code:
public static final int START_REDELIVER_INTENT
Added in API level 5
Constant to return from onStartCommand(Intent, int, int)
:
if this service's process is killed while it is started (after returning from onStartCommand(Intent, int, int))
, then it will be scheduled for a restart and the last delivered Intent re-delivered to it again via onStartCommand(Intent, int, int)
.
This Intent will remain scheduled for redelivery until the service calls stopSelf(int)
with the start ID provided to onStartCommand(Intent, int, int)
. The service will not receive an onStartCommand(Intent, int, int)
call with a null Intent because it will only be re-started if it is not finished processing all Intents sent to it (and any such pending events will be delivered at the point of restart).
Constant Value: 3 (0x00000003)
If you have system level permissions use persistent:true
via manifest permissions.
https://developer.android.com/guide/topics/manifest/application-element
Just set the return type as START_STICKY .
精彩评论