一种数据处理方法、装置、电子设备及存储介质转让专利

申请号 : CN202111166915.6

文献号 : CN113946346B

文献日 :

基本信息:

PDF:

法律信息:

相似专利:

发明人 : 樊锐彭飞邓竹立

申请人 : 北京五八信息技术有限公司

摘要 :

本发明提供了一种数据处理方法、装置、电子设备及存储介质。可以基于可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数,此种检测方式不仅可以兼顾可执行文件对应的开发人员编写的源代码,还可以兼顾可执行文件中的第三方库中的函数的汇编指令,避免漏检,从而可以提高检测的全面性,进而提高检测的准确率。另外,整个检测过程可以没有开发人员的参与,可以节省人工成本。其次,不需要人工修改应用程序的源代码即可实现对应用程序的源代码精简,提高了自动化程度,降低了人工成本。

权利要求 :

1.一种数据处理方法,其特征在于,所述方法包括:

根据应用程序的可执行文件中的符号表,获取所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量;

至少根据所述总数量以及所述第一偏移量,获取各个符号表项中分别记录的所述可执行文件中的函数的函数名在所述可执行文件中的第二偏移量以及各个符号表项中分别记录的所述可执行文件中的函数的汇编指令在所述可执行文件中的第三偏移量;

对于所述可执行文件中的任意一个符号表项,对所述符号表项对应的函数的函数名在所述可执行文件中的第二偏移量反汇编,得到所述符号表项对应的函数的函数名;以及,根据所述符号表项对应的函数的汇编指令在可执行文件中的第三偏移量获取所述符号表项对应的函数的汇编指令,然后在所述可执行文件中的函数的函数名与所述可执行文件中的函数的汇编指令之间的对应关系中,存储所述符号表项对应的函数的函数名与所述符号表项对应的函数的汇编指令;

基于所述可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及所述可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数。

2.根据权利要求1所述的方法,其特征在于,所述根据应用程序的可执行文件中的符号表,获取所述可执行文件中的各个函数分别对应的符号表项的总数量,包括:获取所述符号表中记录的可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量;

根据所述第四偏移量,获取所述符号表中记录的、所述可执行文件中的各个函数分别对应的符号表项的总数量。

3.根据权利要求2所述的方法,其特征在于,所述获取所述符号表中记录的可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量,包括:确定所述符号表的内存结构;

根据所述符号表的内存结构在所述符号表中确定所述可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量。

4.根据权利要求3所述的方法,其特征在于,所述方法还包括:

编译所述应用程序的修改后的源代码,得到应用程序的新的可执行文件。

5.一种数据处理方法,其特征在于,所述方法包括:

获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系;

其中,对于所述对应关系中的任意一个函数名,所述函数名是对所述可执行文件中的一个符号表项中记录的所述函数名在所述可执行文件中的第二偏移量反汇编得到的,所述函数名所对应的函数的汇编指令是根据所述符号表项中记录的所述汇编指令在所述可执行文件中的第三偏移量获取到的,所述第二偏移量以及所述第三偏移量是至少根据所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量分别获取的;

基于所述可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及所述可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数;

在所述对应关系中筛选相似度大于预设相似度的至少两个汇编指令;

在所述对应关系中查找至少两个汇编指令分别对应的函数的函数名;

输出至少两个汇编指令分别对应的函数的函数名。

6.一种数据处理方法,其特征在于,所述方法包括:

获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系;

其中,对于所述对应关系中的任意一个函数名,所述函数名是对所述可执行文件中的一个符号表项中记录的所述函数名在所述可执行文件中的第二偏移量反汇编得到的,所述函数名所对应的函数的汇编指令是根据所述符号表项中记录的所述汇编指令在所述可执行文件中的第三偏移量获取到的,所述第二偏移量以及所述第三偏移量是至少根据所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量分别获取的;

基于所述可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及所述可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数;

在所述对应关系中筛选相似度大于预设相似度的至少两个汇编指令;

在所述对应关系中查找至少两个汇编指令分别对应的函数的函数名;

获取所述应用程序的源代码,在所述源代码中删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码;

将所述源代码中的所述其他函数名替换为所述其中一个函数名,得到所述应用程序的修改后的源代码。

7.一种数据处理装置,其特征在于,所述装置包括:

第一获取模块,用于根据应用程序的可执行文件中的符号表,获取所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量;

第二获取模块,用于至少根据所述总数量以及所述第一偏移量,获取各个符号表项中分别记录的所述可执行文件中的函数的函数名在所述可执行文件中的第二偏移量以及各个符号表项中分别记录的所述可执行文件中的函数的汇编指令在所述可执行文件中的第三偏移量;

反汇编模块,用于对于所述可执行文件中的任意一个符号表项,对所述符号表项对应的函数的函数名在所述可执行文件中的第二偏移量反汇编,得到所述符号表项对应的函数的函数名;第三获取模块,用于根据所述符号表项对应的函数的汇编指令在可执行文件中的第三偏移量获取所述符号表项对应的函数的汇编指令;存储模块,用于在所述可执行文件中的函数的函数名与所述可执行文件中的函数的汇编指令之间的对应关系中,存储所述符号表项对应的函数的函数名与所述符号表项对应的函数的汇编指令;

检测模块,用于基于所述可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及所述可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数。

8.根据权利要求7所述的装置,其特征在于,所述第一获取模块包括:

第一获取单元,用于获取所述符号表中记录的可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量;

第二获取单元,用于根据所述第四偏移量,获取所述符号表中记录的、所述可执行文件中的各个函数分别对应的符号表项的总数量。

9.根据权利要求8所述的装置,其特征在于,所述第一获取单元包括:

第一确定子单元,用于确定所述符号表的内存结构;

第二确定子单元,用于根据所述符号表的内存结构在所述符号表中确定所述可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量。

10.一种数据处理装置,其特征在于,所述装置包括:

第四获取模块,用于获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系;

其中,对于所述对应关系中的任意一个函数名,所述函数名是对所述可执行文件中的一个符号表项中记录的所述函数名在所述可执行文件中的第二偏移量反汇编得到的,所述函数名所对应的函数的汇编指令是根据所述符号表项中记录的所述汇编指令在所述可执行文件中的第三偏移量获取到的,所述第二偏移量以及所述第三偏移量是至少根据所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量分别获取的;

检测模块,用于基于所述可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及所述可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数;

第一筛选模块,用于在所述对应关系中筛选相似度大于预设相似度的至少两个汇编指令;

第一查找模块,用于在所述对应关系中查找至少两个汇编指令分别对应的函数的函数名;

输出模块,用于输出至少两个汇编指令分别对应的函数的函数名。

11.一种数据处理装置,其特征在于,所述装置包括:

第五获取模块,用于获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系;

其中,对于所述对应关系中的任意一个函数名,所述函数名是对所述可执行文件中的一个符号表项中记录的所述函数名在所述可执行文件中的第二偏移量反汇编得到的,所述函数名所对应的函数的汇编指令是根据所述符号表项中记录的所述汇编指令在所述可执行文件中的第三偏移量获取到的,所述第二偏移量以及所述第三偏移量是至少根据所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量分别获取的;

检测模块,用于基于所述可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及所述可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数;

