本公开涉及电子设备领域,尤其涉及应用控制方法及装置。
背景技术:
安卓系统内置了许多应用,这些应用可以分为系统应用和普通应用,其中,系统应用不会随着恢复出厂设置而丢失,用户无需再次安装的应用,普通应用是用户安装且会随着恢复出厂设置而丢失的应用。
技术实现要素:
本公开实施例提供应用控制方法及装置。所述技术方案如下:
根据本公开实施例的第一方面,提供一种应用控制方法,包括:
获取第一系统应用的初始安装时间;
获取所述第一系统应用的应用签名;
当所述初始安装时间不在预设范围内,且所述应用签名不是预设签名时,禁止所述第一系统应用启动。
本公开的实施例提供的技术方案可以包括以下有益效果:只要一个系统应用符合初始安装时间不在预设范围内,且应用签名不是预设签名的条件,就能确定该系统应用是伪造系统应用,需要应用控制,限制伪造系统应用的高频率重启行为,并解决伪造系统应用杀不死引起的功耗问题。
在一个实施例中,所述禁止所述第一系统应用启动包括:
将所述第一系统应用的persistent属性设置为false。
本公开的实施例提供的技术方案可以包括以下有益效果:从程序底层实现禁止伪造系统应用的高频率重启行为。
在一个实施例中,所述禁止所述第一系统应用启动包括:
停止正在运行的所述第一系统应用;
禁止所述第一系统应用再次启动。
本公开的实施例提供的技术方案可以包括以下有益效果:停止正在伪造系统应用,并禁止再次启动,从而完全禁止伪造系统应用的启动。
在一个实施例中,所述获取第一系统应用的初始安装时间包括:
在预设时间段内,获取各个系统应用的启动次数;
获取所述各个应用的每次一启动和对应的上一次启动之间的时间间隔;
当所述第一系统应用的启动次数小于或等于预设值,且所有的所述启动间隔大于第一预设间隔时,获取所述第一系统应用的初始安装时间。
本公开的实施例提供的技术方案可以包括以下有益效果:为判断第一系统应用是否是伪造系统应用提供一个条件。
在一个实施例中,所述方法还包括:
当所述第一系统应用的启动次数小于或等于预设值,或,所有的所述启动间隔小于或等于所述预设间隔时,增大所述时间间隔至第二预设间隔,所述第二预设间隔大于所述第一预设间隔。
本公开的实施例提供的技术方案可以包括以下有益效果:增大启动间隔,从而满足判断条件,可以在之后判断该第一系统应用是否是伪造系统应用。
根据本公开实施例的第二方面,提供一种应用控制装置,包括:
获取模块,用于获取第一系统应用的初始安装时间;获取所述第一系统应用的应用签名;
禁止模块,用于当所述初始安装时间不在预设范围内,且所述应用签名不是预设签名时,禁止所述第一系统应用启动。
在一个实施例中,所述禁止模块包括:
设置子模块,用于将所述第一系统应用的persistent属性设置为false。
在一个实施例中,所述禁止模块包括:
停止子模块,用于停止正在运行的所述第一系统应用;
禁止子模块,用于禁止所述第一系统应用再次启动。
在一个实施例中,所述获取模块包括:
第一获取子模块,用于在预设时间段内,获取各个系统应用的启动次数;
第二获取子模块,用于获取所述各个应用的每次一启动和对应的上一次启动之间的时间间隔;
第三获取子模块,用于当所述第一系统应用的启动次数小于或等于预设值,且所有的所述启动间隔大于第一预设间隔时,获取所述第一系统应用的初始安装时间。
在一个实施例中,所述装置还包括:
增大模块,用于当所述第一系统应用的启动次数小于或等于预设值,或,所有的所述启动间隔小于或等于所述预设间隔时,增大所述时间间隔至第二预设间隔,所述第二预设间隔大于所述第一预设间隔。
根据本公开实施例的第三方面,提供一种应用控制装置,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为:
获取第一系统应用的初始安装时间,获取所述第一系统应用的应用签名;
当所述初始安装时间不在预设范围内,且所述应用签名不是预设签名时,禁止所述第一系统应用启动。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
图1是根据一示例性实施例示出的应用控制方法的流程图。
图2是根据一示例性实施例示出的应用控制方法的流程图。
图3是根据一示例性实施例示出的应用控制方法的流程图。
图4是根据一示例性实施例示出的应用控制装置的框图。
图5是根据一示例性实施例示出的应用控制装置的框图。
图6是根据一示例性实施例示出的应用控制装置的框图。
图7是根据一示例性实施例示出的应用控制装置的框图。
图8是根据一示例性实施例示出的应用控制装置的框图。
图9是根据一示例性实施例示出的应用控制装置的框图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
相关技术中,anroid(安卓)系统中有一类应用叫做系统应用。它们放到/system/app目录下。这一类应用有一个特权,如果系统应用在manefest文件中声明android:persistent=“true”,即persistent属性为true(真)。那么这一类应用被杀死之后会自动重启。实际情况是有些第三方工具利用root权限将特定的应用以系统应用的方式安装,并声明android:persistent=“true”,由此给予这些特性的应用杀死之后重启动的特权。
本实施例所解决的问题为:限制伪造系统应用的高频率重启行为,并解决伪造系统应用杀不死引起的功耗问题。
实施例一
图1是根据一示例性实施例示出的一种应用控制方法的流程图,如图1所示,应用控制方法用于应用控制装置中,该装置用于终端设备,该方法包括以下步骤101-103:
在步骤101中,获取第一系统应用的初始安装时间。
初始安装时间是该第一系统应用的安装时间,不为更新时间。本实施例中,如果初始安装时间是在原生系统的安装时间之后的一段时间内安装,可以说明第一系统应用是在出厂时安装的,即说明第一系统应用是原生系统应用。
这里,系统应用和普通应用可以通过安装位置区分,也可以通过persistent属性来区分。系统应用是无需用户开启就可以在后台运行的应用,即使用户关闭后,还可以再次启动的应用。
在步骤102中,获取第一系统应用的应用签名。
应用签名是为了保证每个应用程序开发商合法身份标识,防止部分开放商可能通过使用相同的包名来混淆替换已经安装的程序,需要对发布的安装包文件进行唯一签名,从而保证每次发布的版本的一致性。
因此,只有应用签名是厂商特定的标识,才能说明第一系统应用是原生的系统应用。示例的,a品牌手机里面某一系统应用的应用签名是a签名,那么说明该系统应用是原生的。
在步骤103中,当初始安装时间不在预设范围内,且应用签名不是预设签名时,禁止第一系统应用启动。
当第一系统应用的初始安装时间不在预设范围内,且应用签名不是预设签名时,第一系统应用是伪造系统应用。这里,预设签名可以是该应用下载来源的公司官网的标识、或者下载该应用的来源处的标识。例如来源处是应用商城、被应用所属公司授权下载的网址等等。
本实施例中,只要一个系统应用符合初始安装时间不在预设范围内,且应用签名不是预设签名的条件,就能确定该系统应用是伪造系统应用,需要禁止启动,限制伪造系统应用的高频率重启行为,并解决伪造系统应用杀不死引起的功耗问题。
在一个实施例中,步骤103可以包括:
将第一系统应用的persistent属性设置为false。
当persistent属性是true时,第一系统应用可以重复自动启动,当persistent属性是false时,第一系统应用不能重复启动。
这里,persistent属性是底层程序中manefest文件设置的一个表征是否表征应用是否是永久性应用的属性。永久性应用就是杀不死的应用,即使停止后,会自动启动的应用。
在一个实施例中,步骤103可以包括:
停止正在运行的第一系统应用;禁止第一系统应用再次启动。
本实施例是上一个实施例具体的表现方式,如果第一系统应用正在运行,那么停止第一应用运行,且禁止再次启动;如果第一系统应用没有在运行,那么禁止启动第一系统应用。
在一个实施例中,步骤101可以包括:
在预设时间段内,获取各个系统应用的启动次数;获取各个应用的每次一启动和对应的上一次启动之间的时间间隔;当第一系统应用的启动次数小于或等于预设值,且所有的启动间隔大于第一预设间隔时,获取第一系统应用的初始安装时间。
这里,当第一系统应用的启动次数小于或等于预设值,且所有的启动间隔大于第一预设间隔时,认为第一系统应用不是频繁启动的系统应用;当第一系统应用的启动次数大于预设值,且所有的启动间隔小于或等于预设间隔时,认为第一系统应用是频繁启动的系统应用。本实施例中,预设时间段是24小时内。
在一个实施例中,所述方法还包括:
当所述第一系统应用的启动次数小于或等于预设值,或,所有的所述启动间隔小于或等于第一预设间隔时,增大所述时间间隔至第二预设间隔,第二间隔大于第一预设间隔。
本实施例中,当第一系统应用启动时,判断本次启动和上次启动之间的时间间隔是否大于或等于第二预设间隔;若是,则启动;若否,则等到。
本实施例还可以在上述条件下,限制第一系统应用在预设时间段内的启动次数至预设次数;所述预设次数小于或等于预设值。即启动预设次数次之后,禁止不再让启动。
实施例二
图2是根据一示例性实施例示出的一种应用控制方法的流程图,如图2所示,应用控制方法用于移动终端中,包括以下步骤201-204,
在步骤201中,获取第一系统应用的初始安装时间。
在步骤202中,获取第一系统应用的应用签名。
在步骤203中,当初始安装时间不在预设范围内,且应用签名不是预设签名时,停止正在运行的第一系统应用。
在步骤204中,禁止第一系统应用再次启动。
本实施例不仅仅可以停止正在运行的伪造系统应用,还可以禁止以后该伪造系统应用的再次启动。
实施例三
图3是根据一示例性实施例示出的一种应用控制方法的流程图,如图1所示,应用控制方法用于服务器中,包括以下步骤301-307:
在步骤301中,在预设时间段内,获取各个系统应用的启动次数。
在步骤302中,获取各个应用的每次一启动和对应的上一次启动之间的时间间隔。
在步骤303中,判断各个系统应用的启动次数是否小于或等于预设值,且判断所有的启动间隔是否大于第一预设间隔。若是,则执行步骤304;若否,则执行步骤307。
在步骤304中,获取第一系统应用的初始安装时间。
在步骤305中,获取第一系统应用的应用签名。
在步骤306中,将第一系统应用的persistent属性从true真设置为false假。
在步骤307中,增大时间间隔至第二预设间隔。
这里,第二预设间隔大于第一预设间隔。
本实施例设置了判定第一系统应用是否是伪造系统应用的条件,减少频繁启动的系统应用的启动,禁止不频繁启动的伪造系统应用的启动,从而限制系统应用的频繁启动,节省了功耗。
下述为本公开装置实施例,可以用于执行本公开方法实施例。
实施例四
图4是根据一示例性实施例示出的一种应用控制装置的框图,该装置可以通过软件、硬件或者两者的结合实现成为电子设备的部分或者全部。如图4所示,该应用控制装置包括:
获取模块401,用于获取第一系统应用的初始安装时间;获取所述第一系统应用的应用签名。
禁止模块402,用于当所述初始安装时间不在预设范围内,且所述应用签名不是预设签名时,禁止所述第一系统应用启动。
本实施例中,只要一个系统应用符合初始安装时间不在预设范围内,且应用签名不是预设签名的条件,就能确定该系统应用是伪造系统应用,需要禁止启动,限制伪造系统应用的高频率重启行为,并解决伪造系统应用杀不死引起的功耗问题。
在一个实施例中,如图5所示,所述禁止模块402包括:
设置子模块4021,用于将所述第一系统应用的persistent属性设置为false假。
在一个实施例中,如图6所示,所述禁止模块402包括:
停止子模块4022,用于停止正在运行的所述第一系统应用;
禁止子模块4023,用于禁止所述第一系统应用再次启动。
在一个实施例中,如图7所示,所述获取模块401包括:
第一获取子模块4011,用于在预设时间段内,获取各个系统应用的启动次数;
第二获取子模块4012,用于获取所述各个应用的每次一启动和对应的上一次启动之间的时间间隔;
第三获取子模块4013,用于当所述第一系统应用的启动次数小于或等于预设值,且所有的所述启动间隔大于第一预设间隔时,获取所述第一系统应用的初始安装时间。
在一个实施例中,如图8所示,所述装置还包括:
增大模块403,用于当所述第一系统应用的启动次数小于或等于预设值,或,所有的所述启动间隔小于或等于所述第一预设间隔时,增大所述时间间隔至第二预设间隔,所述第二预设间隔大于所述第一预设间隔。
根据本公开实施例的第三方面,提供一种应用控制装置,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,处理器被配置为:
获取第一系统应用的初始安装时间;
获取所述第一系统应用的应用签名;
当所述初始安装时间不在预设范围内,且所述应用签名不是预设签名时,禁止所述第一系统应用启动。
上述处理器还可被配置为:
所述禁止所述第一系统应用启动包括:
将所述第一系统应用的persistent属性从true真设置为false假。
所述禁止所述第一系统应用启动包括:
停止正在运行的所述第一系统应用;
禁止所述第一系统应用再次启动。
所述获取第一系统应用的初始安装时间包括:
在预设时间段内,获取各个系统应用的启动次数;
获取所述各个应用的每次一启动和对应的上一次启动之间的时间间隔;
当所述第一系统应用的启动次数小于或等于预设值,且所有的所述启动间隔大于第一预设间隔时,获取所述第一系统应用的初始安装时间。
所述方法还包括:
当所述第一系统应用的启动次数小于或等于预设值,或,所有的所述启动间隔小于或等于所述预设间隔时,增大所述时间间隔至第二预设间隔,所述第二预设间隔大于所述第一预设间隔。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
图9是根据一示例性实施例示出的一种用于应用控制装置的框图,该装置适用于终端设备。例如,装置1700可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
装置1700可以包括以下一个或多个组件:处理组件1702,存储器1704,电源组件1706,多媒体组件1708,音频组件1710,输入/输出(i/o)接口1712,传感器组件1714,以及通信组件1716。
处理组件1702通常控制装置1700的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件1702可以包括一个或多个处理器1720来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件1702可以包括一个或多个模块,便于处理组件1702和其他组件之间的交互。例如,处理组件1702可以包括多媒体模块,以方便多媒体组件1708和处理组件1702之间的交互。
存储器1704被配置为存储各种类型的数据以支持在装置1700的操作。这些数据的示例包括用于在装置1700上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器1704可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(sram),电可擦除可编程只读存储器(eeprom),可擦除可编程只读存储器(eprom),可编程只读存储器(prom),只读存储器(rom),磁存储器,快闪存储器,磁盘或光盘。
电源组件1706为装置1700的各种组件提供电力。电源组件1706可以包括电源管理系统,一个或多个电源,及其他与为装置1700生成、管理和分配电力相关联的组件。
多媒体组件1708包括在所述装置1700和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(lcd)和触摸面板(tp)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件1708包括一个前置摄像头和/或后置摄像头。当装置1700处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件1710被配置为输出和/或输入音频信号。例如,音频组件1710包括一个麦克风(mic),当装置1700处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器1704或经由通信组件1716发送。在一些实施例中,音频组件1710还包括一个扬声器,用于输出音频信号。
i/o接口1712为处理组件1702和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件1714包括一个或多个传感器,用于为装置1700提供各个方面的状态评估。例如,传感器组件1714可以检测到装置1700的打开/关闭状态,组件的相对定位,例如所述组件为装置1700的显示器和小键盘,传感器组件1714还可以检测装置1700或装置1700一个组件的位置改变,用户与装置1700接触的存在或不存在,装置1700方位或加速/减速和装置1700的温度变化。传感器组件1714可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件1714还可以包括光传感器,如cmos或ccd图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件1714还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件1716被配置为便于装置1700和其他设备之间有线或无线方式的通信。装置1700可以接入基于通信标准的无线网络,如wifi,2g或3g,或它们的组合。在一个示例性实施例中,通信组件1716经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件1716还包括近场通信(nfc)模块,以促进短程通信。例如,在nfc模块可基于射频识别(rfid)技术,红外数据协会(irda)技术,超宽带(uwb)技术,蓝牙(bt)技术和其他技术来实现。
在示例性实施例中,装置1700可以被一个或多个应用专用集成电路(asic)、数字信号处理器(dsp)、数字信号处理设备(dspd)、可编程逻辑器件(pld)、现场可编程门阵列(fpga)、控制器、微控制器、微处理器或其他电子组件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器1704,上述指令可由装置1700的处理器1720执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是rom、随机存取存储器(ram)、cd-rom、磁带、软盘和光数据存储设备等。
一种非临时性计算机可读存储介质,当所述存储介质中的指令由装置1700的处理器执行时,使得装置1700能够执行上述应用控制方法,所述方法包括:
获取第一系统应用的初始安装时间;
获取所述第一系统应用的应用签名;
当所述初始安装时间不在预设范围内,且所述应用签名不是预设签名时,禁止所述第一系统应用启动。
所述禁止所述第一系统应用启动包括:
将所述第一系统应用的persistent属性从true真设置为false假。
所述禁止所述第一系统应用启动包括:
停止正在运行的所述第一系统应用;
禁止所述第一系统应用再次启动。
所述获取第一系统应用的初始安装时间包括:
在预设时间段内,获取各个系统应用的启动次数;
获取所述各个应用的每次一启动和对应的上一次启动之间的时间间隔;
当所述第一系统应用的启动次数小于或等于预设值,且所有的所述启动间隔大于第一预设间隔时,获取所述第一系统应用的初始安装时间。
所述方法还包括:
当所述第一系统应用的启动次数小于或等于预设值,或,所有的所述启动间隔小于或等于所述预设间隔时,增大所述时间间隔至第二预设间隔,所述第二预设间隔大于所述第一预设间隔。
本领域技术人员在考虑说明书及实践这里公开的公开后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。