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文件名称获取函数。