一个快速分析android app使用了哪些sdk的工具

简介: 一个快速分析android app使用了哪些sdk的工具

前段时间我们要准备开始做移动端广告sdk,我需要了解市面上一些常用的广告sdk使用情况。如果一个个app去分析,那工作量会非常庞大,所以就产生了这个工具AnalysisApp。通过这个工具我已经分析了top 200个app,并可以识别出99个sdk。能够识别的sdk列表


要是时间充裕,我会不断完善这个项目。


github地址:


https://github.com/fengzhizi715/AnalysisApp


工具使用



首先,它是一个java工程,用Intellij Idea进行开发。混合着groovy,你完全可以把它看成是java,因为需要借助groovy的语法糖快速实现一些功能。


image.png


AnalysisApp工程目录.jpeg


其次,如果要分析某个app使用哪些sdk,必须把AnalysisApp的代码clone下来,并且需要拿到待分析app的AndroidManifest.xml文件。如何获取app的AndroidManifest.xml文件不在本工具的使用范围之列。


AnalysisApp程序的入口在Main.java的main()方法中。需要修改AndroidManifest.xml的路径。

image.png


程序入口.jpeg


其实,更好的做法是把它做成一个service放在服务端,可以不断更新sdk的特征值。

最后,我们来看一下它分析某个app的运行效果:


image.png


分析sdk结果.jpeg


实现原理



  1. 读取某个app的AndroidManifest.xml文件,将其转换成相应的对象。
  2. 遍历该对象中Activity、Service、meta-data、Receiver等元素列表,将其跟sdk的特征值进行匹配。如果匹配成功表示app包含该sdk,并记录下来。


由于整个工程是java的工程,所以由Spring进行统一管理。


handler包下的各个Handler用于处理sdk的特征值。

image.png


handler包下的各个Handler.jpeg


一个Handler至少有一个sdk的特征值。Spring对这些Handler进行管理,通过责任链(Chain of Responsibility)模式将各个Handler串联起来。

@Data
public class Analysis {
    private List<BaseHandler> handlers;
    public BaseHandler getFirstHandler() {
        if (Preconditions.isNotBlank(handlers)) {
            int len = handlers.size();
            for (int i = 0;i<len;i++) {
                if(i>0) {
                    handlers.get(i-1).setNextHandler(handlers.get(i));
                }
            }
            return handlers.get(0);
        }
        return null;
    }
}


对于某些特别复杂的Handler,比如BAT这几家都有很多sdk,他们的Handler会写的非常长,所以采用DFA的算法进行优化。以百度为例,简化了BaiduHandler的代码量。

@Service
class BaiduHandler extends BaseHandler {
    protected boolean handle(ActivityRequest request) {
        State s;
        for (s = BaiduStates.Init; !(s instanceof FinalState); s=s.next(request)) {
        }
        return s == AcceptingState.Accept;
    }
}


所有需要处理BaiduHandler的逻辑放到BaiduStates中去。

/**
 * Created by tony on 16/8/12.
 */
public enum BaiduStates implements State {
    Init {
        public State next(ActivityRequest request) {
            if (request.getActivity()!=null) {
                return ACTIVITY_STATE;
            } else if (request.getMetadata()!=null) {
                return METADATA_STATE;
            } else if (request.getService()!=null) {
                return SERVICE_STATE;
            }
            return FailingState.Fail;
        }
    },
    ACTIVITY_STATE {
        public State next(ActivityRequest request) {
            if (request.getActivity().getName() != null) {
                if (request.getActivity().getName().equals("com.baidu.wallet.paysdk.ui.WelcomeActivity")) {
                    SDK sdk = new SDK("百度钱包sdk");
                    AppInfo.getInstance().addSDK(sdk);
                    return AcceptingState.Accept;
                } else if (request.getActivity().getName().equals("com.baidu.mobad.feeds.BaiduActivity")) {
                    SDK sdk = new SDK("百度MSSP信息流广告",true);
                    AppInfo.getInstance().addSDK(sdk);
                    return AcceptingState.Accept;
                }
            }
            return FailingState.Fail;
        }
    },
    METADATA_STATE {
        public State next(ActivityRequest request) {
            if (request.getMetadata().getName() != null) {
                if (request.getMetadata().getName().equals("com.baidu.lbsapi.API_KEY")) {
                    SDK sdk = new SDK("百度地图sdk");
                    AppInfo.getInstance().addSDK(sdk);
                    return AcceptingState.Accept;
                } else if (request.getMetadata().getName().equals("BaiduMobAd_APP_ID")) {
                    SDK sdk = new SDK("百度广告联盟sdk",true);
                    AppInfo.getInstance().addSDK(sdk);
                    return AcceptingState.Accept;
                } else if (request.getMetadata().getName().equals("BaiduMobAd_STAT_ID")) {
                    SDK sdk = new SDK("百度移动统计sdk");
                    AppInfo.getInstance().addSDK(sdk);
                    return AcceptingState.Accept;
                }
            }
            return FailingState.Fail;
        }
    },
    SERVICE_STATE {
        public State next(ActivityRequest request) {
            if (request.getService().name !=null) {
                if (request.getService().name.equals("com.baidu.android.pushservice.PushService")) {
                    SDK sdk = new SDK("百度云推送sdk");
                    AppInfo.getInstance().addSDK(sdk);
                    return AcceptingState.Accept;
                }
            }
            return FailingState.Fail;
        }
    };
    public abstract State next(ActivityRequest request);
}


