Android实现APP启动监听和拦截

有时候我们需要监听app的启动,并在一定时间进行拦截,其实系统是有提供相应的监听方法的

我们需要申明以下权限

<uses-permission android:name="android.permission.SET_ACTIVITY_WATCHER" />

其次我们需要进行注册

import android.app.ActivityManagerNative;
import android.app.IActivityManager;
import android.os.RemoteException;

setActivityController();

private void setActivityController() {
    IActivityManager am = ActivityManagerNative.getDefault();
    try {
        Log.i("ActivityController", "setActivityController");
        am.setActivityController(new ActivityController(this),true);
    } catch (RemoteException e) {
        Log.i("ActivityController", "setActivityController RemoteException");
        e.printStackTrace();
    }
}

然后我们就去实现对应回调方法


import android.app.IActivityController;
import android.content.Context;
import android.content.Intent;
import android.os.RemoteException;
import android.util.Log;
import android.os.SystemProperties;
import android.provider.Settings;
import android.app.ActivityManager;
import android.content.ComponentName;

import android.os.SystemProperties;

public class ActivityController extends IActivityController.Stub {

    public ActivityController(Context context){
    }
    /**activityStarting:当系统正在启动一个activity时会触发,当返回true,表示允许启动。当返回状态noraml/false分别表示停止/拒绝启动activity
    activityResuming:当系统正在返回一个activity时会触发,当返回true,表示允许返回。当返回状态noraml/false分别表示停止/拒绝返回activity
    appCrashed:当一个应用进程已经崩溃会触发,当返回true时,表示可以重启,当返回false时,表示立即杀死它(进程)。
    appEarlyNotResponding:当一鉴定为ANR时就很早触发;
    appNotResponding:当一个应用进程出现ANR时就会触发,当返回0时,表示会弹出应用无响应的dialog,如果返回1时,表示继续等待,如果返回-1时,表示立即杀死进程。
    systemNotResponding:当系统看门狗已经监测到系统似乎挂起就会触发,如果放回1时,表示继续等待,如果返回-1时,就让系统进行正常的自杀(这里的正常自杀,我的理解是系统自己主动自杀,该保存的数据先保存等然后就自杀,并不是因为其他原因导致的自杀)**/

    public boolean activityStarting(Intent intent, String pkg) throws RemoteException {
        return true;
    }

    public boolean activityResuming(String pkg) throws RemoteException {
        return true;
    }

    public boolean appCrashed(String processName, int pid, String shortMsg, String longMsg, long timeMillis, String stackTrace) throws RemoteException {
        return true;
    }

    public int appEarlyNotResponding(String processName, int pid, String annotation) throws RemoteException {
        return 0;

    }

    public int appNotResponding(String processName, int pid, String processStats) throws RemoteException {

        return 0;

    }

    public int systemNotResponding(String msg) throws RemoteException {

        return 0;

    }

}

以上方法只能系统级应用才能监听

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Android中,可以使用BroadcastReceiver来监听其他应用程序的启动。通过注册一个监听器,我们可以获取到其他应用程序启动的广播信息,并根据需要做出相应的处理。 首先,我们需要创建一个BroadcastReceiver的子类,并重写onReceive()方法,在该方法中处理接收到的广播信息。在onReceive()方法中,我们可以获取到启动应用程序的包名、活动名称等信息,并根据这些信息进行进一步的处理。 接下来,我们需要在AndroidManifest.xml文件中注册BroadcastReceiver。在<application>标签内,添加一个<receiver>标签,并设置其属性如下: ```xml <receiver android:name=".MyReceiver"> <intent-filter> <action android:name="android.intent.action.PACKAGE_ADDED"/> <data android:scheme="package"/> </intent-filter> </receiver> ``` 在上述代码中,我们通过指定intent-filter的action为"android.intent.action.PACKAGE_ADDED"来表示我们要监听应用程序的安装和启动事件。而data标签中的scheme属性为"package"表示我们要监听的是应用程序包名。 最后,在BroadcastReceiver的onReceive()方法中,我们可以通过调用intent对象的getStringExtra()方法获取到启动应用程序的包名信息,即: ```java public class MyReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { String packageName = intent.getStringExtra(Intent.EXTRA_PACKAGE_NAME); // 进行相应的处理 } } ``` 上述代码中,我们通过调用getStringExtra()方法获取到启动应用程序的包名信息,并可以根据这个信息进行我们自己的处理。 总结起来,通过注册BroadcastReceiver来监听其他应用程序的启动,我们可以获取到启动应用程序的包名等信息,从而实现自己的逻辑处理。这样,我们就能够在Android监听其他应用程序的启动了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值