Android监听自身的程序被卸载-LOG监视

原文地址:http://blog.csdn.net/a578559967/article/details/7730361

Android监听自身的程序被卸载

手段略曲折

监听Android上别的程序被安装、卸载很容易,网上到处有教程,可是能监听到自己卸载,就不容易找下教程了。毕竟有的时候我们想了解我们的程序被多少次安装、多少次卸载,统计下用户量,这时必须要能监听到卸载,并在卸载前做一些事。

首先给程序注册读取log权限, 

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

然后在你的程序里开一个后台线程,不停的读取log,当你的应用(包括其他任何应用)被卸载时,系统的ActivityManager会打印出一行log,大概是removing:你的包名。这个时机是在卸载界面点击确定后的一瞬间触发的,如下图


之后你的程序不管是进程还是线程都会被杀死。这一瞬间很短,但足够你捕获到,能不能通过网络发送出去你要发的信息就不敢保证了,我反正是没发出去就被杀死了。

还有个时机是在程序管理界面点击卸载按钮跳转卸载界面时会打印一行log,如图:

   


但是不能保证用户就会点确定真把你的卸载了。。所以自己权衡吧。   

这是我在网上找到的唯一方法 

代码如下:

  1.  private void ListenLog(){  
  2.     Thread t = new Thread(new Runnable() {  
  3.   
  4.     public void run() {  
  5.         // TODO Auto-generated method stub  
  6.         Log.v("Fuck","Start listening log");  
  7.         String[] cmds = { "logcat""-c" };  
  8.         String shellCmd = "logcat";  
  9.         Process process = null;  
  10.         InputStream is = null;  
  11.         DataInputStream dis = null;  
  12.         String line = "";  
  13.         Runtime runtime = Runtime.getRuntime();  
  14.         try {  
  15.             int waitValue;  
  16.             waitValue = runtime.exec(cmds).waitFor();  
  17.             process = runtime.exec(shellCmd);  
  18.             is = process.getInputStream();  
  19.             dis = new DataInputStream(is);  
  20.             while ((line = dis.readLine()) != null && mKeepListenFlag) {  
  21.                 if (!line.contains("Fuck")) {  
  22.                     Log.v("Fuck", line);  
  23.                 }  
  24.                   
  25.                 //就在这里判断line里是否包含removing和你的包名字样,然后做些处理  
  26.                   
  27.             }  
  28.             Log.v("Fuck","finished listen");  
  29.         } catch (InterruptedException e) {  
  30.             e.printStackTrace();  
  31.         } catch (IOException ie) {  
  32.             ie.printStackTrace();  
  33.         } finally {  
  34.             try {  
  35.                 if (dis != null) {  
  36.                     dis.close();  
  37.                 }  
  38.                 if (is != null) {  
  39.                     is.close();  
  40.                 }  
  41.                 if (process != null) {  
  42.                     process.destroy();  
  43.                 }  
  44.             } catch (Exception e) {  
  45.                 e.printStackTrace();  
  46.             }  
  47.         }  
  48.     }  
  49.   
  50. });  
  51.     //mKeepListenFlag是个成员变量,是为了让程序结束时终止线程的,否则可能产生程序多次启动,然后这个线程就启动了多个。Android线程可不会因为Activity的退出而终止。         
  52.     mKeepListenFlag = true;  
  53. t.start();  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值