第二筛选模块,用于在所述对应关系中筛选相似度大于预设相似度的至少两个汇编指令;

第二查找模块,用于在所述对应关系中查找至少两个汇编指令分别对应的函数的函数名;

第六获取模块,用于获取所述应用程序的源代码;

删除模块,用于在所述源代码中删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码;

替换模块,用于将所述源代码中的所述其他函数名替换为所述其中一个函数名,得到所述应用程序的修改后的源代码。

12.根据权利要求11所述的装置,其特征在于,所述装置还包括:

编译模块,用于编译所述应用程序的修改后的源代码,得到应用程序的新的可执行文件。

13.一种电子设备,其特征在于,包括:处理器、存储器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述计算机程序被所述处理器执行时实现如权利要求1至6中任一项所述的数据处理方法的步骤。

14.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至6中任一项所述的数据处理方法的步骤。

说明书 :

一种数据处理方法、装置、电子设备及存储介质

技术领域

[0001] 本发明涉及计算机技术领域,尤其涉及一种数据处理方法、装置、电子设备及存储介质。

背景技术

[0002] 在开发应用程序的源代码的过程中,往往会在应用程序的源代码中编写很多函数,以供应用程序中的一些组件调用函数,另外,还可能会在应用程序的源代码中添加第三方库,第三方库中也存在编译后的函数,以供应用程序中的组件调用第三方库中的编译后的函数。
[0003] 然而,有时候应用程序的源代码是由多个开发人员合作开发的,不同的开发人员开发应用程序的一部分源代码,这样难免会导致最终得到的应用程序的源代码中多次重复出现了同一个函数的情况,进而导致应用程序的源代码冗余,如此会导致对源代码编译得到的应用程序的可执行文件的所占空间大。
[0004] 因此,为了降低应用程序的可执行文件的所占空间,则需要精简应用程序的源代码,为了精简应用程序的源代码,开发人员可以根据函数的函数名人工检测应用程序的源代码中是否存在至少两个相同或相似的函数。
[0005] 然而,发明人发现,上述方式,仅能够检测源代码中是否存在至少两个相同或相似的函数,无法兼顾在应用程序的源代码中添加的第三方库,容易漏检,导致检测准确率低。

发明内容

