CN106528231B - 一种启动应用程序的方法和装置 - Google Patents
一种启动应用程序的方法和装置 Download PDFInfo
- Publication number
- CN106528231B CN106528231B CN201610976153.9A CN201610976153A CN106528231B CN 106528231 B CN106528231 B CN 106528231B CN 201610976153 A CN201610976153 A CN 201610976153A CN 106528231 B CN106528231 B CN 106528231B
- Authority
- CN
- China
- Prior art keywords
- preset
- storage position
- identification code
- hardware identification
- application program
- 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.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 45
- 238000004519 manufacturing process Methods 0.000 claims abstract description 11
- 238000003860 storage Methods 0.000 claims description 273
- 238000013500 data storage Methods 0.000 claims description 26
- 230000008569 process Effects 0.000 claims description 15
- 238000005516 engineering process Methods 0.000 abstract description 4
- 230000006870 function Effects 0.000 description 21
- 238000012545 processing Methods 0.000 description 17
- 238000009434 installation Methods 0.000 description 8
- 238000004891 communication Methods 0.000 description 5
- 238000010586 diagram Methods 0.000 description 5
- 238000001514 detection method Methods 0.000 description 3
- 230000001133 acceleration Effects 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 2
- 230000005484 gravity Effects 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000005236 sound signal Effects 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000002860 competitive effect Effects 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 238000007599 discharging Methods 0.000 description 1
- 238000009826 distribution Methods 0.000 description 1
- 230000000977 initiatory effect Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 230000007774 longterm Effects 0.000 description 1
- 238000010295 mobile communication Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 238000003672 processing method Methods 0.000 description 1
- 238000010079 rubber tapping Methods 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000010897 surface acoustic wave method Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/445—Program loading or initiating
- G06F9/44505—Configuring for program initiating, e.g. using registry, configuration files
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Mobile Radio Communication Systems (AREA)
- Telephonic Communication Services (AREA)
- Telephone Function (AREA)
Abstract
本发明提供了一种启动应用程序的方法和装置,属于电子技术领域。所述方法包括:当检测到目标应用程序的启动触发事件时,通过所述目标应用程序,判断终端的第一预设存储位置中是否存储有预设硬件识别码;如果所述第一预设存储位置中存储有所述预设硬件识别码,则启动所述目标应用程序;如果所述第一预设存储位置中未存储有所述预设硬件识别码,则阻止所述目标应用程序启动。采用本发明,可以防止其他终端生产厂商对应用程序的恶意侵占。
Description
技术领域
本发明涉及电子技术领域,特别涉及一种启动应用程序的方法和装置。
背景技术
随着电子技术的发展,各种各样的终端得到了广泛的应用,比如智能后视镜、智能手机等终端。
终端生产厂商为了使自己生产的终端更能吸引用户,往往会开发一些竞争终端不具备的新功能,具体的,技术人员可以开发一些可实现新功能的应用程序,并将其安装到终端中。使用该终端的用户可以点击该应用程序的快捷方式,终端将会接收到用户输入的对该应用程序的启动指令,进而,对安装到终端的应用程序进行启动,终端即可具有相应的新功能。
在实现本发明的过程中,发明人发现现有技术至少存在以下问题:
其他终端生产厂商往往在未经允许的情况下,也能容易获取到可实现新功能的应用程序的安装包,进而,其他终端生产厂商可以通过获取的应用程序的安装包,将该应用程序安装到自己生产的终端中。当其他终端生产厂商将应用程序安装到自己生产的终端中时,基于上述启动应用程序的方法,其他终端生产厂商生产的终端也可具有相应的新功能,从而,造成其他终端生产厂商对应用程序的恶意侵占。
发明内容
为了解决现有技术的问题,本发明实施例提供了一种启动应用程序的方法和装置。所述技术方案如下:
第一方面,提供了一种启动应用程序的方法,所述方法包括:
当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述预设硬件识别码存储到第一预设存储位置;
当检测到目标应用程序的启动触发事件时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;
如果所述第一预设存储位置中存储有所述预设硬件识别码,则启动所述目标应用程序;如果所述第一预设存储位置中未存储有所述预设硬件识别码,则阻止所述目标应用程序启动。
可选的,所述方法还包括:
在终端生产阶段通过所述调制解调器子程序,接收携带有所述预设硬件识别码和所述第二预设存储位置的存储请求;并将所述预设硬件识别码存储到所述调制解调器子程序对应的数据存储区内的第二预设存储位置。
可选的,所述当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述预设硬件识别码存储到第一预设存储位置,包括:
当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的加密后的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述加密后的预设硬件识别码存储到第一预设存储位置。
可选的,所述通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码,包括:
通过所述目标应用程序,在终端的所述第一预设存储位置进行数据查找;
如果所述第一预设存储位置中存储有第一数据,则基于预设的解密算法对所述第一数据进行解密处理,如果解密后的第一数据与所述预设硬件识别码相匹配,则判定所述第一预设存储位置中存储有所述预设硬件识别码,如果解密后的第一数据与所述预设硬件识别码不匹配,则判定所述第一预设存储位置中未存储所述预设硬件识别码;
如果所述第一预设存储位置中未存储数据,则判定所述第一预设存储位置中未存储所述预设硬件识别码。
可选的,所述当检测到目标应用程序的启动触发事件时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码,包括:
当检测到用户输入的目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;或者,
在所述终端开机过程中接收到目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码。
第二方面,提供了一种启动应用程序的装置,所述装置包括:
第一存储模块,用于当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述预设硬件识别码存储到第一预设存储位置;
判断模块,用于当检测到目标应用程序的启动触发事件时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;
执行模块,用于如果所述第一预设存储位置中存储有所述预设硬件识别码,则启动所述目标应用程序;如果所述第一预设存储位置中未存储有所述预设硬件识别码,则阻止所述目标应用程序启动。
可选的,所述装置还包括:
接收模块,用于在终端生产阶段通过所述调制解调器子程序,接收携带有所述预设硬件识别码和所述第二预设存储位置的存储请求;
第二存储模块,用于将所述预设硬件识别码存储到所述调制解调器子程序对应的数据存储区内的第二预设存储位置。
可选的,所述第一存储模块,用于:
当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的加密后的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述加密后的预设硬件识别码存储到第一预设存储位置。
可选的,所述判断模块,包括:
查找子模块,用于通过所述目标应用程序,在终端的所述第一预设存储位置进行数据查找;
判断子模块,用于如果所述第一预设存储位置中存储有第一数据,则基于预设的解密算法对所述第一数据进行解密处理,如果解密后的第一数据与所述预设硬件识别码相匹配,则判定所述第一预设存储位置中存储有所述硬件识别码,如果解密后的第一数据与所述预设硬件识别码不匹配,则判定所述第一预设存储位置中未存储所述预设硬件识别码;如果所述第一预设存储位置中未存储数据,则判定所述第一预设存储位置中未存储所述预设硬件识别码。
可选的,所述判断模块,用于:
当检测到用户输入的目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;或者,
在所述终端开机过程中接收到目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码。
本发明实施例提供的技术方案带来的有益效果是:
本发明实施例中,当终端检测到目标应用程序的启动触发事件时,目标应用程序可以判断终端的第一预设存储位置中是否存储有预设硬件识别码,如果第一预设存储位置中存储有预设硬件识别码,则可以启动目标应用程序;如果第一预设存储位置中未存储有预设硬件识别码,则可以阻止目标应用程序启动。这样,应用程序只有安装在特定的终端上才能正常启动,其他终端生产厂商即使非法获取了应用程序的安装包,应用程序也不能在其终端上正常启动,即其他终端生产厂商的终端不能具有相应的应用程序的功能,从而,可以防止其他终端生产厂商对应用程序的恶意侵占。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明实施例提供的一种启动应用程序的方法流程图;
图2是本发明实施例提供的一种系统程序示意图;
图3是本发明实施例提供的一种启动应用程序的装置结构示意图;
图4是本发明实施例提供的一种启动应用程序的装置结构示意图;
图5是本发明实施例提供的一种启动应用程序的装置结构示意图;
图6是本发明实施例提供的一种终端结构示意图。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚,下面将结合附图对本发明实施方式作进一步地详细描述。
本发明实施例提供了一种启动应用程序的方法,该方法的执行主体为终端。其中,该终端可以是安装有应用程序的终端,比如可以是手机、平板电脑、智能后视镜等终端。该终端中可以设置有处理器,处理器可以用于启动应用程序或阻止应用程序启动的相关处理。还可以设置有存储器和收发器,存储器可以用于存储下述处理过程中需要和产生的数据,收发器可以用于接收和发送数据。
下面将结合具体实施方式,对图1所示的处理流程进行详细的说明,内容可以如下:
步骤101,当检测到目标应用程序的启动触发事件时,通过目标应用程序,判断终端的第一预设存储位置中是否存储有预设硬件识别码。
其中,目标应用程序可以是终端中安装的终端生产厂商开发的任一应用程序,第一预设存储位置可以是终端的存储区内目标应用程序可以访问的某一预设存储位置。
在实施中,终端的存储区可以包括应用程序可以访问的存储位置和系统子程序可以访问的存储位置,其中,应用程序不能访问系统子程序可以访问的存储位置,系统子程序不能访问应用程序可以访问的存储位置,系统子程序可以是终端中的功能模块,该功能模块可以具有对应的存储位置和处理部件,比如可以是modem(调制解调器)子程序。为防止其他终端生产厂商恶意侵占目标应用程序,技术人员可以在终端生产阶段,在终端中的第一预设存储位置内存储特定数据(即预设硬件识别码),以使当检测到目标应用程序的启动触发事件时,目标应用程序可以通过判断该第一预设存储位置内是否存储有预设硬件识别码,来确定自身正常启动,还是退出,即目标应用程序只有在判断到其所在的终端满足开发厂商生产的终端的特点时,才能正常启动。
具体的,终端中可以预先设置针对目标应用程序的启动触发事件,其中,启动触发事件可以是用于触发目标应用程序启动的事件。终端可以对目标应用程序的启动触发事件进行检测,当启动触发事件发生时,终端即可检测到目标应用程序的启动触发事件,进而,目标应用程序可以判断终端的第一预设存储位置中是否存储有预设硬件识别码。
其中,目标应用程序判断终端的第一预设存储位置中是否存储有预设硬件识别码的方式可以是多种多样的,以下给出了几种可行的处理方式:
方式一,检测到目标应用程序的启动触发事件后,目标应用程序可以对终端的第一预设存储位置进行数据查询(其中,目标应用程序中可以预先设置有第一预设存储位置的地址),如果查询到第一预设存储位置内未存储有数据,则可以判定第一预设存储位置中未存储有预设硬件识别码,如果查询到第一预设存储位置内存储有数据,则目标应用程序可以进一步判断第一预设存储位置内存储的数据是否为预设硬件识别码,如果是预设硬件识别码,则可以判定第一预设存储位置中存储有预设硬件识别码;如果不是,则可以判定第一预设存储位置中未存储有预设硬件识别码,其中,预设硬件识别码可以作为基准值预先设置在目标应用程序中。另外,目标应用程序也可以基于预设存储的第三预设存储位置的地址(其中,地址可以是文件名和文件名对应的文件的存储路径,也可以称第三预设存储位置为节点),从存储有预设硬件识别码的第三预设存储位置获取预设硬件识别码(其中,终端在每次开机时,都会将终端中的各硬件的硬件识别码分别存储在对应的预设存储位置内,第三预设存储位置可以是用于存储预设硬件的硬件识别码的存储位置,比如是中央处理器的串号的存储位置),进而,比较第一预设存储位置中的数据是否与第三预设存储位置中的数据相匹配(比如,比较是否相同),如果相匹配,则可以判定第一预设存储位置中存储有预设硬件识别码;如果不是,则可以判定第一预设存储位置中未存储有预设硬件识别码。
方式二,终端在开机时,终端的framework(框架)程序可以对终端的第一预设存储位置进行数据查询,如果查询到第一预设存储位置内未存储有数据,则framework程序可以判定第一预设存储位置中未存储有预设硬件识别码,如果查询到第一预设存储位置内存储有数据,则framework程序可以进一步判断第一预设存储位置内存储的数据是否为预设硬件识别码,如果是预设硬件识别码,则framework程序可以判定第一预设存储位置中存储有预设硬件识别码;如果不是,则framework程序可以判定第一预设存储位置中未存储有预设硬件识别码,其中,预设硬件识别码可以作为基准值预先设置在目标应用程序中。framework程序得到判定结果后,可以对判定结果进行存储,当终端检测到目标应用程序的启动触发事件后,目标应用程序可以直接向framework程序获取判定结果,根据获取的判定结果确定终端的第一预设存储位置中是否存储有预设硬件识别码,进而,可以根据获取的判定结果进行后续处理。
另外,终端可以在开机时,可以将预先存储到其他预设存储位置的预设硬件识别码移存到第一预设存储位置,相应的,处理过程可以如下:在终端生产阶段通过调制解调器子程序,接收携带有预设硬件识别码和第二预设存储位置的存储请求;并将预设硬件识别码存储到调制解调器子程序对应的数据存储区内的第二预设存储位置;当接收到开机指令时,通过调制解调器子程序,将第二预设存储位置中的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将共享存储位置内的预设硬件识别码存储到第一预设存储位置。
在实施中,如上所述,终端可以包括有系统子程序,其中,系统子程序可以对应有自己的数据存储区,目标应用程序无法访问该数据存储区,且系统子程序不是开源程序,调制解调器子程序可以是终端包括的多个系统子程序中的一个。在终端生产阶段,技术人员也可以通过生产软件工具向终端中的调制解调器子程序发送存储请求,其中,存储请求中可以携带有预设硬件识别码和第二预设存储位置,调制解调器子程序接收到存储请求后,可以将预设硬件识别码存储到对应的数据存储区的第二预设存储位置。也就是说,在终端生产阶段,技术人员可以直接将预设硬件识别码存储到调制解调器子程序对应数据存储区(该数据存储区可以是嵌入式文件系统efs位置)的第二预设存储位置。此种情况下,终端出厂后,每当终端接收到开机指令时,调制解调器子程序可以将预先存储在第二预设存储位置的预设硬件识别码存储到共享存储位置,其中,共享存储位置可以是终端中调制解调器子程序和内核Kernel程序均能访问的存储位置,目标应用程序不能访问该共享存储位置,进而,内核Kernel程序可以将存储在共享存储位置的预设硬件识别码存储到第一预设存储位置,以便当终端检测到目标应用程序的启动触发事件时,可以通过判断第一预设存储位置是否存储有预设硬件识别码,来确定是否启动目标应用程序,其中,终端的系统程序的层次结构如图2所示,由上层到下层依次是:应用程序层、framework程序层和内核程序层。
另外,第一预设存储位置中存储的是可以加密后的预设硬件识别码,针对该种情况,上述存储请求中可以携带有加密后的预设硬件识别码。相应的,终端在接收到开机指令时的处理过程可以如下:当接收到开机指令时,通过调制解调器子程序,将调制解调器子程序对应的数据存储区内的第二预设存储位置中的加密后的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的加密后的预设硬件识别码存储到第一预设存储位置。
可选的,针对预先存储在第一预设存储位置的数据是加密后的预设硬件识别码的情况,相应的,步骤101的处理过程可以如下:通过目标应用程序,在终端的第一预设存储位置进行数据查找;如果终端的第一预设存储位置中存储有第一数据,则基于预设的解密算法对第一数据进行解密处理,如果解密后的第一数据与预设硬件识别码相匹配,则判定终端的第一预设存储位置中存储有预设硬件识别码,如果解密后的第一数据与预设硬件识别码不匹配,则判定终端的第一预设存储位置中未存储预设硬件识别码;如果终端的第一预设存储位置中未存储数据,则判定终端的第一预设存储位置中未存储预设硬件识别码。
在实施中,技术人员通过生产软件工具向终端内的第二预设存储位置存储的数据可以是加密后的预设硬件识别码。此种情况下,终端检测到目标应用程序的启动触发事件后,目标应用程序可以对终端的第一预设存储位置进行数据查询,如果查询到第一预设存储位置内未存储有数据,则可以判定第一预设存储位置中未存储有预设硬件识别码,如果查询到第一预设存储位置内存储有数据(可以称为第一数据),则目标应用程序可以对第一数据进行解密处理,得到解密后的第一数据,然后,目标应用程序再进一步判断解密后的第一数据是否与预设硬件识别码相匹配(比如,两者是否相同),如果解密后的第一数据与预设硬件识别码相匹配(比如,如果两者相同),则可以判定终端的第一预设存储位置中存储有预设硬件识别码,如果解密后的第一数据与预设硬件识别码不匹配(比如,如果两者不相同),则可以判定终端的第一预设存储位置中未存储预设硬件识别码。
可选的,基于目标应用程序的启动触发事件的不同,步骤101的处理过程可以多种多样,以下给出了几种可行的处理方式:
方式一,当检测到用户输入的目标应用程序的启动指令时,通过目标应用程序,判断终端的第一预设存储位置中是否存储有预设硬件识别码。
在实施中,使用该终端的用户可以在使用终端的过程中,需要使用目标应用程序时,点击桌面中显示的目标应用程序的快捷方式(比如图标),此时,终端将会接收到用户输入的目标应用程序的启动指令,进而,终端可以通过目标应用程序,判断终端的第一预设存储位置中是否存储有预设硬件识别码。
方式二,在终端开机过程中接收到目标应用程序的启动指令时,通过目标应用程序,判断终端的第一预设存储位置中是否存储有预设硬件识别码。
在实施中,终端中安装的目标应用程序也可以在开机过程中自启动,此种情况下,终端可以在在终端开机过程中接收到目标应用程序的启动指令时,通过目标应用程序,判断终端的第一预设存储位置中是否存储有预设硬件识别码。
步骤102,如果第一预设存储位置中存储有预设硬件识别码,则启动目标应用程序;如果第一预设存储位置中未存储有预设硬件识别码,则阻止目标应用程序启动。
在实施中,目标应用程序对第一预设存储位置中是否存储有预设硬件识别码进行判断后,可以根据判断结果确定是否要正常启动,具体的,如果判定结果为第一预设存储位置中存储有预设硬件识别码,则可以启动目标应用程序;如果判定结果为第一预设存储位置中未存储有预设硬件识别码,则可以阻止目标应用程序启动。
另外,技术人员在开发目标应用程序时,可以将判断第一预设存储位置中是否存储有预设硬件识别码的代码编译打包为二进制文件,即本发明实施例提供的目标应用程序的安装包中的代码可以是二进制文件。
本发明实施例中,当终端检测到目标应用程序的启动触发事件时,目标应用程序可以判断终端的第一预设存储位置中是否存储有预设硬件识别码,如果第一预设存储位置中存储有预设硬件识别码,则可以启动目标应用程序;如果第一预设存储位置中未存储有预设硬件识别码,则可以阻止目标应用程序启动。这样,目标应用程序只有安装在特定的终端上才能正常启动,其他终端生产厂商即使非法获取了目标应用程序的安装包,目标应用程序也不能在其终端上正常启动,即其他终端生产厂商的终端不能具有相应的目标应用程序的功能,从而,可以防止其他终端生产厂商对应用程序的恶意侵占。
基于相同的技术构思,本发明实施例还提供了一种启动应用程序的装置,如图3所示,该装置包括:
第一存储模块310,用于当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述预设硬件识别码存储到第一预设存储位置;
判断模块320,用于当检测到目标应用程序的启动触发事件时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;
执行模块330,用于如果所述第一预设存储位置中存储有所述预设硬件识别码,则启动所述目标应用程序;如果所述第一预设存储位置中未存储有所述预设硬件识别码,则阻止所述目标应用程序启动。
可选的,如图4所示,所述装置还包括:
接收模块340,用于在终端生产阶段通过所述调制解调器子程序,接收携带有所述预设硬件识别码和所述第二预设存储位置的存储请求;
第二存储模块350,用于将所述预设硬件识别码存储到所述调制解调器子程序对应的数据存储区内的第二预设存储位置。
可选的,所述第一存储模块310,用于:
当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的加密后的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述加密后的预设硬件识别码存储到第一预设存储位置。
可选的,如图5所示,所述判断模块320,包括:
查找子模块3201,用于通过所述目标应用程序,在终端的所述第一预设存储位置进行数据查找;
判断子模块3202,用于如果所述第一预设存储位置中存储有第一数据,则基于预设的解密算法对所述第一数据进行解密处理,如果解密后的第一数据与所述预设硬件识别码相匹配,则判定所述第一预设存储位置中存储有所述硬件识别码,如果解密后的第一数据与所述预设硬件识别码不匹配,则判定所述第一预设存储位置中未存储所述预设硬件识别码;如果所述第一预设存储位置中未存储数据,则判定所述第一预设存储位置中未存储所述预设硬件识别码。
可选的,所述判断模块320,用于:
当检测到用户输入的目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;或者,
在所述终端开机过程中接收到目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码。
本发明实施例中,当终端检测到目标应用程序的启动触发事件时,目标应用程序可以判断终端的第一预设存储位置中是否存储有预设硬件识别码,如果第一预设存储位置中存储有预设硬件识别码,则可以启动目标应用程序;如果第一预设存储位置中未存储有预设硬件识别码,则可以阻止目标应用程序启动。这样,目标应用程序只有安装在特定的终端上才能正常启动,其他终端生产厂商即使非法获取了目标应用程序的安装包,目标应用程序也不能在其终端上正常启动,即其他终端生产厂商的终端不能具有相应的目标应用程序的功能,从而,可以防止其他终端生产厂商对应用程序的恶意侵占。
需要说明的是:上述实施例提供的启动应用程序的装置在启动应用程序时,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将终端的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。另外,上述实施例提供的启动应用程序的装置与启动应用程序的方法实施例属于同一构思,其具体实现过程详见方法实施例,这里不再赘述。
请参考图6,其示出了本发明实施例所涉及的终端的结构示意图,该终端可以用于实施上述实施例中提供的启动应用程序的方法。具体来讲:终端600可以包括RF(RadioFrequency,射频)电路110、包括有一个或多个计算机可读存储介质的存储器120、输入单元130、显示单元140、传感器150、音频电路160、WiFi(wireless fidelity,无线保真)模块170、包括有一个或者多个处理核心的处理器180、以及电源190等部件。本领域技术人员可以理解,图6中示出的终端结构并不构成对终端的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。其中:
RF电路110可用于收发信息或通话过程中,信号的接收和发送,特别地,将基站的下行信息接收后,交由一个或者多个处理器180处理;另外,将涉及上行的数据发送给基站。通常,RF电路110包括但不限于天线、至少一个放大器、调谐器、一个或多个振荡器、用户身份模块(SIM)卡、收发信机、耦合器、LNA(Low Noise Amplifier,低噪声放大器)、双工器等。此外,RF电路110还可以通过无线通信与网络和其他设备通信。所述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯系统)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA(CodeDivision Multiple Access,码分多址)、WCDMA(Wideband Code Division MultipleAccess,宽带码分多址)、LTE(Long Term Evolution,长期演进)、电子邮件、SMS(ShortMessaging Service,短消息服务)等。
存储器120可用于存储软件程序以及模块,处理器180通过运行存储在存储器120的软件程序以及模块,从而执行各种功能应用以及数据处理。存储器120可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据终端600的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器120可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。相应地,存储器120还可以包括存储器控制器,以提供处理器180和输入单元130对存储器120的访问。
输入单元130可用于接收输入的数字或字符信息,以及产生与用户设置以及功能控制有关的键盘、鼠标、操作杆、光学或者轨迹球信号输入。具体地,输入单元130可包括触敏表面131以及其他输入设备132。触敏表面131,也称为触摸显示屏或者触控板,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触敏表面131上或在触敏表面131附近的操作),并根据预先设定的程式驱动相应的连接装置。可选的,触敏表面131可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器180,并能接收处理器180发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触敏表面131。除了触敏表面131,输入单元130还可以包括其他输入设备132。具体地,其他输入设备132可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种。
显示单元140可用于显示由用户输入的信息或提供给用户的信息以及终端600的各种图形用户接口,这些图形用户接口可以由图形、文本、图标、视频和其任意组合来构成。显示单元140可包括显示面板141,可选的,可以采用LCD(Liquid Crystal Display,液晶显示器)、OLED(Organic Light-Emitting Diode,有机发光二极管)等形式来配置显示面板141。进一步的,触敏表面131可覆盖显示面板141,当触敏表面131检测到在其上或附近的触摸操作后,传送给处理器180以确定触摸事件的类型,随后处理器180根据触摸事件的类型在显示面板141上提供相应的视觉输出。虽然在图6中,触敏表面131与显示面板141是作为两个独立的部件来实现输入和输入功能,但是在某些实施例中,可以将触敏表面131与显示面板141集成而实现输入和输出功能。
终端600还可包括至少一种传感器150,比如光传感器、运动传感器以及其他传感器。具体地,光传感器可包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板141的亮度,接近传感器可在终端600移动到耳边时,关闭显示面板141和/或背光。作为运动传感器的一种,重力加速度传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于终端600还可配置的陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
音频电路160、扬声器161,传声器162可提供用户与终端600之间的音频接口。音频电路160可将接收到的音频数据转换后的电信号,传输到扬声器161,由扬声器161转换为声音信号输出;另一方面,传声器162将收集的声音信号转换为电信号,由音频电路160接收后转换为音频数据,再将音频数据输出处理器180处理后,经RF电路110以发送给比如另一终端,或者将音频数据输出至存储器120以便进一步处理。音频电路160还可能包括耳塞插孔,以提供外设耳机与终端600的通信。
WiFi属于短距离无线传输技术,终端600通过WiFi模块170可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图6示出了WiFi模块170,但是可以理解的是,其并不属于终端600的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
处理器180是终端600的控制中心,利用各种接口和线路连接整个手机的各个部分,通过运行或执行存储在存储器120内的软件程序和/或模块,以及调用存储在存储器120内的数据,执行终端600的各种功能和处理数据,从而对手机进行整体监控。可选的,处理器180可包括一个或多个处理核心;优选的,处理器180可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器180中。
终端600还包括给各个部件供电的电源190(比如电池),优选的,电源可以通过电源管理系统与处理器180逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。电源190还可以包括一个或多个的直流或交流电源、再充电系统、电源故障检测电路、电源转换器或者逆变器、电源状态指示器等任意组件。
尽管未示出,终端600还可以包括摄像头、蓝牙模块等,在此不再赘述。具体在本实施例中,终端600的显示单元是触摸屏显示器,终端600还包括有存储器,以及一个或者多个的程序,其中一个或者多个程序存储于存储器中,且经配置以由一个或者多个处理器执行述一个或者多个程序包含用于进行以下操作的指令:
当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述预设硬件识别码存储到第一预设存储位置;
当检测到目标应用程序的启动触发事件时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;
如果所述第一预设存储位置中存储有所述预设硬件识别码,则启动所述目标应用程序;如果所述第一预设存储位置中未存储有所述预设硬件识别码,则阻止所述目标应用程序启动。
可选的,所述方法还包括:
在终端生产阶段通过所述调制解调器子程序,接收携带有所述预设硬件识别码和所述第二预设存储位置的存储请求;并将所述预设硬件识别码存储到所述调制解调器子程序对应的数据存储区内的第二预设存储位置。
可选的,所述当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述预设硬件识别码存储到第一预设存储位置,包括:
当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的加密后的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述加密后的预设硬件识别码存储到第一预设存储位置。
可选的,所述通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码,包括:
通过所述目标应用程序,在终端的所述第一预设存储位置进行数据查找;
如果所述第一预设存储位置中存储有第一数据,则基于预设的解密算法对所述第一数据进行解密处理,如果解密后的第一数据与所述预设硬件识别码相匹配,则判定所述第一预设存储位置中存储有所述预设硬件识别码,如果解密后的第一数据与所述预设硬件识别码不匹配,则判定所述第一预设存储位置中未存储所述预设硬件识别码;
如果所述第一预设存储位置中未存储数据,则判定所述第一预设存储位置中未存储所述预设硬件识别码。
可选的,所述当检测到目标应用程序的启动触发事件时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码,包括:
当检测到用户输入的目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;或者,
在所述终端开机过程中接收到目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码。
本发明实施例中,当终端检测到目标应用程序的启动触发事件时,目标应用程序可以判断终端的第一预设存储位置中是否存储有预设硬件识别码,如果第一预设存储位置中存储有预设硬件识别码,则可以启动目标应用程序;如果第一预设存储位置中未存储有预设硬件识别码,则可以阻止目标应用程序启动。这样,目标应用程序只有安装在特定的终端上才能正常启动,其他终端生产厂商即使非法获取了目标应用程序的安装包,目标应用程序也不能在其终端上正常启动,即其他终端生产厂商的终端不能具有相应的目标应用程序的功能,从而,可以防止其他终端生产厂商对应用程序的恶意侵占。
本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,所述的程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。
以上所述仅为本发明的较佳实施例,并不用以限制本发明,凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
Claims (10)
1.一种启动应用程序的方法,其特征在于,所述方法包括:
当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述预设硬件识别码存储到第一预设存储位置,所述第一预设存储位置是终端的存储位置中目标应用程序能够访问的存储位置;
当检测到所述目标应用程序的启动触发事件时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;
如果所述第一预设存储位置中存储有所述预设硬件识别码,则启动所述目标应用程序;如果所述第一预设存储位置中未存储有所述预设硬件识别码,则阻止所述目标应用程序启动。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
在终端生产阶段通过所述调制解调器子程序,接收携带有所述预设硬件识别码和所述第二预设存储位置的存储请求;并将所述预设硬件识别码存储到所述调制解调器子程序对应的数据存储区内的第二预设存储位置。
3.根据权利要求1所述的方法,其特征在于,所述当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述预设硬件识别码存储到第一预设存储位置,包括:
当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的加密后的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述加密后的预设硬件识别码存储到第一预设存储位置。
4.根据权利要求3所述的方法,其特征在于,所述通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码,包括:
通过所述目标应用程序,在终端的所述第一预设存储位置进行数据查找;
如果所述第一预设存储位置中存储有第一数据,则基于预设的解密算法对所述第一数据进行解密处理,如果解密后的第一数据与所述预设硬件识别码相匹配,则判定所述第一预设存储位置中存储有所述预设硬件识别码,如果解密后的第一数据与所述预设硬件识别码不匹配,则判定所述第一预设存储位置中未存储所述预设硬件识别码;
如果所述第一预设存储位置中未存储数据,则判定所述第一预设存储位置中未存储所述预设硬件识别码。
5.根据权利要求1所述的方法,其特征在于,所述当检测到目标应用程序的启动触发事件时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码,包括:
当检测到用户输入的目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;或者,
在所述终端开机过程中接收到目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码。
6.一种启动应用程序的装置,其特征在于,所述装置包括:
第一存储模块,用于当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述预设硬件识别码存储到第一预设存储位置,所述第一预设存储位置是终端的存储位置中目标应用程序能够访问的存储位置;
判断模块,用于当检测到所述目标应用程序的启动触发事件时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;
执行模块,用于如果所述第一预设存储位置中存储有所述预设硬件识别码,则启动所述目标应用程序;如果所述第一预设存储位置中未存储有所述预设硬件识别码,则阻止所述目标应用程序启动。
7.根据权利要求6所述的装置,其特征在于,所述装置还包括:
接收模块,用于在终端生产阶段通过所述调制解调器子程序,接收携带有所述预设硬件识别码和所述第二预设存储位置的存储请求;
第二存储模块,用于将所述预设硬件识别码存储到所述调制解调器子程序对应的数据存储区内的第二预设存储位置。
8.根据权利要求6所述的装置,其特征在于,所述第一存储模块,用于:
当接收到开机指令时,通过调制解调器子程序,将所述调制解调器子程序对应的数据存储区内的第二预设存储位置中的加密后的预设硬件识别码存储到共享存储位置,并通过内核Kernel程序将所述共享存储位置内的所述加密后的预设硬件识别码存储到第一预设存储位置。
9.根据权利要求8所述的装置,其特征在于,所述判断模块,包括:
查找子模块,用于通过所述目标应用程序,在终端的所述第一预设存储位置进行数据查找;
判断子模块,用于如果所述第一预设存储位置中存储有第一数据,则基于预设的解密算法对所述第一数据进行解密处理,如果解密后的第一数据与所述预设硬件识别码相匹配,则判定所述第一预设存储位置中存储有所述硬件识别码,如果解密后的第一数据与所述预设硬件识别码不匹配,则判定所述第一预设存储位置中未存储所述预设硬件识别码;如果所述第一预设存储位置中未存储数据,则判定所述第一预设存储位置中未存储所述预设硬件识别码。
10.根据权利要求6所述的装置,其特征在于,所述判断模块,用于:
当检测到用户输入的目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码;或者,
在所述终端开机过程中接收到目标应用程序的启动指令时,通过所述目标应用程序,判断终端的所述第一预设存储位置中是否存储有所述预设硬件识别码。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610976153.9A CN106528231B (zh) | 2016-11-07 | 2016-11-07 | 一种启动应用程序的方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610976153.9A CN106528231B (zh) | 2016-11-07 | 2016-11-07 | 一种启动应用程序的方法和装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN106528231A CN106528231A (zh) | 2017-03-22 |
CN106528231B true CN106528231B (zh) | 2019-08-20 |
Family
ID=58349963
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610976153.9A Active CN106528231B (zh) | 2016-11-07 | 2016-11-07 | 一种启动应用程序的方法和装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN106528231B (zh) |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108595962B (zh) * | 2018-04-19 | 2022-06-03 | 深圳鼎智通讯股份有限公司 | 一种pos机终端解码库授权码校检方法 |
CN111783169B (zh) * | 2020-07-09 | 2024-05-24 | 深圳市欢太科技有限公司 | 设备唯一识别码确定方法、装置、终端设备及存储介质 |
CN115080151B (zh) * | 2022-07-22 | 2023-07-14 | 平安银行股份有限公司 | App启动流程控制方法、计算机可读存储介质及终端 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101084482A (zh) * | 2004-09-17 | 2007-12-05 | 英华达股份有限公司 | 电子软件分配方法及使用以硬件识别为基础的数字权利管理方法的系统 |
CN101142599A (zh) * | 2004-09-17 | 2008-03-12 | 英华达股份有限公司 | 基于硬件识别的数字权利管理系统 |
CN103620556A (zh) * | 2011-05-02 | 2014-03-05 | 微软公司 | 将应用绑定到设备能力 |
CN104363094A (zh) * | 2014-10-30 | 2015-02-18 | 广东欧珀移动通信有限公司 | 一种认证应用程序用户身份的方法、装置和系统 |
-
2016
- 2016-11-07 CN CN201610976153.9A patent/CN106528231B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101084482A (zh) * | 2004-09-17 | 2007-12-05 | 英华达股份有限公司 | 电子软件分配方法及使用以硬件识别为基础的数字权利管理方法的系统 |
CN101142599A (zh) * | 2004-09-17 | 2008-03-12 | 英华达股份有限公司 | 基于硬件识别的数字权利管理系统 |
CN103620556A (zh) * | 2011-05-02 | 2014-03-05 | 微软公司 | 将应用绑定到设备能力 |
CN104363094A (zh) * | 2014-10-30 | 2015-02-18 | 广东欧珀移动通信有限公司 | 一种认证应用程序用户身份的方法、装置和系统 |
Also Published As
Publication number | Publication date |
---|---|
CN106528231A (zh) | 2017-03-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106598584B (zh) | 一种处理资源文件的方法、装置和系统 | |
CN103389863B (zh) | 一种显示控制方法和装置 | |
CN106502703B (zh) | 一种函数调用方法和装置 | |
CN106775833B (zh) | 设备驱动程序加载方法、终端及系统 | |
CN106713608B (zh) | 应用的功能状态修改方法、装置及终端 | |
CN104965722B (zh) | 一种显示信息的方法及装置 | |
CN106953898B (zh) | 一种获取软件包的方法和装置 | |
EP2869604B1 (en) | Method, apparatus and device for processing a mobile terminal resource | |
CN109067751B (zh) | 一种非Root环境下ARP欺骗检测方法、装置及终端 | |
CN110830127B (zh) | 射频参数处理方法、装置、移动终端及存储介质 | |
CN106528231B (zh) | 一种启动应用程序的方法和装置 | |
CN105975316A (zh) | 一种进程管理方法、装置及设备 | |
WO2015120796A1 (en) | Application-based service providing method, apparatus, and system | |
CN106095423B (zh) | 提供浏览服务的方法、终端及服务器 | |
US20200125369A1 (en) | Method, device, and terminal for accelerating startup of application | |
EP3129883B1 (en) | Method and apparatus for repairing dynamic link library file | |
CN105278942B (zh) | 组件管理方法及装置 | |
CN106850957B (zh) | 应用通知管理的方法、装置及移动终端 | |
CN110891262A (zh) | 一种蓝牙配对的方法、系统和终端设备 | |
CN105955789A (zh) | 一种应用程序卸载方法、装置及设备 | |
CN107122204B (zh) | 应用的卸载状态检测方法及装置 | |
CN106933626B (zh) | 应用关联方法及装置 | |
CN106445594B (zh) | 系统应用的安装方法、装置和终端设备 | |
CN108549552B (zh) | 一种内核加载方法、装置及存储介质 | |
CN108280798B (zh) | 一种浏览器内核渲染显示的方法和装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant | ||
CP03 | Change of name, title or address | ||
CP03 | Change of name, title or address |
Address after: Shandong City, Qingdao Province, Jiangxi City Road No. 11 Patentee after: Qingdao Hisense Mobile Communication Technology Co.,Ltd. Country or region after: China Address before: Shandong City, Qingdao Province, Jiangxi City Road No. 11 Patentee before: HISENSE MOBILE COMMUNICATIONS TECHNOLOGY Co.,Ltd. Country or region before: China |