CN111090854A - 目标程序的执行与转换方法、装置、终端和存储介质 - Google Patents

目标程序的执行与转换方法、装置、终端和存储介质 Download PDF

Info

Publication number
CN111090854A
CN111090854A CN201911165563.5A CN201911165563A CN111090854A CN 111090854 A CN111090854 A CN 111090854A CN 201911165563 A CN201911165563 A CN 201911165563A CN 111090854 A CN111090854 A CN 111090854A
Authority
CN
China
Prior art keywords
program
file
target
target program
information
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201911165563.5A
Other languages
English (en)
Inventor
郑靖博
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Shanghai Dameng Database Co Ltd
Original Assignee
Shanghai Dameng Database Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Shanghai Dameng Database Co Ltd filed Critical Shanghai Dameng Database Co Ltd
Priority to CN201911165563.5A priority Critical patent/CN111090854A/zh
Publication of CN111090854A publication Critical patent/CN111090854A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/50Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
    • G06F21/52Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow
    • G06F21/54Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow by adding security routines or objects to programs

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)

Abstract

本发明实施例公开了一种目标程序的执行与转换方法、装置、终端和存储介质。所述目标程序的执行方法包括:获取对应目标程序的程序文件的内容信息和类型信息;根据所述内容信息生成所述目标程序的程序文件;基于所述类型信息调用所述程序文件,以控制所述目标程序执行。本发明实施例通过采用上述技术方案,通过控制程序控制目标程序运行,能够增大非法人员获取目标程序的程序代码的难度,从而降低目标程序的程序代码被窃取与修改的概率,提高目标程序的安全性。

Description