[0006] 为了降低人工成本以及提高检测准确率,本申请示出了一种数据处理方法、装置、电子设备及存储介质。
[0007] 第一方面,本申请示出了一种数据处理方法,所述方法包括:
[0008] 根据应用程序的可执行文件中的符号表,获取所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量;
[0009] 至少根据所述总数量以及所述第一偏移量,获取各个符号表项中分别记录的所述可执行文件中的函数的函数名在所述可执行文件中的第二偏移量以及各个符号表项中分别记录的所述可执行文件中的函数的汇编指令在所述可执行文件中的第三偏移量;
[0010] 对于所述可执行文件中的任意一个符号表项,对所述符号表项对应的函数的函数名在所述可执行文件中的第二偏移量反汇编,得到所述符号表项对应的函数的函数名;以及,根据所述符号表项对应的函数的汇编指令在可执行文件中的第三偏移量获取所述符号表项对应的函数的汇编指令,然后在所述可执行文件中的函数的函数名与所述可执行文件中的函数的汇编指令之间的对应关系中,存储所述符号表项对应的函数的函数名与所述符号表项对应的函数的汇编指令。
[0011] 在一个可选的实现方式中,所述根据应用程序的可执行文件中的符号表,获取所述可执行文件中的各个函数分别对应的符号表项的总数量,包括:
[0012] 获取所述符号表中记录的可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量。
[0013] 根据所述第四偏移量,获取所述符号表中记录的、所述可执行文件中的各个函数分别对应的符号表项的总数量。
[0014] 在一个可选的实现方式中,所述获取所述符号表中记录的可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量,包括:
[0015] 确定所述符号表的内存结构;
[0016] 根据所述符号表的内存结构在所述符号表中确定所述可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量。
[0017] 第二方面,本申请示出了一种数据处理方法,所述方法包括:
[0018] 获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系;
[0019] 其中,对于所述对应关系中的任意一个函数名,所述函数名是对所述可执行文件中的一个符号表项中记录的所述函数名在所述可执行文件中的第二偏移量反汇编得到的,所述函数名所对应的函数的汇编指令可以是根据所述符号表项中记录的所述汇编指令在所述可执行文件中的第三偏移量获取到的,所述第二偏移量以及所述第三偏移量是至少根据所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量分别获取的;
[0020] 在所述对应关系中筛选相似度大于预设相似度的至少两个汇编指令;
[0021] 在所述对应关系中查找至少两个汇编指令分别对应的函数的函数名;
[0022] 输出至少两个汇编指令分别对应的函数的函数名。
[0023] 第三方面,本申请示出了一种数据处理方法,所述方法包括:
[0024] 获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系;
[0025] 其中,对于所述对应关系中的任意一个函数名,所述函数名是对所述可执行文件中的一个符号表项中记录的所述函数名在所述可执行文件中的第二偏移量反汇编得到的,所述函数名所对应的函数的汇编指令可以是根据所述符号表项中记录的所述汇编指令在所述可执行文件中的第三偏移量获取到的,所述第二偏移量以及所述第三偏移量是至少根据所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量分别获取的;
[0026] 在所述对应关系中筛选相似度大于预设相似度的至少两个汇编指令;
[0027] 在所述对应关系中查找至少两个汇编指令分别对应的函数的函数名;
[0028] 获取所述应用程序的源代码,在所述源代码中删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码;
[0029] 将所述源代码中的所述其他函数名替换为所述其中一个函数名,得到所述应用程序的修改后的源代码。
[0030] 在一个可选的实现方式中,所述方法还包括:
[0031] 编译所述应用程序的修改后的源代码,得到应用程序的新的可执行文件。
[0032] 第四方面,本申请示出了一种数据处理装置,所述装置包括:
[0033] 第一获取模块,用于根据应用程序的可执行文件中的符号表,获取所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量;
[0034] 第二获取模块,用于至少根据所述总数量以及所述第一偏移量,获取各个符号表项中分别记录的所述可执行文件中的函数的函数名在所述可执行文件中的第二偏移量以及各个符号表项中分别记录的所述可执行文件中的函数的汇编指令在所述可执行文件中的第三偏移量;
[0035] 反汇编模块,用于对于所述可执行文件中的任意一个符号表项,对所述符号表项对应的函数的函数名在所述可执行文件中的第二偏移量反汇编,得到所述符号表项对应的函数的函数名;第三获取模块,用于根据所述符号表项对应的函数的汇编指令在可执行文件中的第三偏移量获取所述符号表项对应的函数的汇编指令;存储模块,用于在所述可执行文件中的函数的函数名与所述可执行文件中的函数的汇编指令之间的对应关系中,存储所述符号表项对应的函数的函数名与所述符号表项对应的函数的汇编指令。
[0036] 在一个可选的实现方式中,所述以获取模块包括:
[0037] 第一获取单元,用于获取所述符号表中记录的可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量。
[0038] 第二获取单元,用于根据所述第四偏移量,获取所述符号表中记录的、所述可执行文件中的各个函数分别对应的符号表项的总数量。
[0039] 在一个可选的实现方式中,所述第一获取单元包括:
[0040] 第一确定子单元,用于确定所述符号表的内存结构;
[0041] 第二确定子单元,用于根据所述符号表的内存结构在所述符号表中确定所述可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量。
[0042] 第五方面,本申请示出了一种数据处理装置,所述装置包括:
[0043] 第四获取模块,用于获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系;
[0044] 其中,对于所述对应关系中的任意一个函数名,所述函数名是对所述可执行文件中的一个符号表项中记录的所述函数名在所述可执行文件中的第二偏移量反汇编得到的,所述函数名所对应的函数的汇编指令可以是根据所述符号表项中记录的所述汇编指令在所述可执行文件中的第三偏移量获取到的,所述第二偏移量以及所述第三偏移量是至少根据所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量分别获取的;
[0045] 第一筛选模块,用于在所述对应关系中筛选相似度大于预设相似度的至少两个汇编指令;
[0046] 第一查找模块,用于在所述对应关系中查找至少两个汇编指令分别对应的函数的函数名;
[0047] 输出模块,用于输出至少两个汇编指令分别对应的函数的函数名。
[0048] 第六方面,本申请示出了一种数据处理装置,所述装置包括:
[0049] 第五获取模块,用于获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系;
[0050] 其中,对于所述对应关系中的任意一个函数名,所述函数名是对所述可执行文件中的一个符号表项中记录的所述函数名在所述可执行文件中的第二偏移量反汇编得到的,所述函数名所对应的函数的汇编指令可以是根据所述符号表项中记录的所述汇编指令在所述可执行文件中的第三偏移量获取到的,所述第二偏移量以及所述第三偏移量是至少根据所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量分别获取的;
[0051] 第二筛选模块,用于在所述对应关系中筛选相似度大于预设相似度的至少两个汇编指令;
[0052] 第二查找模块,用于在所述对应关系中查找至少两个汇编指令分别对应的函数的函数名;
[0053] 第六获取模块,用于获取所述应用程序的源代码;
[0054] 删除模块,用于在所述源代码中删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码;
[0055] 替换模块,用于将所述源代码中的所述其他函数名替换为所述其中一个函数名,得到所述应用程序的修改后的源代码。
[0056] 在一个可选的实现方式中,所述装置还包括:
[0057] 编译模块,用于编译所述应用程序的修改后的源代码,得到应用程序的新的可执行文件。
[0058] 第七方面,本申请示出了一种电子设备,所述电子设备包括:
[0059] 处理器;
[0060] 用于存储处理器可执行指令的存储器;
[0061] 其中,所述处理器被配置为执行如第一方面所述的数据处理方法。
[0062] 第八方面,本申请示出了一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如第一方面所述的数据处理方法。
[0063] 第九方面,本申请示出了一种计算机程序产品,当所述计算机程序产品中的指令由电子设备的处理器执行时,使得电子设备能够执行如第一方面所述的数据处理方法。
[0064] 第十方面,本申请示出了一种电子设备,所述电子设备包括:
[0065] 处理器;
[0066] 用于存储处理器可执行指令的存储器;
[0067] 其中,所述处理器被配置为执行如第二方面所述的数据处理方法。
[0068] 第十一方面,本申请示出了一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如第二方面所述的数据处理方法。
[0069] 第十二方面,本申请示出了一种计算机程序产品,当所述计算机程序产品中的指令由电子设备的处理器执行时,使得电子设备能够执行如第二方面所述的数据处理方法。
[0070] 第十三方面,本申请示出了一种电子设备,所述电子设备包括:
[0071] 处理器;
[0072] 用于存储处理器可执行指令的存储器;
[0073] 其中,所述处理器被配置为执行如第三方面所述的数据处理方法。
[0074] 第十四方面,本申请示出了一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如第三方面所述的数据处理方法。
[0075] 第十五方面,本申请示出了一种计算机程序产品,当所述计算机程序产品中的指令由电子设备的处理器执行时,使得电子设备能够执行如第三方面所述的数据处理方法。
[0076] 本申请提供的技术方案可以包括以下有益效果:
[0077] 其中,在可执行文件中包括第三方库的情况下,由于第三方库是对第三方库对应的源代码编译得到的,开发人员仅能够得到第三方库,无法得到第三方库对应的源代码编,但是开发人员是无法人工识别编译后得到的第三方库中的内容的含义的,如此,开发人员也仅仅能够检测可执行文件对应的开发人员编写的源代码中是否存在至少两个相同或相似的函数,检测时无法兼顾第三方库,容易漏检,导致检测准确率低。
[0078] 通过本申请,可以基于可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数,此种检测方式不仅可以兼顾可执行文件对应的开发人员编写的源代码,还可以兼顾可执行文件中的第三方库中的函数的汇编指令,避免漏检,从而可以提高检测的全面性,进而提高检测的准确率。
[0079] 另外,整个检测过程可以没有开发人员的参与,可以节省人工成本。
[0080] 其次,在可执行文件中是否存在至少两个相同或相似的函数的情况下,可以在应用程序的源代码中,删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码,并将源代码中的其他函数名替换为该其中一个函数名,得到应用程序的修改后的源代码。不需要人工修改应用程序的源代码即可实现对应用程序的源代码精简,提高了自动化程度,降低了人工成本。
[0081] 以及,如果至少两个相同或相似的函数位于可执行文件中的第三方库中,则可以向第三方库的厂商发送请求,以使第三方库的厂商根据请求对第三方库精简,进而可以降低可执行文件的所占空间。

附图说明

[0082] 图1是本申请的一种数据处理方法的步骤流程图。
[0083] 图2是本申请的一种数据处理方法的步骤流程图。
[0084] 图3是本申请的一种数据处理方法的步骤流程图。
[0085] 图4是本申请的一种数据处理装置的结构框图。
[0086] 图5是本申请的一种数据处理装置的结构框图。
[0087] 图6是本申请的一种数据处理装置的结构框图。
[0088] 图7是本申请的一种电子设备的框图。
[0089] 图8是本申请的一种电子设备的框图。

具体实施方式

