Android多开检测

Android多开检测

公司使用的是自己开发的一套OA系统,包括打卡,一直相安无事,最近发现有人使用市面的的一些虚拟软件,定位打卡。所以就...

使用文件名检测

分析了多开的方式后发现一个规律,应用多开其实是在自己的目录下面创建一个沙盒,运行app,这样和原来的app不共享数据存储。所以我们可以检测app的文件路径如果不是正常的路径那么就是不合法的使用app。

比如某多开软件下启动自己的app,通过Context.getFileDir()获取到的路径是:

/data/user/0/package/virtual/data/user/0/package/files

而正常的是:

/data/user/0/package/files

所以我们可以使用:

if (!"/data/user/0/your package/files".equals(getFilesDir().toString())) {
            // do something
   }

基于Socket

本方式来源:https://github.com/lamster2018/EasyProtector/issues/25

public class App extends Application {

    LocalServerSocket mServerSocket;

    @Override
    public void onCreate() {
        super.onCreate();
        try {
            // 借鉴自 AMS 与 zygote 通信
            mServerSocket = new LocalServerSocket("唯一的字符串"); # 最好不要用包名
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

原理:
LocalServerSocket 在构造的时候只需要传递一个名字,系统底层会在 Linux 抽象命名空间里创建,如果多次创建同一个名字的 LocalServerSocket,后续创建的会抛异常

其他

更多方式可以参考EasyProtector这个库,但是实际测试的时候发现大多数方法都无效。

声明:原创文章,版权所有,转载请注明出处,https://litets.com。