目标程序的执行与转换方法、装置、终端和存储介质
技术领域
本发明涉及软件控制技术领域,尤其涉及一种目标程序的执行与转换方法、装置、终端和存储介质。
背景技术
程序是计算机设备上运行的计算机设备能够识别和执行的指令,其是计算机运行以及计算机满足人们使用需求的基础。
在计算机设备中,较简单的程序可以以一个脚本或者一个二进制的可执行文件的方式呈现,此种程序可以称之为单文件程序;较复杂的程序,由于其程序的构成较复杂,一般由若干个可执行文件和数据文件组成,因此,需要以多个文件的方式件呈现,此种程序可以称之为多文件程序。
但是,无论是单文件程序还是多文件程序,其程序内容对用户均是可见的,用户可以自行查看和修改程序的程序代码,使得程序代码极易被窃取与修改,不利于程序的安全运行。
发明内容
有鉴于此,本发明实施例提供一种目标程序的执行与转换方法、装置、终端和存储介质,以降低程序的程序代码被窃取与修改的概率,提高程序的安全性。
第一方面,本发明实施例提供了一种目标程序的执行方法,包括:
获取对应目标程序的程序文件的内容信息和类型信息;
根据所述内容信息生成所述目标程序的程序文件;
基于所述类型信息调用所述程序文件,以控制所述目标程序执行。
第二方面,本发明实施例提供了一种目标程序的转换方法,包括:
获取目标程序的程序文件的内容信息和类型信息;
分别将所述内容信息和所述类型信息添加至预设控制程序模板的相应位置,得到所述目标程序对应的控制程序,以通过所述控制程序控制所述目标程序执行。
第三方面,本发明实施例提供了一种目标程序的执行装置,包括:
第一信息获取模块,用于获取对应目标程序的程序文件的内容信息和类型信息;
文件生成模块,用于根据所述内容信息生成所述目标程序的程序文件;
基于所述类型信息调用所述程序文件,以控制所述目标程序执行。
第四方面,本发明实施例提供了一种目标程序的转换装置,包括:
第二信息获取模块,用于获取目标程序的程序文件的内容信息和类型信息;
信息添加模块,用于分别将所述内容信息和所述类型信息添加至预设控制程序模板的相应位置,得到所述目标程序对应的控制程序,以通过所述控制程序控制所述目标程序执行。
第五方面,本发明实施例提供了一种终端,包括:
一个或多个处理器;
存储器,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如本发明实施例所述的目标程序的执行方法或者实现如本发明实施例所述的目标程序的转换方法。
第六方面,本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如本发明实施例所述的目标程序的执行方法或者实现如本发明实施例所述的目标程序的转换方法。
本发明实施例提供的目标程序的执行与转换方法、装置、终端和存储介质,获取控制程序对应的目标程序的程序文件的内容信息和类型信息,根据该内容信息生成目标程序的程序文件,并基于该类型信息调用所生成的目标程序的程序文件,从而控制目标程序执行。本发明实施例通过采用上述技术方案,通过控制程序控制目标程序运行,能够增大非法人员获取目标程序的程序代码的难度,从而降低目标程序的程序代码被窃取与修改的概率,提高目标程序的安全性。
附图说明
通过阅读参照以下附图所作的对非限制性实施例所作的详细描述,本发明的其它特征、目的和优点将会变得更明显:
图1为本发明实施例一提供的一种目标程序的执行方法的流程示意图;
图2为本发明实施例一提供的一种控制程序的程序结构示意图;
图3为本发明实施例二提供的一种目标程序的转换方法的流程示意图;
图4为本发明实施例三提供的一种目标程序的执行装置的结构框图;
图5为本发明实施例四提供的一种目标程序的转换装置的结构框图;
图6为本发明实施例五提供的一种终端的结构示意图。
具体实施方式
下面结合附图和实施例对本发明作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明相关的部分而非全部内容。此外,在不冲突的情况下,本发明中的实施例及实施例中的特征可以相互组合
实施例一
本发明实施例一提供一种目标程序的执行方法。该方法可以由目标程序的执行装置执行,其中,该装置可以由软件和/或硬件实现,本实施例以目标程序的执行装置由软件实现为例进行说明,目标程序的执行装置一般可集成于用户终端中,可适用于基于控制目标程序执行的场景,尤其适用于控制多文件目标程序执行的场景。图1为本发明实施例一提供的一种目标程序的执行方法的流程示意图,如图1所示,所述方法包括:
S110、获取对应目标程序的程序文件的内容信息和类型信息。
在本实施例中,控制程序(即以软件的方式实现时的目标程序的执行装置)可以在当前条件满足执行程序的运行条件时运行并获取对应目标程序的程序文件的内容信息和类型信息。其中,控制程序为本发明实施例所构建的用于控制目标程序执行的程序,控制程序的运行条件可以根据需要设置,如可以在控制程序下载至用户终端时自动运行、用户终端开机启动时自动运行或者在用户触发控制程序时运行等等;目标程序可以为单文件程序或多文件程序,目标程序的程序文件可包括构成目标程序的所有文件,如可执行文件和/或数据文件,相应的,其内容信息可理解为其可执行文件和/或数据文件的代码信息。
在本步骤中,可以自控制程序的程序文件中读取目标程序的程序文件的内容信息和类型信息;也可以自用户终端或服务器相应的存储位置获取目标程序的程序文件的内容信息和类型信息。当自用户终端或服务器相应的存储位置获取目标程序的程序文件的内容信息和类型信息时,举例而言,用户终端下载目标程序的控制程序时,同步下载目标程序的程序文件的内容信息和类型信息(对用户不可见),并将其与目标程序的控制程序关联存储,控制程序启动后自用户终端中获取与其关联存储的目标程序的程序文件的内容信息和类型信息;或者,预先将目标文件的内容信息和类型信息存储于服务器中,并在构建目标程序对应的执行程序时,将目标程序的程序ID添加于控制程序的程序代码的相应位置,从而,控制程序在执行至相应程序代码时,生成携带有目标程序的程序ID的请求信息并将其发送至服务器,服务器基于该请求信息中携带的程序ID查询得到目标程序的程序文件的内容信息和类型信息,并将其发送至用户终端,以使目标程序对应的控制程序获取得到目标程序的程序文件的内容信息和类型信息。
为了减少目标程序执行所占用的网络资源,并保证控制程序的完整性,优选的,控制程序可以自自身的程序文件中获取目标程序的程序文件的内容信息和类型信息,从而使得控制程序为单文件程序,降低控制程序在传输过程中发生数据丢失的概率,并降低控制程序完整性校验的复杂程度。此时,相应的,在构建目标程序的控制程序时,可以分别将目标程序的程序文件的内容信息和类型信息拷贝至所述控制程序的相应位置,即拷贝至控制程序的程序文件的相应位置,从而,控制程序运行后可以自该相应位置获取目标程序的程序文件的内容信息和类型信息。
其中,内容信息和类型信息在控制程序程序文件的位置可以根据控制程序的运行逻辑设置,该运行逻辑可以由开发人员预先编写。可选的,可以将控制程序划分为程序部分和数据部分两部分,从而,在数据部分记录目标程序的程序文件的内容信息,在程序部分记录控制程序的运行逻辑,并在该运行逻辑的相应行记录目标程序的程序文件的类型信息。
此时,所述获取对应目标程序的程序文件的内容信息和类型信息,可优化包括:根据控制程序中程序部分的长度信息确定数据部分在所述控制程序中的位置信息,并基于所述位置信息获取对应目标程序的程序文件的内容信息,其中,所述控制程序由程序部分和数据部分组成,所述数据部分用于记载对应目标程序的程序文件的内容信息;以及,获取控制程序中记载的对应目标程序的程序文件的类型信息。
在上述优化中,程序部分所记录的执行程序可以为shell脚本,程序部分和数据部分的位置关系可以根据需要灵活设置,如程序部分可以位于数据部分的前面或后面。以程序部分位于数据部分的前面为例(此时控制程序的程序结构如图2所示),在获取目标程序的程序文件的内容信息时,可以自程序部分读取控制程序中程序部分的长度信息,根据该长度信息确定数据部分在控制程序中的起始位置,即确定目标程序的程序文件的内容信息在控制程序中的起始位置,并自该起始位置开始,获取该起始位置之后(包括该起始位置处)记录的所有信息,作为目标程序的程序文件的内容信息;在获取目标程序的程序文件的类型信息时,依次执行控制程序的各行执行程序,执行至类型信息所属行时即可得到目标程序的程序文件的类型信息。
S120、根据所述内容信息生成目标程序的程序文件。
示例性的,可以在用户终端内生成一个空白文件,并将目标程序的程序文件的内容信息粘贴至该空白文件中,即可得到目标程序的程序文件。其中,生成程序文件的过程可以视为对构建控制程序时所依据的目标程序的程序文件的还原过程,生成得到的目标程序的程序文件可以为二进制文件或压缩文件(即压缩包),具体视构建控制程序时获取内容信息的程序文件而定,若构建控制程序时所依据的目标程序的程序文件为二进制文件,控制程序所生成的目标程序的程序文件即为二进制文件;若构建控制程序时目标程序的程序文件为压缩文件,控制程序所生成的目标程序的程序文件即为压缩文件。
本实施例中,可以在程序文件的预设存储路径下生成上述空白文件,此时,所述根据所述内容信息生成所述目标程序的程序文件可优化包括:确定所述目标程序的程序文件的存储路径;根据所述内容信息在所述存储路径下生成所述目标程序的程序文件。其中,程序文件的存储路径的确定方法可以根据需要设置,如可以将预先设置的默认存储路径确定为程序文件的存储路径,或者,将用户选取确定的存储路径确定为程序文件的存储路径等,本实施例不对此进行限制。
S130、基于所述类型信息调用所述程序文件,以控制所述目标程序执行。
具体的,采用与目标程序程序文件的类型信息相符的方式调用该程序文件,以运行该目标程序。例如,当目标程序的程序文件为可执行文件时,直接调用该可执行文件,从而控制目标程序运行;当目标程序的程序文件为压缩文件时,对所述压缩文件进行解压缩处理,得到目标程序的原始文件,并调用该原始文件中的可执行文件,以使目标程序运行。
示例性的,以控制程序中的执行程序为shell脚本且程序部分位于数据部分前面为例,控制程序的运行过程可以描述为:控制程序被作为shell脚本运行;控制程序读取shell脚本中定义的shell脚本的长度信息;控制程序根据该长度信息获取控制程序数据部分的内容作为程序文件的内容信息,并读取shell脚本中定义的程序文件的类型信息;控制程序根据该内容信息在指定路径下生成目标程序的程序文件;控制程序根据类型信息来调用生成的程序文件,以控制目标程序运行;控制程序在目标程序运行完成(即目标程序运行结束)后结束运行。
本发明实施例一提供的目标程序的执行方法,获取控制程序对应的目标程序的程序文件的内容信息和类型信息,根据该内容信息生成目标程序的程序文件,并基于该类型信息调用所生成的目标程序的程序文件,从而控制目标程序执行。本实施例通过采用上述技术方案,通过控制程序控制目标程序运行,能够增大非法人员获取目标程序的程序代码的难度,从而降低目标程序的程序代码被窃取与修改的概率,提高目标程序的安全性。此外,当目标程序为多文件程序,控制程序为单文件程序时,上述执行方法还能够将多文件的目标程序转换为单文件的控制程序,减少目标程序结构的复杂度,降低目标程序在传输过程中发生数据丢失的概率,并且,只需对单文件控制程序进行完整性校验,能够降低目标程序完整性校验的复杂程序。
实施例二
本发明实施例二提供一种目标程序的转换方法。该方法可以由目标程序的转换装置执行,其中,该装置可以由软件和/或硬件实现,一般可集成于开发终端中,可以适用于在目标程序开发完成后,将目标程序转换为控制程序的情况,尤其适用于将多文件目标程序转换为单文件控制程序。图3为本发明实施例二提供的一种目标程序的转换方法的流程示意图,如图3所示,所述方法包括:
S210、获取目标程序的程序文件的内容信息和类型信息。
具体的,可以根据目标程序的程序文件确定目标程序的程序文件的内容信息和类型信息,如获取目标程序的程序文件,基于该程序文件的文件名称后缀确定该程序文件的类型信息,并读取该程序文件,得到该程序文件的内容信息。其中,程序文件的类型信息可以为文本文件、可执行文件、压缩文件等。在基于程序文件的文件名称后缀确定程序文件的类型信息时,举例而言,当程序文件的文件名称后缀为txt时,可以确定目标文件为文本文件,当程序文件的文件名称后缀为exe时,可以确定目标文件为可执行文件,当程序文件的文件名称后缀为zip时,可以确定目标文件为压缩文件。
在本实施例中,目标程序的程序文件可以为目标程序原始文件,也可以为对目标程序的原始文件进行压缩后得到的文件,本实施例不对此进行限制。为了进一步降低构建得到控制程序的复杂度,优选的,获取其内容信息的程序文件可以为单文件,如当目标程序为单文件程序时,可以直接将该原始文件确定为目标程序的程序文件;当目标程序为多文件程序时,可以对目标程序的原始文件进行压缩,得到一个压缩文件,并将该压缩文件确定为目标程序的程序文件,从而确保无论目标程序文件为何种程序文件,后续都只需向控制程序模板中添加一个文件的类型信息和内容信息即可完成控制程序的构建,减少需要向控制程序模板添加的信息的数量,且无需建立各类型信息与各内容信息之间的对应关系。相应的,当所述目标程序为多文件程序,所述控制程序为单文件程序时,在所述获取目标程序的程序文件的内容信息和类型信息之前,还可以优化包括:获取所述目标程序的原始文件,并将所述原始文件压缩为一个程序文件。
S220、分别将所述内容信息和所述类型信息添加至预设控制程序模板的相应位置,得到所述目标程序对应的控制程序,以通过所述控制程序控制所述目标程序执行。
在本实施例中,添加内容信息和类型信息的预设控制程序模板可以为各类型程序文件通用的控制程序模板,也可以为仅适用当前程序文件类型的控制程序模板,本实施例不对此进行限制。当添加内容信息和类型信息的预设控制程序模板为仅适用当前程序文件类型的控制程序模板时,在添加目标文件的程序文件的内容信息和类型信息之前,可以根据目标程序的程序文件的类型信息确定构建该目标程序的控制程序时可使用的控制程序模板;相应的,开发人员可以预先为不同程序文件类型的程序编写其适用的控制程序模板。
此外,开发人员在为某一程序文件类型编写其适用的控制程序模板时,可以为该程序文件类型的程序编写该程序文件类型的程序均适用的控制程序模板。考虑到所生成的控制程序的简洁性,开发人员优选可以按照程序文件的调用方式对该程序文件类型中的各程序再次进行分类,并分别为不同类别的程序编写不同的控制程序模板,此时,相应的,在将目标程序的程序文件的内容信息和类型信息添加至预设控制程序模板的相应位置之前,还可以包括:获取程序文件的调用方式信息,并选取与所述类型信息和所述调用方式信息相符的控制程序模板作为所述目标程序对应的控制程序模板。其中,调用方式可以为目标程序原始文件的调用方式,如控制目标程序执行时需要调用的可执行文件的数量等。
示例性的,以控制程序模板中的执行程序为shell脚本且控制程序的程序部分位于数据部分的前面为例,生成程序(即由软件实现时的目标程序的转换装置)与控制程序的工作过程可以描述为:开发人员预先编写分别适用于不同类型与不同调用方式的程序的控制程序模板;生成程序在被触发后,获取目标程序的程序文件,根据该程序文件按确定目标程序的程序文件的内容信息、类型信息以及该程序文件的调用方式信息,根据该类型信息和该调用方式信息确定该目标程序对应的控制程序模板,将该类型信息和该内容信息添加至所确定的控制程序模板的相应位置,如将类型信息添加至相应的程序行,并使用cat等命令将内容信息全部拷贝到shell脚本的后面,得到目标程序对应的控制程序,并将该控制程序上传至服务器;用户终端自服务器下载该控制程序,并在当前条件符合控制程序的运行条件时触发该控制程序;控制程序获取对应目标程序的程序文件的内容信息和类型信息,根据该内容信息生成目标程序的程序文件,并基于该类型信息调用该程序文件,从而控制目标程序运行。
在上述示例性的描述中,开发人员在编写分别适用于不同类型信息与不同调用方式的程序的控制程序模板时,可以针对每一类型下的每一种调用方式的程序,定义shell脚本的长度信息,编写控制程序获取目标程序的程序文件的内容信息的相关逻辑以及调用所生成的程序文件的逻辑,并在shell脚本的结尾处设置退出标志,以使控制程序运行至shell脚本结尾处时结束运行。其中,shell脚本的长度信息可以在编写相应运行逻辑之前或之后定义,如可以在编写相应运行逻辑之前,将shell脚本的长度信息设置为一个默认的值,并在shell脚本的实际长度不足该默认值时,采用空格或换行的方式将shell脚本的长度补齐为该默认值;也可以在编写相应运行逻辑之后,根据所编写的运行逻辑,将该长度信息定义为shell脚本的实际长度。
本发明实施例二提供的目标程序的转换方法,获取需要转换的目标程序的程序文件的内容信息和类型信息,分别将该内容信息和类型信息添加到预设控制程序模板的相应位置,得到该目标程序对应的控制程序,从而通过所生成的控制程序控制目标程序执行。本实施例通过采用上述技术方案,将目标程序转换为控制程序,能够增大非法人员获取目标程序的程序代码的难度,从而降低目标程序的程序代码被窃取与修改的概率,提高目标程序的安全性。此外,当目标程序为多文件程序,控制程序为单文件程序时,上述执行方法还能够将多文件的目标程序转换为单文件的控制程序,减少目标程序结构的复杂度,降低目标程序在传输过程中发生数据丢失的概率,并且,只需对单文件控制程序进行完整性校验,能够降低目标程序完整性校验的复杂程序。
实施例三
本发明实施例三提供一种目标程序的执行装置。该装置可以由软件和/或硬件实现,一般可集成于用户终端中,可适用于基于控制目标程序执行的场景,尤其适用于控制多文件目标程序执行的场景。图4为发明实施例三提供的一种目标程序的执行装置的结构框图,如图4所示,所述目标程序的执行装置包括第一信息获取模块301、文件生成模块302和文件调用模块303,其中,
第一信息获取模块301,用于获取对应目标程序的程序文件的内容信息和类型信息;
文件生成模块302,用于根据所述内容信息生成所述目标程序的程序文件;
文件调用模块303,用于基于所述类型信息调用所述程序文件,以控制所述目标程序执行。
本发明实施例三提供的目标程序的执行装置,通过第一信息获取模块获取控制程序对应的目标程序的程序文件的内容信息和类型信息,通过文件生成模块根据该内容信息生成目标程序的程序文件,并通过文件调用模块基于该类型信息调用所生成的目标程序的程序文件,从而控制目标程序执行。本实施例通过采用上述技术方案,通过控制程序控制目标程序运行,能够增大非法人员获取目标程序的程序代码的难度,从而降低目标程序的程序代码被窃取与修改的概率,提高目标程序的安全性。此外,当目标程序为多文件程序,控制程序为单文件程序时,上述执行方法还能够将多文件的目标程序转换为单文件的控制程序,减少目标程序结构的复杂度,降低目标程序在传输过程中发生数据丢失的概率,并且,只需对单文件控制程序进行完整性校验,能够降低目标程序完整性校验的复杂程序。
在上述方案中,所述第一信息获取模块301可以包括:内容信息获取单元,用于根据控制程序中程序部分的长度信息确定数据部分在所述控制程序中的位置信息,并基于所述位置信息获取对应目标程序的程序文件的内容信息,其中,所述控制程序由程序部分和数据部分组成,所述数据部分用于记载对应目标程序的程序文件的内容信息;以及,类型信息获取单元,用于获取控制程序中记载的对应目标程序的程序文件的类型信息。
在上述方案中,所述文件生成模块302可以包括:路径确定单元,用于确定所述目标程序的程序文件的存储路径;文件生成单元,用于根据所述内容信息在所述存储路径下生成所述目标程序的程序文件。
在上述方案中,所述目标程序可以为多文件程序,所述程序文件可以为压缩文件,所述控制程序可以为单文件程序,所述控制程序的执行程序可以为shell脚本。
本发明实施例三提供的目标程序的执行装置可执行本发明任意实施例提供的目标程序的执行方法,具备执行目标程序的执行方法相应的功能模块和有益效果。未在本实施例中详尽描述的技术细节,可参见本发明任意实施例所提供的目标程序的执行方法。
实施例四
本发明实施例四提供一种目标程序的转换装置。该装置可以由软件和/或硬件实现,一般可集成于开发终端中,可以适用于在目标程序开发完成后,将目标程序转换为控制程序的情况,尤其适用于将多文件目标程序转换为单文件控制程序。图5为本发明实施例四提供的一种目标程序的转换装置的结构框图,如图5所示,所述目标程序的转换装置包括第二信息获取模块401和信息添加模块402,其中,
第二信息获取模块401,用于获取目标程序的程序文件的内容信息和类型信息;
信息添加模块402,用于分别将所述内容信息和所述类型信息添加至预设控制程序模板的相应位置,得到所述目标程序对应的控制程序,以通过所述控制程序控制所述目标程序执行。
本发明实施例四提供的目标程序的转换装置,通过第二信息获取模块获取需要转换的目标程序的程序文件的内容信息和类型信息,通过信息添加模块分别将该内容信息和类型信息添加到预设控制程序模板的相应位置,得到该目标程序对应的控制程序,从而通过所生成的控制程序控制目标程序执行。本实施例通过采用上述技术方案,将目标程序转换为控制程序,能够增大非法人员获取目标程序的程序代码的难度,从而降低目标程序的程序代码被窃取与修改的概率,提高目标程序的安全性。此外,当目标程序为多文件程序,控制程序为单文件程序时,上述执行方法还能够将多文件的目标程序转换为单文件的控制程序,减少目标程序结构的复杂度,降低目标程序在传输过程中发生数据丢失的概率,并且,只需对单文件控制程序进行完整性校验,能够降低目标程序完整性校验的复杂程序。
进一步地,所述目标程序为多文件程序,所述控制程序为单文件程序,所述目标程序的转换装置还可以包括:压缩模块,用于在所述获取目标程序的程序文件的内容信息和类型信息之前,获取所述目标程序的原始文件,并将所述原始文件压缩为一个程序文件。
本发明实施例四提供的目标程序的转换装置可执行本发明任意实施例提供的目标程序的转换方法,具备执行目标程序的转换方法相应的功能模块和有益效果。未在本实施例中详尽描述的技术细节,可参见本发明任意实施例所提供的目标程序的转换方法。
实施例五
图6为本发明实施例五提供的一种终端的结构示意图,如图6所示,该终端包括处理器50和存储器51,还可以包括输入装置52和输出装置53;终端中处理器50的数量可以是一个或多个,图6中以一个处理器50为例;终端中的处理器50、存储器51、输入装置52和输出装置53可以通过总线或其他方式连接,图6中以通过总线连接为例。
存储器51作为一种计算机可读存储介质,可用于存储软件程序、计算机可执行程序以及模块,如本发明实施例中的目标程序的执行方法对应的程序指令/模块(例如,目标程序的执行装置中的第一信息获取模块301、文件生成模块302和文件调用模块303)或者本发明实施例中的目标程序的转换方法对应的程序指令/模块(例如,目标程序的转换装置中的第二信息获取模块401和信息添加模块402)。处理器50通过运行存储在存储器51中的软件程序、指令以及模块,从而执行终端的各种功能应用以及数据处理,即实现上述的目标程序的执行方法或目标程序的转换方法。
存储器51可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序;存储数据区可存储根据终端的使用所创建的数据等。此外,存储器51可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他非易失性固态存储器件。在一些实例中,存储器51可进一步包括相对于处理器50远程设置的存储器,这些远程存储器可以通过网络连接至终端。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
输入装置52可用于接收输入的数字或字符信息,以及产生与终端的用户设置以及功能控制有关的键信号输入。输出装置53可包括显示屏等显示设备。
本发明实施例五还提供一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由计算机处理器执行时用于执行一种目标程序的执行方法或目标程序的转换方法,该目标程序的执行方法包括:
获取对应目标程序的程序文件的内容信息和类型信息;
根据所述内容信息生成所述目标程序的程序文件;
基于所述类型信息调用所述程序文件,以控制所述目标程序执行。
该目标程序的转换方法包括:
获取目标程序的程序文件的内容信息和类型信息;
分别将所述内容信息和所述类型信息添加至预设控制程序模板的相应位置,得到所述目标程序对应的控制程序,以通过所述控制程序控制所述目标程序执行。
当然,本发明实施例所提供的一种包含计算机可执行指令的存储介质,其计算机可执行指令不限于如上所述的方法操作,还可以执行本发明任意实施例所提供的目标程序的执行方法或目标程序的转换方法中的相关操作。
通过以上关于实施方式的描述,所属领域的技术人员可以清楚地了解到,本发明可借助软件及必需的通用硬件来实现,当然也可以通过硬件实现,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在计算机可读存储介质中,如计算机的软盘、只读存储器(Read-Only Memory,ROM)、随机存取存储器(RandomAccess Memory,RAM)、闪存(FLASH)、硬盘或光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述的方法。
值得注意的是,上述目标程序的执行装置和目标程序的转换装置的实施例中,所包括的各个单元和模块只是按照功能逻辑进行划分的,但并不局限于上述的划分,只要能够实现相应的功能即可;另外,各功能单元的具体名称也只是为了便于相互区分,并不用于限制本发明的保护范围。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。