[0090] 下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
[0091] 参照图1,示出了本申请的一种数据处理方法的步骤流程图,该方法应用于电子设备,该方法具体可以包括如下步骤:
[0092] 在步骤S101中,根据应用程序的可执行文件中的符号表,获取可执行文件中的各个函数分别对应的符号表项的总数量以及可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量。
[0093] 应用程序的可执行文件可以是对应用程序的源代码编译后得到的。
[0094] 其中,应用程序的源代码中包括几个函数,则应用程序的可执行文件中的符号表中往往就可以包括几个符号表项,应用程序的源代码中的函数与应用程序中的可执行文件中的符号表项一一对应。
[0095] 应用程序的可执行文件中包括符号表。
[0096] 在一个例子中,在应用程序的可执行文件包括Mach‑O文件的情况下,符号表则可以是LC_SYMTAB等。符号表项可以包括nlist_64内存结构的符号表项等。
[0097] 符号表中记录有可执行文件的属性信息等,例如,包括符号表所占的空间大小、可执行文件中包括的符号表项的数量以及可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量等。
[0098] 在本申请中,在电子设备中启动可执行文件的情况下,电子设备可以为可执行文件分配内存地址。例如,可执行文件的内存地址可以为内存中的某一地址至另一地址之间的内存地址等。
[0099] 可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量可以理解为:可执行文件中的第一个函数对应的符号表项在电子设备的内存中的起始地址与可执行文件的内存地址中的首地址之间的距离。
[0100] 在本申请中,符号表在可执行文件中的位置(例如偏移量等)是固定不变的,符号表是存储在可执行文件中的特定的位置中的,因此,电子设备可以在可执行文件中的特定的位置获取符号表,之后可以在符号表中获取可执行文件中的各个函数分别对应的符号表项的总数量以及可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量,然后可以执行步骤S102。
[0101] 其中,“根据应用程序的可执行文件中的符号表,获取可执行文件中的各个函数分别对应的符号表项的总数量”的方式,包括:
[0102] 1011、获取符号表中记录的可执行文件中的各个函数分别对应的符号表项的总数量在符号表中的第四偏移量。
[0103] 本步骤可以通过如下流程实现,包括:
[0104] 11)、确定符号表的内存结构。
[0105] 在本申请中,符号表中往往具有多个内容,不同的内容在符号表中的位置是固定的,因此,符号表的内存结构是固定的。
[0106] 12)、根据符号表的内存结构在符号表中确定可执行文件中的各个函数分别对应的符号表项的总数量在符号表中的第四偏移量。
[0107] 在本申请中,符号表在内存中具有内存地址,这个内存地址为电子设备在为可执行文件分配的内存地址时为符号表分配的,可执行文件中的各个函数分别对应的符号表项的总数量在符号表中的第四偏移量可以理解为:可执行文件中的各个函数分别对应的符号表项的总数量在符号表中的起始地址距离符号表的内存地址的首地址的距离。
[0108] 在符号表的内存结构确定之后,符号表中按照顺序包括哪些内容就确定了,且符号表中的各个内容所占的空间大小也就确定的。
[0109] 如此,符号表中记录的可执行文件中的各个函数分别对应的符号表项的总数量在符号表中的位置顺序即可确定,进而符号表中的位于可执行文件中的各个函数分别对应的符号表项的总数量之前有哪些内容以及这些内容各自所占的空间大小即可确定,因此,根据符号表中的位于可执行文件中的各个函数分别对应的符号表项的总数量之前有哪些内容以及这些内容各自所占的空间大小,即可在符号表中确定出可执行文件中的各个函数分别对应的符号表项的总数量在符号表中的第四偏移量。
[0110] 1012、根据可执行文件中的各个函数分别对应的符号表项的总数量在符号表中的第四偏移量,获取符号表中记录的、可执行文件中的各个函数分别对应的符号表项的总数量。
[0111] 相应地,参考上述方式也可以根据应用程序的可执行文件中的符号表,获取可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量。
[0112] 例如,可以获取符号表中记录的“可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量”在符号表中的第五偏移量,具体获取方式可以参见1011的流程,在此不做详述。然后可以根据“可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量”在符号表中的第五偏移量,获取符号表中记录的、可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量。
[0113] 在步骤S102中,至少根据可执行文件中的各个函数分别对应的符号表项的总数量以及可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量,获取各个符号表项中分别记录的可执行文件中的函数的函数名在可执行文件中的第二偏移量以及各个符号表项中分别记录的可执行文件中的函数的汇编指令在可执行文件中的第三偏移量。
[0114] 在本申请一个实施例中,可执行文件中包括多个符号表项,各个符号表项所占的空间大小相同,可以通过特定的方法获取到符号表项所占的空间大小,例如,通过“sizeof”函数获取符号表项所占的空间大小。
[0115] 符号表中的多个符号表项是依次连续排列在可执行文件中的。
[0116] 如此,由于符号表中记录有可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量,因此,通过特定的方法可以获取到第一个函数对应的符号表项所占的空间大小,根据第一个函数对应的符号表项在可执行文件中的第一偏移量与第一个函数对应的符号表项所占的空间大小,可以确定出可执行文件中的第二个函数对应的符号表项在可执行文件中的第一偏移量。
[0117] 根据第二个函数对应的符号表项在可执行文件中的第一偏移量与第二个函数对应的符号表项所占的空间大小,可以确定出可执行文件中的第三个函数对应的符号表项在可执行文件中的第一偏移量,以此类推,直至确定出可执行文件中的第N个函数对应的符号表项在可执行文件中的第一偏移量为止,其中,N与可执行文件中的各个函数分别对应的符号表项的总数量相同。
[0118] 对于可执行文件中的任意一个符号表项,在得到该符号表项在可执行文件中的第一偏移量之后,可以根据该符号表项在可执行文件中的第一偏移量以及该符号表项所占的空间大小确定该符号表项的内存地址,并获取位于该符号表项的内存地址中的数据。
[0119] 其中,该内存地址中至少记录有该符号表项对应的函数的函数名在可执行文件中的第二偏移量以及该符号表项对应的函数的汇编指令在可执行文件中的第三偏移量。
[0120] 需要说明的是,第二偏移量是函数名的偏移量,不是函数的实现的偏移量,基于第二偏移量可以找到该符号表项对应的函数的函数名。基于第三偏移量可以找到该符号表项对应的函数的汇编指令。
[0121] 例如,在该符号表项的内存地址中,以“键值对(例如key‑value等)”的形式记录该符号表项对应的函数的函数名的第二偏移量以及该符号表项对应的函数的汇编指令的第三偏移量。
[0122] 在一个例子中,该符号表项对应的函数的函数名的第二偏移量为value,该符号表项对应的函数的函数名的第二偏移量对应的key可以为预设的第一特定字符串。
[0123] 该符号表项对应的函数的汇编指令的第三偏移量为value,该符号表项对应的函数的汇编指令的第三偏移量的key可以为预设的第二特定字符串。
[0124] 如此,在该位于该符号表项的内存地址中的数据中,可以根据第一特定字符串获取该符号表项对应的函数的函数名在可执行文件中的第二偏移量,以及,可以根据第二特定字符串获取该符号表项对应的函数的汇编指令在可执行文件中的第三偏移量。
[0125] 对于可执行文件中的其他每一个符号表项,同样如此。
[0126] 在步骤S103中,对于可执行文件中的任意一个符号表项,对该符号表项对应的函数的函数名在可执行文件中的第二偏移量反汇编,得到该符号表项对应的函数的函数名;以及,根据该符号表项对应的函数的汇编指令在可执行文件中的第三偏移量获取该符号表项对应的函数的汇编指令,在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,存储该符号表项对应的函数的函数名与该符号表项对应的函数的汇编指令。
[0127] 对于可执行文件中的其他每一个符号表项,同样如此。
[0128] 在一个实施例中,对该符号表项对应的函数的函数名在可执行文件中的第二偏移量反汇编的反汇编方式可以参见当前已经存在的方式,在此不做详述。
[0129] 其中,在可执行文件中包括第三方库的情况下,由于第三方库是对第三方库对应的源代码编译得到的,开发人员仅能够得到第三方库,无法得到第三方库对应的源代码编,但是开发人员是无法人工识别编译后得到的第三方库中的内容的含义的,如此,开发人员也仅仅能够检测可执行文件对应的开发人员编写的源代码中是否存在至少两个相同或相似的函数,检测时无法兼顾第三方库,容易漏检,导致检测准确率低。
[0130] 而在本申请中,根据应用程序的可执行文件中的符号表,获取可执行文件中的各个函数分别对应的符号表项的总数量以及可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量。至少根据总数量以及第一偏移量,获取各个符号表项中分别记录的可执行文件中的函数的函数名在可执行文件中的第二偏移量以及各个符号表项中分别记录的可执行文件中的函数的汇编指令在可执行文件中的第三偏移量。对于可执行文件中的任意一个符号表项,对该符号表项对应的函数的函数名在可执行文件中的第二偏移量反汇编,得到该符号表项对应的函数的函数名;以及,根据该符号表项对应的函数的汇编指令在可执行文件中的第三偏移量获取该符号表项对应的函数的汇编指令,在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,存储该符号表项对应的函数的函数名与该符号表项对应的函数的汇编指令。
[0131] 通过本申请,不仅可以得到可执行文件对应的开发人员编写的源代码中的函数的汇编指令,还可以得到可执行文件中的第三方库中的函数的汇编指令,函数的汇编指令可以体现出函数的实现原理,因此,在得到可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及可执行文件中的第三方库中的函数的汇编指令的情况下,之后通过汇编指令即可检测可执行文件中是否存在至少两个相同或相似的函数,此种检测方式不仅可以兼顾可执行文件对应的开发人员编写的源代码,还可以兼顾可执行文件中的第三方库中的函数的汇编指令,避免漏检,从而可以提高检测的全面性,进而提高检测的准确率。
[0132] 在一个实施例中,在得到可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系之后,就可以根据可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系检测可执行文件中是否存在至少两个相同或相似的函数,并在可执行文件中存在至少两个相同或相似的函数的情况下,可以输出至少两个相同或相似的函数的函数名,以供开发人员查看至少两个相同或相似的函数的函数名,之后开发人员可以根据至少两个相同或相似的函数的函数名对应用程序的源代码修改,例如,在源代码中保留至少两个相同或相似的函数中的其中一个函数,以达到精简应用程序的源代码的目的,进而可以降低之后根据精简后的源代码生成的应用程序的新的可执行文件的所占空间。
[0133] 具体地,参照图2,示出了本申请的一种数据处理方法的步骤流程图,该方法应用于电子设备,该方法具体可以包括如下步骤:
[0134] 在步骤S201中,获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系。
[0135] 其中,对于可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中的任意一个函数名,该函数名可以是对“可执行文件中的一个符号表项中记录的该函数名在可执行文件中的第二偏移量”反汇编得到的,该函数名所对应的函数的汇编指令可以是根据该符号表项中记录的该汇编指令在可执行文件中的第三偏移量获取到的。第二偏移量以及第三偏移量是至少根据可执行文件中的各个函数分别对应的符号表项的总数量以及可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量分别获取的。
[0136] 对于可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中的其他每一个函数的函数名,同样如此。
[0137] 在本申请一个实施例中,可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系可以是电子设备实时地根据应用程序的可执行文件生成的,具体生成方式可以参见图1所示的实施例,在此不做详述。
[0138] 在本申请另一个实施例中,可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系可以是事先按照图1所示的实施例生成的。
[0139] 例如,可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系可以是电子设备自己事先生成的并存储在电子设备中的,具体生成方式可以参见图1所示的实施例,在此不做详述。如此,在本步骤中,电子设备可以获取本地存储的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系。
[0140] 再例如,可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系可以是其他设备事先生成的并存储在云端的,具体生成方式可以参见图1所示的实施例,在此不做详述。如此,在本步骤中,电子设备从云端下载可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系。
[0141] 在步骤S202中,在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,筛选相似度大于预设相似度的至少两个汇编指令。
[0142] 在本申请中,在计算可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中的任意两个汇编指令之间的相似度时,可以参考当前已经存在的方式,本申请对具体的计算方式不做限定。
[0143] 以及,预设相似度可以根据实际情况而定,本申请对此不做限定。例如,预设相似度可以根据选取的计算相似度的计算方式而定等。
[0144] 在步骤S203中,在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,查找至少两个汇编指令分别对应的函数的函数名。
[0145] 对于至少两个汇编指令中的任意一个汇编指令,可以在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,查找该汇编指令对应的函数名,对于至少两个汇编指令中的其他每一个汇编指令,同样如此。
[0146] 在步骤S204中,输出至少两个汇编指令分别对应的函数的函数名。
[0147] 在本申请一个实施例中,可以在电子设备的屏幕上显示提示信息,提示信息包括至少两个汇编指令分别对应的函数的函数名,提示信息用于指示应用程序中的至少两个函数名对应的函数之间的相似度大于预设相似度,也即,其可以向用户提示至少两个函数名对应的函数可能为相同的函数或者为相似(例如功能相似)的函数。
[0148] 或者,在本申请一个实施例中,可以使用电子设备的音响播放提示信息,提示信息包括至少两个汇编指令分别对应的函数的函数名,提示信息用于指示应用程序中的至少两个函数名对应的函数之间的相似度大于预设相似度,也即,其可以向用户提示至少两个函数名对应的函数可能为相同的函数或者为相似(例如功能相似)的函数。
[0149] 在开发人员感知到该提示信息之后,就可以获知应用程序中的至少两个函数名对应的函数之间的相似度大于预设相似度,也即,用户可以获知至少两个函数名对应的函数可能为相同的函数或者为相似(例如功能相似)的函数,开发人员可以对应用程序的源代码修改,例如,在源代码中保留至少两个相同或相似的函数中的其中一个函数,以达到精简应用程序的源代码的目的,进而可以降低之后根据精简后的源代码生成的应用程序的可执行文件的所占空间。
[0150] 或者,在本申请一个实施例中,还可以在电子设备中的预设文件中记录至少两个汇编指令分别对应的函数的函数名,以供开发人员之后在需要的时候在预设文件中可以查看至少两个汇编指令分别对应的函数的函数名。
[0151] 或者,在本申请一个实施例中,还可以将至少两个汇编指令分别对应的函数的函数名通过邮件、短信或PUSH消息等任何可用方式发送给相关开发人员,以供开发人员查看至少两个汇编指令分别对应的函数的函数名等。
[0152] 其中,在可执行文件中包括第三方库的情况下,由于第三方库是对第三方库对应的源代码编译得到的,开发人员仅能够得到第三方库,无法得到第三方库对应的源代码编,但是开发人员是无法人工识别编译后得到的第三方库中的内容的含义的,如此,开发人员也仅仅能够检测可执行文件对应的开发人员编写的源代码中是否存在至少两个相同或相似的函数,检测时无法兼顾第三方库,容易漏检,导致检测准确率低。
[0153] 而在本申请中,获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系。在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,筛选相似度大于预设相似度的至少两个汇编指令。在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,查找至少两个汇编指令分别对应的函数的函数名。输出至少两个汇编指令分别对应的函数的函数名。
[0154] 通过本申请,可以基于可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数,此种检测方式不仅可以兼顾可执行文件对应的开发人员编写的源代码,还可以兼顾可执行文件中的第三方库中的函数的汇编指令,避免漏检,从而可以提高检测的全面性,进而提高检测的准确率。
[0155] 另外,整个检测过程可以没有开发人员的参与,可以节省人工成本。
[0156] 在一个实施例中,在得到可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系之后,就可以根据可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系检测可执行文件中是否存在至少两个相同或相似的函数,并在可执行文件中存在至少两个相同或相似的函数的情况下,根据至少两个相同或相似的函数的函数名对应用程序的源代码修改,例如,在源代码中保留至少两个相同或相似的函数中的其中一个函数,以达到精简应用程序的源代码的目的,进而可以降低之后根据精简后的源代码生成的应用程序的新的可执行文件的所占空间。
[0157] 具体地,参照图3,示出了本申请的一种数据处理方法的步骤流程图,该方法应用于电子设备,该方法具体可以包括如下步骤:
[0158] 在步骤S301中,获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系。
[0159] 其中,对于可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中的任意一个函数名,该函数名可以是对“可执行文件中的一个符号表项中记录的该函数名在可执行文件中的第二偏移量”反汇编得到的,该函数名所对应的函数的汇编指令可以是根据该符号表项中记录的该汇编指令在可执行文件中的第三偏移量获取到的。第二偏移量以及第三偏移量是至少根据可执行文件中的各个函数分别对应的符号表项的总数量以及可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量分别获取的。
[0160] 对于可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中的其他每一个函数的函数名,同样如此。
[0161] 在本申请一个实施例中,可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系可以是电子设备实时地根据应用程序的可执行文件生成的,具体生成方式可以参见图1所示的实施例,在此不做详述。
[0162] 在本申请另一个实施例中,可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系可以是事先按照图1所示的实施例生成的。
[0163] 例如,可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系可以是电子设备自己事先生成的并存储在电子设备中的,具体生成方式可以参见图1所示的实施例,在此不做详述。如此,在本步骤中,电子设备可以获取本地存储的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系。
[0164] 再例如,可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系可以是其他设备事先生成的并存储在云端的,具体生成方式可以参见图1所示的实施例,在此不做详述。如此,在本步骤中,电子设备从云端下载可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系。
[0165] 在步骤S302中,在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,筛选相似度大于预设相似度的至少两个汇编指令。
[0166] 在本申请中,在计算可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中的任意两个汇编指令之间的相似度时,可以参考当前已经存在的方式,本申请对具体的计算方式不做限定。
[0167] 以及,预设相似度可以根据实际情况而定,本申请对此不做限定。例如,预设相似度可以根据选取的计算相似度的计算方式而定等。
[0168] 在步骤S303中,在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,查找至少两个汇编指令分别对应的函数的函数名。
[0169] 对于至少两个汇编指令中的任意一个汇编指令,可以在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,查找该汇编指令对应的函数名,对于至少两个汇编指令中的其他每一个汇编指令,同样如此。
[0170] 在步骤S304中,获取应用程序的源代码,在应用程序的源代码中,删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码。
[0171] 在本申请中,由于至少两个函数的汇编指令之间的相似度大于预设相似度,则往往说明至少两个函数的汇编指令的功能几乎相同,在这种情况下,应用程序的源代码中往往也就不需要同时存在至少两个函数,应用程序的源代码中可以仅仅保留其中一个函数即可即可,从而可以精简应用程序的源代码。
[0172] 该其中一个函数名可以为查找到的至少两个汇编指令分别对应的函数的函数名中的任意一个函数名,或者,可以为开发人员在查找到的至少两个汇编指令分别对应的函数的函数名中指定的一个函数名等。
[0173] 可以在应用程序的源代码中查找其他函数名对应的函数的代码,并在应用程序的源代码中删除查找到的代码。
[0174] 在步骤S305中,将源代码中的其他函数名替换为该其中一个函数名,得到应用程序的修改后的源代码。
[0175] 其中,在应用程序的源代码中,有一些组件需要调用除其中一个函数名以外的其他函数名对应的函数,因此,这些组件中会存在该其他函数名,但是,在应用程序的源代码中删除该其他函数名对应的函数的代码之后,应用程序的源代码中即不再存在该其他函数名对应的函数,这样,即使这些组件中存在该其他函数名,也无法通过该其他函数名调用到该其他函数名对应的函数,如此,这些组件就无法使用该其他函数名对应的函数的功能。
[0176] 因此,为了使得这些组件就能够使用该其他函数名对应的函数的功能,在应用程序的源代码中删除该其他函数名对应的函数的代码之后,可以将源代码中的该其他函数名替换为该其中一个函数名,得到应用程序的修改后的源代码,如此,源代码中的该其他函数名就会被替换为该其中一个函数名,这样,这些组件就可以通过该其中一个函数名在应用程序中调用到该其中一个函数名对应的函数,如此,这些组件就可以使用该其中一个函数名对应的函数的功能。
[0177] 由于该其中一个函数名对应的函数的汇编指令与该其他函数名对应的函数的汇编指令之间的相似度非常大甚至相同,因此,该其中一个函数名对应的函数的功能与该其他函数名对应的函数的功能之间的相似度非常大甚至相同,所以,组件使用该其中一个函数名对应的函数实现的目的与使用该其他函数名对应的函数实现的目的几乎相同,因此,组件使用该其中一个函数名对应的函数的功能相当于使用该其他函数名对应的函数的功能。
[0178] 其中,在可执行文件中包括第三方库的情况下,由于第三方库是对第三方库对应的源代码编译得到的,开发人员仅能够得到第三方库,无法得到第三方库对应的源代码编,但是开发人员是无法人工识别编译后得到的第三方库中的内容的含义的,如此,开发人员也仅仅能够检测可执行文件对应的开发人员编写的源代码中是否存在至少两个相同或相似的函数,检测时无法兼顾第三方库,容易漏检,导致检测准确率低。
[0179] 而在本申请中,获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系。在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,筛选相似度大于预设相似度的至少两个汇编指令。在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,查找至少两个汇编指令分别对应的函数的函数名。获取应用程序的源代码,在应用程序的源代码中,删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码。将源代码中的其他函数名替换为该其中一个函数名,得到应用程序的修改后的源代码。
[0180] 通过本申请,可以基于可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数,此种检测方式不仅可以兼顾可执行文件对应的开发人员编写的源代码,还可以兼顾可执行文件中的第三方库中的函数的汇编指令,避免漏检,从而可以提高检测的全面性,进而提高检测的准确率。
[0181] 另外,整个检测过程可以没有开发人员的参与,可以节省人工成本。
[0182] 其次,在可执行文件中是否存在至少两个相同或相似的函数的情况下,可以在应用程序的源代码中,删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码,并将源代码中的其他函数名替换为该其中一个函数名,得到应用程序的修改后的源代码。不需要人工修改应用程序的源代码即可实现对应用程序的源代码精简,提高了自动化程度,降低了人工成本。
[0183] 以及,如果至少两个相同或相似的函数位于可执行文件中的第三方库中,则可以向第三方库的厂商发送请求,以使第三方库的厂商根据请求对第三方库精简,进而可以降低可执行文件的所占空间。
[0184] 进一步地,在得到应用程序的修改后的源代码之后,可以自动编译应用程序的修改后的源代码,得到应用程序的新的可执行文件。
[0185] 如此,不需要人工编译应用程序的修改后的源代码,提高了自动化程度,降低了人工成本。
[0186] 需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域开发人员应该知悉,本申请并不受所描述的动作顺序的限制,因为依据本申请,某些步骤可以采用其他顺序或者同时进行。其次,本领域开发人员也应该知悉,说明书中所描述的实施例均属于可选实施例,所涉及的动作并不一定是本申请所必须的。
[0187] 参照图4,示出了本申请的一种数据处理装置的结构框图,该装置具体可以包括如下模块:
[0188] 第一获取模块11,用于根据应用程序的可执行文件中的符号表,获取所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量;
[0189] 第二获取模块12,用于至少根据所述总数量以及所述第一偏移量,获取各个符号表项中分别记录的所述可执行文件中的函数的函数名在所述可执行文件中的第二偏移量以及各个符号表项中分别记录的所述可执行文件中的函数的汇编指令在所述可执行文件中的第三偏移量;
[0190] 反汇编模块13,用于对于所述可执行文件中的任意一个符号表项,对所述符号表项对应的函数的函数名在所述可执行文件中的第二偏移量反汇编,得到所述符号表项对应的函数的函数名;第三获取模块14,用于根据所述符号表项对应的函数的汇编指令在可执行文件中的第三偏移量获取所述符号表项对应的函数的汇编指令;存储模块15,用于在所述可执行文件中的函数的函数名与所述可执行文件中的函数的汇编指令之间的对应关系中,存储所述符号表项对应的函数的函数名与所述符号表项对应的函数的汇编指令。
[0191] 在一个可选的实现方式中,所述以获取模块包括:
[0192] 第一获取单元,用于获取所述符号表中记录的可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量。
[0193] 第二获取单元,用于根据所述第四偏移量,获取所述符号表中记录的、所述可执行文件中的各个函数分别对应的符号表项的总数量。
[0194] 在一个可选的实现方式中,所述第一获取单元包括:
[0195] 第一确定子单元,用于确定所述符号表的内存结构;
[0196] 第二确定子单元,用于根据所述符号表的内存结构在所述符号表中确定所述可执行文件中的各个函数分别对应的符号表项的总数量在所述符号表中的第四偏移量。
[0197] 其中,在可执行文件中包括第三方库的情况下,由于第三方库是对第三方库对应的源代码编译得到的,开发人员仅能够得到第三方库,无法得到第三方库对应的源代码编,但是开发人员是无法人工识别编译后得到的第三方库中的内容的含义的,如此,开发人员也仅仅能够检测可执行文件对应的开发人员编写的源代码中是否存在至少两个相同或相似的函数,检测时无法兼顾第三方库,容易漏检,导致检测准确率低。
[0198] 而在本申请中,根据应用程序的可执行文件中的符号表,获取可执行文件中的各个函数分别对应的符号表项的总数量以及可执行文件中的第一个函数对应的符号表项在可执行文件中的第一偏移量。至少根据总数量以及第一偏移量,获取各个符号表项中分别记录的可执行文件中的函数的函数名在可执行文件中的第二偏移量以及各个符号表项中分别记录的可执行文件中的函数的汇编指令在可执行文件中的第三偏移量。对于可执行文件中的任意一个符号表项,对该符号表项对应的函数的函数名在可执行文件中的第二偏移量反汇编,得到该符号表项对应的函数的函数名;以及,根据该符号表项对应的函数的汇编指令在可执行文件中的第三偏移量获取该符号表项对应的函数的汇编指令,在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,存储该符号表项对应的函数的函数名与该符号表项对应的函数的汇编指令。
[0199] 通过本申请,不仅可以得到可执行文件对应的开发人员编写的源代码中的函数的汇编指令,还可以得到可执行文件中的第三方库中的函数的汇编指令,函数的汇编指令可以体现出函数的实现原理,因此,在得到可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及可执行文件中的第三方库中的函数的汇编指令的情况下,之后通过汇编指令即可检测可执行文件中是否存在至少两个相同或相似的函数,此种检测方式不仅可以兼顾可执行文件对应的开发人员编写的源代码,还可以兼顾可执行文件中的第三方库中的函数的汇编指令,避免漏检,从而可以提高检测的全面性,进而提高检测的准确率。
[0200] 参照图5,示出了本申请的一种数据处理装置的结构框图,该装置具体可以包括如下模块:
[0201] 第四获取模块21,用于获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系;
[0202] 其中,对于所述对应关系中的任意一个函数名,所述函数名是对所述可执行文件中的一个符号表项中记录的所述函数名在所述可执行文件中的第二偏移量反汇编得到的,所述函数名所对应的函数的汇编指令可以是根据所述符号表项中记录的所述汇编指令在所述可执行文件中的第三偏移量获取到的,所述第二偏移量以及所述第三偏移量是至少根据所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量分别获取的;
[0203] 第一筛选模块22,用于在所述对应关系中筛选相似度大于预设相似度的至少两个汇编指令;
[0204] 第一查找模块23,用于在所述对应关系中查找至少两个汇编指令分别对应的函数的函数名;
[0205] 输出模块24,用于输出至少两个汇编指令分别对应的函数的函数名。
[0206] 其中,在可执行文件中包括第三方库的情况下,由于第三方库是对第三方库对应的源代码编译得到的,开发人员仅能够得到第三方库,无法得到第三方库对应的源代码编,但是开发人员是无法人工识别编译后得到的第三方库中的内容的含义的,如此,开发人员也仅仅能够检测可执行文件对应的开发人员编写的源代码中是否存在至少两个相同或相似的函数,检测时无法兼顾第三方库,容易漏检,导致检测准确率低。
[0207] 而在本申请中,获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系。在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,筛选相似度大于预设相似度的至少两个汇编指令。在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,查找至少两个汇编指令分别对应的函数的函数名。输出至少两个汇编指令分别对应的函数的函数名。
[0208] 通过本申请,可以基于可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数,此种检测方式不仅可以兼顾可执行文件对应的开发人员编写的源代码,还可以兼顾可执行文件中的第三方库中的函数的汇编指令,避免漏检,从而可以提高检测的全面性,进而提高检测的准确率。
[0209] 另外,整个检测过程可以没有开发人员的参与,可以节省人工成本。
[0210] 参照图6,示出了本申请的一种数据处理装置的结构框图,该装置具体可以包括如下模块:
[0211] 第五获取模块31,用于获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系;
[0212] 其中,对于所述对应关系中的任意一个函数名,所述函数名是对所述可执行文件中的一个符号表项中记录的所述函数名在所述可执行文件中的第二偏移量反汇编得到的,所述函数名所对应的函数的汇编指令可以是根据所述符号表项中记录的所述汇编指令在所述可执行文件中的第三偏移量获取到的,所述第二偏移量以及所述第三偏移量是至少根据所述可执行文件中的各个函数分别对应的符号表项的总数量以及所述可执行文件中的第一个函数对应的符号表项在所述可执行文件中的第一偏移量分别获取的;
[0213] 第二筛选模块32,用于在所述对应关系中筛选相似度大于预设相似度的至少两个汇编指令;
[0214] 第二查找模块33,用于在所述对应关系中查找至少两个汇编指令分别对应的函数的函数名;
[0215] 第六获取模块34,用于获取所述应用程序的源代码;
[0216] 删除模块35,用于在所述源代码中删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码;
[0217] 替换模块36,用于将所述源代码中的所述其他函数名替换为所述其中一个函数名,得到所述应用程序的修改后的源代码。
[0218] 在一个可选的实现方式中,所述装置还包括:
[0219] 编译模块,用于编译所述应用程序的修改后的源代码,得到应用程序的新的可执行文件。
[0220] 其中,在可执行文件中包括第三方库的情况下,由于第三方库是对第三方库对应的源代码编译得到的,开发人员仅能够得到第三方库,无法得到第三方库对应的源代码编,但是开发人员是无法人工识别编译后得到的第三方库中的内容的含义的,如此,开发人员也仅仅能够检测可执行文件对应的开发人员编写的源代码中是否存在至少两个相同或相似的函数,检测时无法兼顾第三方库,容易漏检,导致检测准确率低。
[0221] 而在本申请中,获取应用程序的可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系。在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,筛选相似度大于预设相似度的至少两个汇编指令。在可执行文件中的函数的函数名与可执行文件中的函数的汇编指令之间的对应关系中,查找至少两个汇编指令分别对应的函数的函数名。获取应用程序的源代码,在应用程序的源代码中,删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码。将源代码中的其他函数名替换为该其中一个函数名,得到应用程序的修改后的源代码。
[0222] 通过本申请,可以基于可执行文件对应的开发人员编写的源代码中的函数的汇编指令以及可执行文件中的第三方库中的函数的汇编指令,检测可执行文件中是否存在至少两个相同或相似的函数,此种检测方式不仅可以兼顾可执行文件对应的开发人员编写的源代码,还可以兼顾可执行文件中的第三方库中的函数的汇编指令,避免漏检,从而可以提高检测的全面性,进而提高检测的准确率。
[0223] 另外,整个检测过程可以没有开发人员的参与,可以节省人工成本。
[0224] 其次,在可执行文件中是否存在至少两个相同或相似的函数的情况下,可以在应用程序的源代码中,删除查找到的函数名中的除其中一个函数名以外的其他函数名对应的函数的代码,并将源代码中的其他函数名替换为该其中一个函数名,得到应用程序的修改后的源代码。不需要人工修改应用程序的源代码即可实现对应用程序的源代码精简,提高了自动化程度,降低了人工成本。
[0225] 以及,如果至少两个相同或相似的函数位于可执行文件中的第三方库中,则可以向第三方库的厂商发送请求,以使第三方库的厂商根据请求对第三方库精简,进而可以降低可执行文件的所占空间。
[0226] 对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
[0227] 可选的,本发明实施例还提供了一种电子设备,包括:处理器,存储器,存储在存储器上并可在处理器上运行的计算机程序,该计算机程序被处理器执行时实现上述数据处理方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。
[0228] 本发明实施例还提供了一种计算机可读存储介质,计算机可读存储介质上存储有计算机程序,计算机程序被处理器执行时实现上述数据处理方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。其中,所述的计算机可读存储介质,如只读存储器(Read‑Only Memory,简称ROM)、随机存取存储器(Random Access Memory,简称RAM)、磁碟或者光盘等。
[0229] 图7是本申请示出的一种电子设备800的框图。例如,电子设备800可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
[0230] 参照图7,电子设备800可以包括以下一个或多个组件:处理组件802,存储器804,电力组件806,多媒体组件808,音频组件810,输入/输出(I/O)的接口812,传感器组件814,以及通信组件816。
[0231] 处理组件802通常控制电子设备800的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件802可以包括一个或多个处理器820来执行指令,以完成上述方法的全部或部分步骤。此外,处理组件802可以包括一个或多个模块,便于处理组件802和其他组件之间的交互。例如,处理组件802可以包括多媒体模块,以方便多媒体组件808和处理组件802之间的交互。
[0232] 存储器804被配置为存储各种类型的数据以支持在设备800的操作。这些数据的示例包括用于在电子设备800上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图像,视频等。存储器804可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
[0233] 电源组件806为电子设备800的各种组件提供电力。电源组件806可以包括电源管理系统,一个或多个电源,及其他与为电子设备800生成、管理和分配电力相关联的组件。
[0234] 多媒体组件808包括在所述电子设备800和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件808包括一个前置摄像头和/或后置摄像头。当设备800处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
[0235] 音频组件810被配置为输出和/或输入音频信号。例如,音频组件810包括一个麦克风(MIC),当电子设备800处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收到的音频信号可以被进一步存储在存储器804或经由通信组件816发送。在一些实施例中,音频组件810还包括一个扬声器,用于输出音频信号。
[0236] I/O接口812为处理组件802和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
[0237] 传感器组件814包括一个或多个传感器,用于为电子设备800提供各个方面的状态评估。例如,传感器组件814可以检测到设备800的打开/关闭状态,组件的相对定位,例如所述组件为电子设备800的显示器和小键盘,传感器组件814还可以检测电子设备800或电子设备800一个组件的位置改变,用户与电子设备800接触的存在或不存在,电子设备800方位或加速/减速和电子设备800的温度变化。传感器组件814可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件814还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件814还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
[0238] 通信组件816被配置为便于电子设备800和其他设备之间有线或无线方式的通信。电子设备800可以接入基于通信标准的无线网络,如WiFi,运营商网络(如2G、3G、4G或5G),或它们的组合。在一个示例性实施例中,通信组件816经由广播信道接收来自外部广播管理系统的广播信号或广播操作信息。在一个示例性实施例中,所述通信组件816还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
[0239] 在示例性实施例中,电子设备800可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
[0240] 在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器804,上述指令可由电子设备800的处理器820执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD‑ROM、磁带、软盘和光数据存储设备等。
[0241] 图8是本申请示出的一种电子设备1900的框图。例如,电子设备1900可以被提供为一服务器。
[0242] 参照图8,电子设备1900包括处理组件1922,其进一步包括一个或多个处理器,以及由存储器1932所代表的存储器资源,用于存储可由处理组件1922的执行的指令,例如应用程序。存储器1932中存储的应用程序可以包括一个或一个以上的每一个对应于一组指令的模块。此外,处理组件1922被配置为执行指令,以执行上述方法。
[0243] 电子设备1900还可以包括一个电源组件1926被配置为执行电子设备1900的电源管理,一个有线或无线网络接口1950被配置为将电子设备1900连接到网络,和一个输入输出(I/O)接口1958。电子设备1900可以操作基于存储在存储器1932的操作系统,例如Windows ServerTM,Mac OS XTM,UnixTM,LinuxTM,FreeBSDTM或类似。
[0244] 需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
[0245] 通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
[0246] 上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,均属于本发明的保护之内。
[0247] 本领域普通技术人员可以意识到,结合本发明实施例中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
[0248] 所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统、装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
[0249] 在本申请所提供的实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
[0250] 所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
[0251] 另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。
[0252] 所述功能如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、ROM、RAM、磁碟或者光盘等各种可以存储程序代码的介质。
[0253] 以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以权利要求的保护范围为准。