利索能及
我要发布
收藏
专利号: 2017108056704
申请人: 武汉斗鱼网络科技有限公司
专利类型:发明专利
专利状态:已下证
更新日期:2025-11-27
缴费截止日期: 暂无
联系人

摘要:

权利要求书:

1.一种IOS平台隐藏dylib文件的方法,其特征在于,包括:

S1:获取IOS应用内的所有Mach-o文件及每个Mach-o文件内的dylib文件名称获取函数;

S2:编写一hook函数,所述hook函数用于获取dylib文件名称获取函数获取的dylib文件的名称;

S3:当IOS应用调用dylib文件名称获取函数进行IOS应用内所有dylib文件名称的获取时,通过hook函数获取dylib文件名称获取函数获取的dylib文件名称,根据dylib文件名称判断是否含有待隐藏dylib文件,若是,转到S4,若否,转到S5;

S4:隐藏待隐藏dylib文件名称,并将隐藏了待隐藏dylib文件名称后的dylib文件名称数据返回给IOS应用;

S5:将dylib文件名称获取函数取的dylib文件名称返回给IOS应用;

所述IOS应用还用于调用Mach-o文件内的dylib文件个数获取函数获取IOS应用内的dylib文件个数;

当dylib文件名称获取函数获取的dylib文件名称中含有待隐藏dylib文件名称,则返回给IOS应用的dylib文件个数为获取的dylib文件总个数减去待隐藏dylib文件的个数;

当dylib文件名称获取函数获取的dylib文件名称中不含有待隐藏dylib文件名称,则返回给IOS应用的dylib文件个数即为获取的dylib文件总个数,其中,通过hook方式对返回给IOS应用的dylib文件的个数进行修改;

其中,通过hook函数获取dylib文件名称获取函数获取的dylib文件名称,根据dylib文件名称判断是否含有待隐藏dylib文件,具体包括以下步骤:编写一功能函数my_dyld_get_image_name,当dylib文件名称获取函数执行时,通过hook函数将目标函数的内存地址进行替换成设定地址,进而执行编写的功能函数my_dyld_get_image_name;

在my_dyld_get_image_name中依次判断当前获取的dylib文件名称是否是待隐藏的dylib文件的名称。

2.如权利要求1所述的一种IOS平台隐藏dylib文件的方法,其特征在于,对于Mach-o文件内dylib文件名称获取函数的获取,具体为:S101: 获取IOS应用内的所有Mach-o文件及每个Mach-o文件所对应的内存起始地址,并根据内存起始地址获取Mach-o文件在内存中的虚拟内存地址;

S102:根据Mach-o文件在内存中的虚拟内存地址,解析Mach-o文件,得到每个Mach-o文件内每个函数的名称和指针;

S103:遍历得到的每个Mach-o文件内每个函数的名称,找到每个Mach-o文件内的dylib文件名称获取函数。

3.如权利要求1所述的一种IOS平台隐藏dylib文件的方法,其特征在于:

所述hook函数用于将目标函数的内存地址进行替换成设定地址;

当目标函数执行时,跳转至设定地址以进行dylib文件名称获取函数获取的dylib文件名称的获取;

所述目标函数为dylib文件名称获取函数。

4.一种存储介质,该存储介质上存储有计算机程序,其特征在于:所述计算机程序被处理器执行时实现权利要求1至3任一项所述的方法。

5.一种电子设备,包括存储器和处理器,存储器上储存有在处理器上运行的计算机程序,其特征在于:所述处理器执行所述计算机程序时实现权利要求1至3任一项所述的方法。

6.一种IOS平台隐藏dylib文件的系统,其特征在于,包括:

获取模块,其用于获取IOS应用内的所有Mach-o文件及每个Mach-o文件内的dylib文件名称获取函数;

编写模块,其用于编写一hook函数,所述hook函数用于获取dylib文件名称获取函数获取的dylib文件的名称;编写一功能函数my_dyld_get_image_name;所述my_dyld_get_image_name用于依次判断当前获取的dylib文件名称是否是待隐藏的dylib文件的名称;

判断与执行模块,其用于当IOS应用调用dylib文件名称获取函数进行IOS应用内dylib文件名称的获取时,通过hook函数获取dylib文件名称获取函数获取的dylib文件名称,根据dylib文件名称判断是否含有待隐藏dylib文件,若是,则隐藏待隐藏dylib文件名称,并将隐藏了待隐藏dylib文件名称后的dylib文件名称数据返回给IOS应用,若否,则将dylib文件名称获取函数取的dylib文件名称返回给IOS应用;其中,通过hook函数获取dylib文件名称获取函数获取的dylib文件名称,根据dylib文件名称判断是否含有待隐藏dylib文件,具体包括以下步骤:当dylib文件名称获取函数执行时,通过hook函数将目标函数的内存地址进行替换成设定地址,进而执行编写的功能函数my_dyld_get_image_name,依次判断当前获取的dylib文件名称是否是待隐藏的dylib文件的名称。

7.如权利要求6所述的一种IOS平台隐藏dylib文件的系统,其特征在于:所述获取模块对于Mach-o文件内dylib文件名称获取函数的获取,具体为:获取IOS应用内的所有Mach-o文件及每个Mach-o文件所对应的内存起始地址,并根据内存起始地址获取Mach-o文件在内存中的虚拟内存地址;

根据Mach-o文件在内存中的虚拟内存地址,解析Mach-o文件,得到每个Mach-o文件内每个函数的名称和指针;

遍历得到的每个Mach-o文件内每个函数的名称,找到每个Mach-o文件内的dylib文件名称获取函数。

8.如权利要求7所述的一种IOS平台隐藏dylib文件的系统,其特征在于:所述hook函数用于将目标函数的内存地址进行替换成设定地址;当目标函数执行时,跳转至设定地址以进行dylib文件名称获取函数获取的dylib文件名称的获取;所述目标函数为dylib文件名称获取函数。