Claims (10)

1.一种目标程序的执行方法,其特征在于,包括:
获取对应目标程序的程序文件的内容信息和类型信息;
根据所述内容信息生成所述目标程序的程序文件;
基于所述类型信息调用所述程序文件,以控制所述目标程序执行。
2.根据权利要求1所述的方法,其特征在于,所述获取对应目标程序的程序文件的内容信息和类型信息,包括:
根据控制程序中程序部分的长度信息确定数据部分在所述控制程序中的位置信息,并基于所述位置信息获取对应目标程序的程序文件的内容信息,其中,所述控制程序由程序部分和数据部分组成,所述数据部分用于记载对应目标程序的程序文件的内容信息;以及,
获取控制程序中记载的对应目标程序的程序文件的类型信息。
3.根据权利要求1所述的方法,其特征在于,所述根据所述内容信息生成所述目标程序的程序文件,包括:
确定所述目标程序的程序文件的存储路径;
根据所述内容信息在所述存储路径下生成所述目标程序的程序文件。
4.根据权利要求2或3所述的方法,其特征在于,所述目标程序为多文件程序,所述程序文件为压缩文件,所述控制程序为单文件程序,所述控制程序的执行程序为shell脚本。
5.一种目标程序的转换方法,其特征在于,包括:
获取目标程序的程序文件的内容信息和类型信息;
分别将所述内容信息和所述类型信息添加至预设控制程序模板的相应位置,得到所述目标程序对应的控制程序,以通过所述控制程序控制所述目标程序执行。
6.根据权利要求5所述的方法,其特征在于,所述目标程序为多文件程序,所述控制程序为单文件程序,在所述获取目标程序的程序文件的内容信息和类型信息之前,还包括:
获取所述目标程序的原始文件,并将所述原始文件压缩为一个程序文件。
7.一种目标程序的执行装置,其特征在于,包括:
第一信息获取模块,用于获取对应目标程序的程序文件的内容信息和类型信息;
文件生成模块,用于根据所述内容信息生成所述目标程序的程序文件;
文件调用模块,用于基于所述类型信息调用所述程序文件,以控制所述目标程序执行。
8.一种目标程序的转换装置,其特征在于,包括:
第二信息获取模块,用于获取目标程序的程序文件的内容信息和类型信息;
信息添加模块,用于分别将所述内容信息和所述类型信息添加至预设控制程序模板的相应位置,得到所述目标程序对应的控制程序,以通过所述控制程序控制所述目标程序执行。
9.一种终端,其特征在于,包括:
一个或多个处理器;
存储器,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-4中任一所述的目标程序的执行方法或者实现如权利要求5或6所述的目标程序的转换方法。
10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-4中任一所述的目标程序的执行方法或者实现如权利要求5或6所述的目标程序的转换方法。
CN201911165563.5A 2019-11-25 2019-11-25 目标程序的执行与转换方法、装置、终端和存储介质 Pending CN111090854A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911165563.5A CN111090854A (zh) 2019-11-25 2019-11-25 目标程序的执行与转换方法、装置、终端和存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911165563.5A CN111090854A (zh) 2019-11-25 2019-11-25 目标程序的执行与转换方法、装置、终端和存储介质