相关文章
|
26天前
|
ARouter IDE 开发工具
Android面试题之App的启动流程和启动速度优化
App启动流程概括: 当用户点击App图标,Launcher通过Binder IPC请求system_server启动Activity。system_server指示Zygote fork新进程,接着App进程向system_server申请启动Activity。经过Binder通信,Activity创建并回调生命周期方法。启动状态分为冷启动、温启动和热启动,其中冷启动耗时最长。优化技巧包括异步初始化、避免主线程I/O、类加载优化和简化布局。
35 3
Android面试题之App的启动流程和启动速度优化
|
11天前
|
Android开发
Android面试题经典之如何全局替换App的字体
在Android应用中替换字体有全局和局部方法。全局替换涉及在`Application`的`onCreate`中设置自定义字体,并创建新主题。局部替换则可在布局中通过`ResourcesCompat.getFont()`加载字体文件并应用于`TextView`。
21 2
|
17天前
|
移动开发 小程序 开发工具
微信支付的类型分析(JSAPI+APP+H5+NATIVE+付款码+合单)
微信支付的类型分析(JSAPI+APP+H5+NATIVE+付款码+合单)
20 1
|
24天前
|
缓存 JSON 网络协议
Android面试题:App性能优化之电量优化和网络优化
这篇文章讨论了Android应用的电量和网络优化。电量优化涉及Doze和Standby模式,其中应用可能需要通过用户白名单或电池广播来适应限制。Battery Historian和Android Studio的Energy Profile是电量分析工具。建议减少不必要的操作,延迟非关键任务,合并网络请求。网络优化包括HTTPDNS减少DNS解析延迟,Keep-Alive复用连接,HTTP/2实现多路复用,以及使用protobuf和gzip压缩数据。其他策略如使用WebP图像格式,按网络质量提供不同分辨率的图片,以及启用HTTP缓存也是有效手段。
42 9
|
19天前
|
监控 Android开发 iOS开发
探索Android与iOS开发的差异:平台、工具和用户体验的比较
【6月更文挑战第25天】在移动应用开发的广阔天地中,Android和iOS两大平台各领风骚,它们在开发环境、工具选择及用户体验设计上展现出独特的风貌。本文将深入探讨这两个操作系统在技术实现、市场定位和用户交互方面的关键差异,旨在为开发者提供一个全景式的视图,帮助他们在面对项目决策时能够更加明智地选择适合自己项目需求的平台。
|
24天前
|
开发工具 Android开发 iOS开发
探索安卓与iOS开发的差异:从工具到用户体验
【6月更文挑战第20天】在移动应用开发的广阔天地中,安卓和iOS两大平台各自占据半壁江山。本文将深入探讨这两个操作系统在开发环境、编程语言、用户界面设计以及性能优化等方面的关键差异。我们将通过比较分析,揭示各自平台的独特优势和面临的挑战,为开发者提供决策参考,并为最终用户提供更深层次的用户体验洞察。
|
25天前
|
XML 监控 安全
Android App性能优化之卡顿监控和卡顿优化
本文探讨了Android应用的卡顿优化,重点在于布局优化。建议包括将耗时操作移到后台、使用ViewPager2实现懒加载、减少布局嵌套并利用merge标签、使用ViewStub减少资源消耗,以及通过Layout Inspector和GPU过度绘制检测来优化。推荐使用AsyncLayoutInflater异步加载布局,但需注意线程安全和不支持特性。卡顿监控方面,提到了通过Looper、ChoreographerHelper、adb命令及第三方工具如systrace和BlockCanary。总结了Choreographer基于掉帧计算和BlockCanary基于Looper监控的原理。
27 3
|
1月前
|
数据采集 JSON 算法
使用Python爬取华为市场APP应用进行分析
这个网站也是作者最近接触到的一个APP应用市场类网站。讲实话,还是蛮适合新手朋友去动手学习的。毕竟爬虫领域要想进步,还是需要多实战、多分析!该网站中的一些小细节也是能够锻炼分析能力的,也有反爬虫处理。甚至是下载APP的话在Web端是无法拿到APK下载的直链,需要去APP端接口数据获取
|
1月前
|
安全 Android开发 数据安全/隐私保护
同样的 APP 为何在 Android 8 以后网络感觉变卡?
【6月更文挑战第8天】Android 8 及以后系统中,APP 网络感觉变卡源于更严格的安全机制和后台限制,系统对网络优化的侧重改变,以及APP自身兼容性问题。开发者需优化APP,适应新系统,用户可更新APP或检查权限设置。通过共同努力,有望改善网络卡顿现象,提升用户体验。
|
23天前
|
Java Android开发 Kotlin
Android面试题:App性能优化之Java和Kotlin常见的数据结构
Java数据结构摘要:ArrayList基于数组,适合查找和修改;LinkedList适合插入删除;HashMap1.8后用数组+链表/红黑树,初始化时预估容量可避免扩容。SparseArray优化查找,ArrayMap减少冲突。 Kotlin优化摘要:Kotlin的List用`listOf/mutableListOf`,Map用`mapOf/mutableMapOf`,支持操作符重载和扩展函数。序列提供懒加载,解构用于遍历Map,扩展函数默认参数增强灵活性。
17 0