[发明专利]一种识别APP程序中第三方库的方法有效
申请号: | 201810361862.5 | 申请日: | 2018-04-20 |
公开(公告)号: | CN108710492B | 公开(公告)日: | 2021-09-07 |
发明(设计)人: | 闫晓艳;刘亮;张耀 | 申请(专利权)人: | 四川普思科创信息技术有限公司 |
主分类号: | G06F8/53 | 分类号: | G06F8/53;G06F21/56 |
代理公司: | 成都顶峰专利事务所(普通合伙) 51224 | 代理人: | 陈钱 |
地址: | 610000 四川省成都市高新*** | 国省代码: | 四川;51 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 识别 app 程序 第三 方法 | ||
本发明涉及信息安全技术领域,公开了一种识别APP程序中第三方库的方法。通过本发明创造,可提供一种基于函数调用关系的、在APP已混淆程序中能够识别是否使用第三方库的方法,考虑在APP程序中嵌入第三方库,是为了使用它的功能,常规的混淆并不改变函数之间的调用关系以及类之间的相对路径,因此将调用关系最复杂的函数作为特征函数,并为该特征函数计算防混淆的函数特征值,可以利用该函数特征值唯一表征第三方库,进而通过后续地函数特征值的对比,可以在APP已混淆程序中高精准地识别出是否使用已知的第三方库,便于实际应用和推广。
技术领域
本发明属于信息安全技术领域,具体涉及一种识别APP程序中第三方库的方法。
背景技术
当前安卓APP程序中经常嵌有大量的第三方库(即第三方的软件包),但是有可能已被混淆,很难识别出安卓APP程序中具体使用了哪些第三方库。目前识别第三方库的方法主要有如下两种:(1)直接使用函数名匹配的方法,即首先提取第三方库中函数的函数名,再提取APP程序中的函数名,通过函数名匹配的方法确定在APP程序中是否使用了该第三方库,但是如果APP程序出现代码混淆的话,就行不通了;(2)对第三方库中的所有类计算特征值,再对APP程序中的所有类计算特征值,最终进行特征值匹配,如果第三方库有60%以上的类出现在了APP程序中,就认为在APP程序中使用了该第三方库,但是这样识别的准确率不够高,需要60%这个阈值。由此有必要提供一种可识别一个给定APP程序中使用了哪些第三方库的新方法。
发明内容
为了解决现有技术存在的上述问题,本发明目的在于提供一种识别APP程序中第三方库的方法。
本发明所采用的技术方案为:
一种识别APP程序中第三方库的方法,包括如下步骤:
S101.收集已知的第三方库;
S102.针对各个第三方库,通过预处理获取对应第三方库中的所有函数,并根据函数调用关系确定该第三方库的特征函数;
S103.针对各个第三方库的特征函数,确定第一函数特征值;
S104.针对目标APP程序,通过预处理获取目标APP程序中的所有函数;
S105.针对目标APP程序中的各个函数,按照与步骤S103一致的方法,确定第二函数特征值;
S106.遍历目标APP程序中各个函数的第二函数特征值,若与其中一个第三方库的第一函数特征值相同,则确定在目标APP程序中使用了该第三方库。
具体的,在所述步骤S103中,按照如下步骤确定第一函数特征值:
S201.获取特征函数的返回值类型,若该返回值类型为系统类型,则将该返回值类型作为第一特征字段,否则获取该返回值类型与参考类的相对路径,并将经匿名化处理的该相对路径作为第一特征字段;
S202.获取特征函数的所有参数类型,并针对每个参数类型,若该参数类型为系统类型,则将该参数类型作为第二特征字段,否则获取该参数类型与参考类的相对路径,将经匿名化处理的该相对路径作为第二特征字段;
S203.判断特征函数是否拥有直接调用的被调用函数,若有则将被调用函数视为特征函数,按照与步骤S103一致的方法,获取各个被调用函数的函数特征值,然后依次拼接第一特征字段、所有的第二特征字段和按字母顺序排序的所有被调用函数的函数特征值,得到特征函数的特征字符串;
S204.对特征函数的特征字符串进行哈希算法处理,获取第一函数特征值。
进一步具体的,在所述步骤S203中,若判断特征函数没有直接调用的被调用函数,则依次拼接第一特征字段和所有的第二特征字段,得到特征函数的特征字符串。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于四川普思科创信息技术有限公司,未经四川普思科创信息技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810361862.5/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种基于C/S架构的软件管理系统及方法
- 下一篇:软件清理方法及装置