Publications (1)

Publication Number Publication Date
CN111090854A true CN111090854A (zh) 2020-05-01

Family

ID=70394058

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911165563.5A Pending CN111090854A (zh) 2019-11-25 2019-11-25 目标程序的执行与转换方法、装置、终端和存储介质

Country Status (1)

Country Link
CN (1) CN111090854A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113791838A (zh) * 2021-08-20 2021-12-14 深圳市元征科技股份有限公司 一种程序文件调用方法、装置以及存储介质

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1834911A (zh) * 2005-03-14 2006-09-20 华为技术有限公司 实现程序加载运行的方法
US8887152B1 (en) * 2011-11-04 2014-11-11 Trend Micro, Inc. Android application virtual environment
CN104182257A (zh) * 2011-11-22 2014-12-03 华为数字技术(成都)有限公司 应用软件的安装方法和应用软件的安装装置
CN104423986A (zh) * 2013-09-02 2015-03-18 北京亿阳信通科技有限公司 一种应用系统内嵌脚本的方法和装置
CN106228041A (zh) * 2016-07-21 2016-12-14 北京理工大学 一种针对Android预编译的代码保护方法
CN108427559A (zh) * 2018-03-14 2018-08-21 新华三技术有限公司 一种脚本文件生成和调用方法以及装置

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1834911A (zh) * 2005-03-14 2006-09-20 华为技术有限公司 实现程序加载运行的方法
US8887152B1 (en) * 2011-11-04 2014-11-11 Trend Micro, Inc. Android application virtual environment
CN104182257A (zh) * 2011-11-22 2014-12-03 华为数字技术(成都)有限公司 应用软件的安装方法和应用软件的安装装置
CN104423986A (zh) * 2013-09-02 2015-03-18 北京亿阳信通科技有限公司 一种应用系统内嵌脚本的方法和装置
CN106228041A (zh) * 2016-07-21 2016-12-14 北京理工大学 一种针对Android预编译的代码保护方法
CN108427559A (zh) * 2018-03-14 2018-08-21 新华三技术有限公司 一种脚本文件生成和调用方法以及装置

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113791838A (zh) * 2021-08-20 2021-12-14 深圳市元征科技股份有限公司 一种程序文件调用方法、装置以及存储介质
CN113791838B (zh) * 2021-08-20 2024-04-23 深圳市元征科技股份有限公司 一种程序文件调用方法、装置以及存储介质

Similar Documents

Publication Publication Date Title
CN111045655B (zh) 一种页面渲染的方法、装置、渲染服务器和存储介质
US11016785B2 (en) Method and system for mirror image package preparation and application operation
CN104731589A (zh) 用户界面的自动生成方法及自动生成装置
CN107402792B (zh) 应用软件安装包的集成方法、装置、设备及存储介质
CN110210212A (zh) 一种数据处理方法、装置以及相关设备
CN111459539A (zh) 基于镜像分层的持续集成流水线运行方法及装置
CN114064024A (zh) 微应用的开发方法、装置、设备、存储介质及程序产品
CN113515278A (zh) 低代码模型处理方法、系统、电子设备及存储介质
CN109271157B (zh) 软件开发方法、设备及计算机可读存储介质
CN108037932B (zh) Spi-nand的配置文件获取方法和装置
CN114528064A (zh) 一种场景配置方法、存储介质及终端设备
CN110764894A (zh) 一种定时任务管理方法、装置、设备及存储介质
CN111090854A (zh) 目标程序的执行与转换方法、装置、终端和存储介质
CN114911541B (zh) 配置信息的处理方法、装置、电子设备及存储介质
CN110045997B (zh) 基础功能模块的对象初始化方法、装置、设备和存储介质
CN113268232A (zh) 一种页面皮肤生成方法、装置和计算机可读存储介质
KR102506155B1 (ko) 전자장치, 어플리케이션 실행 시스템 및 그 제어방법
CN111124386B (zh) 基于Unity的动画事件处理方法、装置、设备和存储介质
CN114237736A (zh) 页面资源加载方法、系统、装置、计算机设备及存储介质
CN113961234A (zh) 一种Linux发行版本的构建方法及相关装置
CN116795356B (zh) Flutter与原生平台的混合开发方法、系统及装置
CN109492181B (zh) 页面跳转方法、装置、计算机设备和存储介质
CN113741946B (zh) 公共接口函数库的裁剪方法、装置、设备及可读存储介质
CN111949716B (zh) 格式化数据输出字段处理方法、计算机设备及存储介质
CN117234512B (zh) 业务快速开发方法、系统、电子设备及存储介质

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
RJ01 Rejection of invention patent application after publication

Application publication date: 20200501

RJ01 Rejection of invention patent application after publication