一种应用程序的处理方法及电子设备与流程

文档序号:29938870发布日期:2022-05-07 14:03阅读:88来源:国知局
一种应用程序的处理方法及电子设备与流程

1.本技术涉及终端技术领域,尤其涉及一种应用程序的处理方法及电子设备。


背景技术:

2.随着电子设备的发展,各类应用程序(application,app)层出不穷,使得用户可以在电子设备上通过app处理很多事情,为用户提供了方便。运营商或企业可以定制一些个性化app。开发人员可以将运营商或企业定制的app的相关资源(如,图片、音频以及视频等)和对应安装包(android package,apk)打包成一个定制包。定制的app被测试通过后,由app管理人员将测试通过的定制包上传到app服务器。然后,app服务器将定制包推送至电子设备进行安装。
3.由于定制包中包括定制app的相关资源和apk等信息,电子设备从app服务器下载定制包进行升级时,存在升级速率慢、定制包占用空间大等问题。


技术实现要素:

4.本技术实施例提供一种应用程序的处理方法及电子设备,可以通过电子设备获取定制包;其中,定制包中包括多个app的标识,电子设备根据多个app标识从服务器下载得到多个app的apk后,对多个app的apk进行安装。由此,本技术中的定制包并未包含多个app的apk,而是根据定制包中的多个app的标识从服务器下载得到对应的apk,不仅减小了定制包的大小,还提高了电子设备从app服务器下载定制包的速率,减少了定制包在电子设备中占用的存储空间。同时,还提高了电子设备安装多个app的效率。
5.为达到上述目的,本技术采用如下技术方案:
6.第一方面,本技术实施例提供一种应用程序的处理方法,应用于电子设备,方法包括:获取定制包;其中,定制包中包括多个应用程序的标识,且未包括应用程序安装包;根据多个应用程序的标识,获取与多个应用程序的标识对应的多个应用程序安装包;根据多个应用程序安装包,对多个应用程序进行安装或更新。
7.由此,由于定制包并未包含多个app的apk,而是电子设备根据定制包中的多个app的标识从服务器下载得到对应的apk,不仅减小了定制包的大小,还提高了电子设备从app服务器下载定制包的速率,减少了定制包在电子设备中占用的存储空间。同时,还提高了电子设备安装多个app的效率。
8.在一种可能的实现方式中,根据多个应用程序的标识,获取与多个应用程序的标识对应的多个应用程序安装包,包括:向服务器发送第一请求消息;其中,第一请求消息中携带有多个应用程序的标识;接收服务器发送的与多个应用程序的标识对应的多个应用程序的下载路径;向服务器发送下载请求;其中,下载请求中携带有多个应用程序对应的下载路径。
9.由此,电子设备根据多个app的标识从服务器获取到各app标识对应的下载路径后,根据下载路径从服务器下载对应的多个app安装包,并未将多个app安装包封装至定制
包中,不仅减小了定制包的大小,还提高了电子设备从app服务器下载定制包的速率,减少了定制包在电子设备中占用的存储空间。
10.在另一种可能的实现方式中,根据多个应用程序的标识,获取与多个应用程序的标识对应的多个应用程序安装包,包括:向服务器发送第二请求消息;其中,第二请求消息中携带有多个应用程序的标识;接收服务器发送的分别与多个应用程序的标识对应的多个应用程序安装包。
11.由此,电子设备根据多个app的标识从服务器获取多个应用程序安装包,提高了获取多个应用程序安装包的效率。此外,并未将多个app安装包封装至定制包中,不仅减小了定制包的大小,还提高了电子设备从app服务器下载定制包的速率,减少了定制包在电子设备中占用的存储空间。
12.在另一种可能的实现方式中,定制包还包括多个应用程序的安装路径,根据多个应用程序安装包,对多个应用程序进行安装或更新,包括:根据多个应用程序对应的安装路径,对多个应用程序进行安装或更新。
13.由此,将多个app安装包安装至对应的安装路径,避免了获取应用程序安装路径的过程,提高了多个app的安装或更新效率。
14.在另一种可能的实现方式中,获取定制包,包括:向服务器发送搜包请求;获取服务器发送的定制包。
15.由此,电子设备可以在首次联网或者按照预设时长(如12小时、24小时等)主动向服务器发送搜包请求,实现了电子设备自动获取定制包的目的。
16.在另一种可能的实现方式中,获取定制包,包括:接收服务器推送的定制包。
17.由此,服务器主动向电子设备推送定制包,实现了服务器侧主动推荐安装app或更新app的目的。
18.在另一种可能的实现方式中,对多个应用程序进行安装或更新之后,还包括:显示提示信息;提示信息用于提示用户多个应用程序是否安装或更新成功。
19.由此,用户可以根据电子设备显示的提示信息确定多个app是否安装或更新成功,避免了电子设备并未安装或更新多个app而用户并未清楚的情况。
20.在另一种可能的实现方式中,根据多个应用程序的标识,获取与多个应用程序的标识对应的多个应用程序安装包之前,还包括:对多个应用程序的标识进行筛选,得到待安装或待升级的应用程序的标识。
21.由此,用户或手机自动筛选掉定制包中包括的电子设备中已经安装或更新过app,避免电子设备重复获取apk的过程。
22.在另一种可能的实现方式中,多个应用程序为同一运营商、企业或服务商定制的,或者,多个应用程序为不同运营商、企业或服务商定制的相关应用程序。
23.当同一运营商、企业或服务商定制多个app时,开发人员可以将多个app的标识封装在同一个定制包中,以实现对多个app进行安装或更新。或者,当不同运营商、企业或服务商定制的多个相关app时,开发人员也可以将多个app的标识封装在同一个定制包中,可以一次性的对多个相关app进行安装或更新。
24.第二方面,本技术实施例提供另一种应用程序的处理方法,应用于服务器,方法包括:向电子设备发送定制包;定制包中包括多个应用程序的标识,且未包括应用程序安装
包;响应于电子设备发送的第三请求消息,查询得到与多个应用程序的标识对应的多个应用程序安装包;向电子设备发送多个应用程序安装包。
25.由此,定制包并未包含多个app的apk,不仅提高了app服务器向电子设备发送定制包的速率,还减少了定制包在电子设备中占用的存储空间。
26.在一种可能的实现方式中,响应于电子设备发送的第三请求消息,查询得到与多个应用程序的标识对应的多个应用程序安装包,包括:接收电子设备发送的第三请求消息,其中,第三请求消息中携带有多个应用程序的标识;根据多个应用程序的标识,查询得到与多个应用程序的标识对应的多个应用程序安装包。
27.由此,服务器根据多个app的标识直接查询得到多个app对应的apk,并未将多个app安装包封装至定制包中,提高了app服务器向电子设备发送定制包的速率。
28.在另一种可能的实现方式中,响应于电子设备发送的第三请求消息,查询得到与多个应用程序的标识对应的多个应用程序安装包,包括:根据多个应用程序的标识,查询得到与多个应用程序对应的下载路径;向电子设备发送多个应用程序对应的下载路径;接收电子设备发送的下载请求;其中,下载请求中携带有多个应用程序对应的下载路径;根据多个应用程序对应下载路径,查询得到多个应用程序安装包。
29.在另一种可能的实现方式中,多个应用程序为同一运营商、企业或服务商定制的,或者,多个应用程序为不同运营商、企业或服务商定制的相关应用程序。
30.第三方面,本技术提供一种电子设备,包括:一个或多个处理器;存储器;其中,存储器中存储有一个或多个计算机程序,一个或多个计算机程序包括指令,当指令被电子设备执行时,使得电子设备执行以下步骤:获取定制包;其中,定制包中包括多个应用程序的标识,且未包括应用程序安装包;根据多个应用程序的标识,获取与多个应用程序的标识对应的多个应用程序安装包;根据多个应用程序安装包,对多个应用程序进行安装或更新。
31.第四方面,本技术提供一种服务器,包括:一个或多个处理器;存储器;其中,存储器中存储有一个或多个计算机程序,一个或多个计算机程序包括指令,当指令被服务器执行时,使得服务器执行以下步骤:向电子设备发送定制包;定制包中包括多个应用程序的标识,且未包括应用程序安装包;响应于电子设备发送的第三请求消息,查询得到与多个应用程序的标识对应的多个应用程序安装包;向电子设备发送多个应用程序安装包。
32.第五方面,本技术提供一种计算机存储介质,包括计算机指令,当计算机指令在电子设备上运行时,使得电子设备执行如第一方面中任一项的应用程序的处理方法,或者,当指令在服务器上运行时,使得服务器执行如第一方面的应用程序的处理方法。
33.第六方面,本技术提供一种计算机程序产品,当计算机程序产品在电子设备上运行时,使得电子设备执行如第一方面中任一项的应用程序的处理方法,或者,当计算机指令在服务器上运行时,使得服务器执行如第二方面的应用程序的处理方法。
34.可以理解地,上述提供的电子设备,服务器,计算机存储介质,以及计算机程序产品均用于执行上文所提供的对应的方法,因此,其所能达到的有益效果可参考上文所提供的对应的方法中的有益效果,此处不再赘述。
附图说明
35.图1为相关技术中提供的一种定制包的示意图;
36.图2为本技术实施例提供的一种电子设备的结构示意图一;
37.图3为本技术实施例提供的一种电子设备的结构示意图二;
38.图4为本技术实施例提供的一种定制包的示意图;
39.图5为本技术实施例提供的一种应用程序的处理方法的应用场景示意图一;
40.图6为本技术实施例提供的一种应用程序的处理方法的流程示意图;
41.图7为本技术实施例提供的一种应用程序的处理方法的应用场景示意图二;
42.图8为本技术实施例提供的一种应用程序的处理方法的应用场景示意图三;
43.图9为本技术实施例提供的一种应用程序的处理方法的应用场景示意图四;
44.图10为本技术实施例提供的一种应用程序的处理方法的应用场景示意图五;
45.图11为本技术实施例提供的一种电子设备的结构示意图三。
具体实施方式
46.下面将结合本技术实施例中的附图,对本技术实施例中的技术方案进行描述。其中,在本技术实施例的描述中,除非另有说明,“/”表示或的意思,例如,a/b可以表示a或b;本文中的“和/或”仅仅是一种描述关联对象的关联关系,表示可以存在三种关系,例如,a和/或b,可以表示:单独存在a,同时存在a和b,单独存在b这三种情况。
47.以下,术语“第一”、“第二”仅用于描述目的,而不能理解为指示或暗示相对重要性或者隐含指明所指示的技术特征的数量。由此,限定有“第一”、“第二”的特征可以明示或者隐含地包括一个或者更多个该特征。在本技术实施例的描述中,除非另有说明,“多个”的含义是两个或两个以上。
48.在本技术实施例中,“示例性的”或者“例如”等词用于表示作例子、例证或说明。本技术实施例中被描述为“示例性的”或者“例如”的任何实施例或设计方案不应被解释为比其它实施例或设计方案更优选或更具优势。确切而言,使用“示例性的”或者“例如”等词旨在以具体方式呈现相关概念。
49.目前,运营商(如,移动、电信等)、企业或服务商根据需求定制app时,开发人员把定制的所有app对应的apk打包成一个完整的定制包。其中,apk可以为apk文件,是android用于分发和安装应用程序的文件格式。apk文件中可以包括被编译的代码文件、文件资源(如,音频、视频、图片等文件资源)、证书、清单文件等。定制app的定制包被测试通过后,由app管理人员将测试通过的定制包上传至app服务器。然后,app服务器将定制包推送至电子设备进行安装。例如,手机的厂商生产出通用版本的手机后,再在手机中安装上运营商定制的app和一些资源就可以得到一个运营商定制版本的手机(如,移动定制手机等)。其中,运营商定制相关的app的apk和资源打包成一个独立的定制包,该定制包被称为运营商定制包。
50.示例性的,如图1所示,运营商、企业或服务商定制多个app时,定制包可以包括所有的定制app文件、参数包以及资源。例如,定制包中可以包括app1、app2等所有的定制app文件,以及定制app的所有信息(如,各app对应的安装路径信息、参数信息等等)等。其中,定制app文件可以包括定制app对应的apk等。
51.相关技术中,定制app为多个时,开发人员将多个定制app的所有信息及该app对应的apk封装成一个定制包,从而导致该定制包存在占用空间大、出包周期长以及测试周期长
等缺点。其中,出包周期是指开发人员设计定制包时耗费的时长。测试周期是指开发人员对设计好的定制包进行测试的时长。进而,电子设备从app服务器下载该定制包时,不仅花费大量的下载时间,下载的定制包还会占用电子设备的大量内存。
52.此外,相关技术中,对电子设备中的app进行安装或升级时,无法同时安装或升级多个app,仅能依次对app进行安装或升级,从而导致对多个app进行安装或升级时存在安装或升级速率慢的问题。
53.本技术实施例提供一种应用程序的处理方法,该方法可以通过电子设备从app服务器下载得到定制包;其中,定制包中包括app清单文件,电子设备根据app清单文件中的多个app标识从服务器下载得到多个app的apk后,对多个app的apk进行安装。由此,定制包中并未包含app的apk,不仅缩短了开发人员测试定制包的测试周期,还提高了电子设备从app服务器下载定制包的速率,减少了定制包在电子设备中占用的存储空间。此外,还提高了对多个app安装或更新的效率。
54.示例性的,本技术实施例提供的应用程序的处理方法可应用于应用程序安装系统,该系统包括电子设备和app服务器,其中,电子设备可以是手机、平板电脑、个人计算机(personal computer,pc)、个人数字助理(personal digital assistant,pda)、智能手表、上网本、可穿戴电子设备、增强现实技术(augmented reality,ar)设备、虚拟现实(virtual reality,vr)设备、车载设备、智能汽车、智能音响等具有显示屏的电子设备,本技术实施例对此不做任何限制。
55.示例性的,图2为本技术实施例提供的电子设备100的一种结构示意图。如图2所示,其中,电子设备可以包括:处理器110,外部存储器接口120,内部存储器121,通用串行总线(universal serial bus,usb)接口130,充电管理模块140,电源管理模块141,电池142,天线1,天线2,移动通信模块150,无线通信模块160,音频模块170,扬声器170a,受话器170b,麦克风170c,耳机接口170d,传感器模块180,按键190,马达191,指示器192,摄像头193,显示屏194,以及用户标识模块(subscriber identification module,sim)卡接口195等。
56.可以理解的是,本实施例示意的结构并不构成对电子设备的具体限定。在另一些实施例中,电子设备可以包括比图示更多或更少的部件,或者组合某些部件,或者拆分某些部件,或者不同的部件布置。图示的部件可以以硬件,软件或软件和硬件的组合实现。
57.处理器110可以包括一个或多个处理单元,例如:处理器110可以包括应用处理器(application processor,ap),调制解调处理器,图形处理器(graphics processing unit,gpu),图像信号处理器(image signal processor,isp),控制器,存储器,视频编解码器,数字信号处理器(digital signal processor,dsp),基带处理器,和/或神经网络处理器(neural-network processing unit,npu)等。其中,不同的处理单元可以是独立的器件,也可以集成在一个或多个处理器中。
58.控制器可以是电子设备的神经中枢和指挥中心。控制器可以根据指令操作码和时序信号,产生操作控制信号,完成取指令和执行指令的控制。
59.处理器110中还可以设置存储器,用于存储指令和数据。在一些实施例中,处理器110中的存储器为高速缓冲存储器。该存储器可以保存处理器110刚用过或循环使用的指令或数据。如果处理器110需要再次使用该指令或数据,可从所述存储器中直接调用。避免了
重复存取,减少了处理器110的等待时间,因而提高了系统的效率。
60.在一些实施例中,处理器110可以包括一个或多个接口。接口可以包括集成电路(inter-integrated circuit,i2c)接口,集成电路内置音频(inter-integrated circuit sound,i2s)接口,脉冲编码调制(pulse code modulation,pcm)接口,通用异步收发传输器(universal asynchronous receiver/transmitter,uart)接口,移动产业处理器接口(mobile industry processor interface,mipi),通用输入输出(general-purpose input/output,gpio)接口,用户标识模块(subscriber identity module,sim)接口,和/或通用串行总线(universal serial bus,usb)接口等。
61.可以理解的是,本实施例示意的各模块间的接口连接关系,只是示意性说明,并不构成对电子设备的结构限定。在另一些实施例中,电子设备也可以采用上述实施例中不同的接口连接方式,或多种接口连接方式的组合。
62.充电管理模块140用于从充电器接收充电输入。其中,充电器可以是无线充电器,也可以是有线充电器。在一些有线充电的实施例中,充电管理模块140可以通过usb接口130接收有线充电器的充电输入。在一些无线充电的实施例中,充电管理模块140可以通过电子设备的无线充电线圈接收无线充电输入。充电管理模块140为电池142充电的同时,还可以通过电源管理模块141为电子设备供电。
63.电源管理模块141用于连接电池142,充电管理模块140与处理器110。电源管理模块141接收电池142和/或充电管理模块140的输入,为处理器110,内部存储器121,外部存储器,显示屏194,摄像头193,和无线通信模块160等供电。电源管理模块141还可以用于监测电池容量,电池循环次数,电池健康状态(漏电,阻抗)等参数。在其他一些实施例中,电源管理模块141也可以设置于处理器110中。在另一些实施例中,电源管理模块141和充电管理模块140也可以设置于同一个器件中。
64.电子设备的无线通信功能可以通过天线1,天线2,移动通信模块150,无线通信模块160,调制解调处理器以及基带处理器等实现。
65.电子设备通过gpu,显示屏194,以及应用处理器等实现显示功能。gpu为图像处理的微处理器,连接显示屏194和应用处理器。gpu用于执行数学和几何计算,用于图形渲染。处理器110可包括一个或多个gpu,其执行程序指令以生成或改变显示信息。
66.显示屏194用于显示图像,视频等。该显示屏194包括显示面板。显示面板可以采用液晶显示屏(liquid crystal display,lcd),有机发光二极管(organic light-emitting diode,oled),有源矩阵有机发光二极体或主动矩阵有机发光二极体(active-matrix organic light emitting diode,amoled),柔性发光二极管(flex light-emitting diode,fled),miniled,microled,micro-oled,量子点发光二极管(quantum dot light emitting diodes,qled)等。
67.本技术实施例中,电子设备的显示屏194可以用于显示提示信息,以提醒用户安装定制包的过程。
68.电子设备可以通过isp,摄像头193,视频编解码器,gpu,显示屏194以及应用处理器等实现拍摄功能。
69.isp用于处理摄像头193反馈的数据。例如,拍照时,打开快门,光线通过镜头被传递到摄像头感光元件上,光信号转换为电信号,摄像头感光元件将所述电信号传递给isp处
理,转化为肉眼可见的图像。isp还可以对图像的噪点,亮度,肤色进行算法优化。isp还可以对拍摄场景的曝光,色温等参数优化。在一些实施例中,isp可以设置在摄像头193中。
70.摄像头193用于捕获静态图像或视频。物体通过镜头生成光学图像投射到感光元件。感光元件可以是电荷耦合器件(charge coupled device,ccd)或互补金属氧化物半导体(complementary metal-oxide-semiconductor,cmos)光电晶体管。感光元件把光信号转换成电信号,之后将电信号传递给isp转换成数字图像信号。isp将数字图像信号输出到dsp加工处理。dsp将数字图像信号转换成标准的rgb,yuv等格式的图像信号。在一些实施例中,电子设备可以包括1个或n个摄像头193,n为大于1的正整数。
71.数字信号处理器用于处理数字信号,除了可以处理数字图像信号,还可以处理其他数字信号。例如,当电子设备在频点选择时,数字信号处理器用于对频点能量进行傅里叶变换等。
72.视频编解码器用于对数字视频压缩或解压缩。电子设备可以支持一种或多种视频编解码器。这样,电子设备可以播放或录制多种编码格式的视频,例如:动态图像专家组(moving picture experts group,mpeg)1,mpeg2,mpeg3,mpeg4等。
73.npu为神经网络(neural-network,nn)计算处理器,通过借鉴生物神经网络结构,例如借鉴人脑神经元之间传递模式,对输入信息快速处理,还可以不断的自学习。通过npu可以实现电子设备的智能认知等应用,例如:图像识别,人脸识别,语音识别,文本理解等。
74.电子设备可以通过音频模块170,扬声器170a,受话器170b,麦克风170c,耳机接口170d,以及应用处理器等实现音频功能。例如音乐播放,录音等。
75.音频模块170用于将数字音频信息转换成模拟音频信号输出,也用于将模拟音频输入转换为数字音频信号。音频模块170还可以用于对音频信号编码和解码。在一些实施例中,音频模块170可以设置于处理器110中,或将音频模块170的部分功能模块设置于处理器110中。扬声器170a,也称“喇叭”,用于将音频电信号转换为声音信号。受话器170b,也称“听筒”,用于将音频电信号转换成声音信号。麦克风170c,也称“话筒”,“传声器”,用于将声音信号转换为电信号。
76.耳机接口170d用于连接有线耳机。耳机接口170d可以是usb接口130,也可以是3.5mm的开放移动电子设备平台(open mobile terminal platform,omtp)标准接口,美国蜂窝电信工业协会(cellular telecommunications industry association of the usa,ctia)标准接口。
77.内部存储器121可以用于存储计算机可执行程序代码,所述可执行程序代码包括指令。处理器110通过运行存储在内部存储器121的指令,从而执行电子设备的各种功能应用以及数据处理。例如,在本技术实施例中,处理器110可以通过执行存储在内部存储器121中的指令,内部存储器121可以包括存储程序区和存储数据区。
78.其中,存储程序区可存储操作系统,至少一个功能所需的应用程序(比如声音播放功能,图像播放功能等)等。存储数据区可存储电子设备使用过程中所创建的数据(比如音频数据,电话本等)等。此外,内部存储器121可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件,闪存器件,通用闪存存储器(universal flash storage,ufs)等。
79.本技术实施例中,存储数据区可用于存储电子设备从app服务器下载的定制包。其
中,电子设备从app服务器下载的定制包可以为用于电子设备首次安装的定制包,也可以为用于对电子设备中已经安装的app进行更新的定制包,在此不做限定。
80.按键190包括开机键,音量键等。按键190可以是机械按键。也可以是触摸式按键。马达191可以产生振动提示。马达191可以用于来电振动提示,也可以用于触摸振动反馈。指示器192可以是指示灯,可以用于指示充电状态,电量变化,也可以用于指示消息,未接来电,通知等。sim卡接口195用于连接sim卡。sim卡可以通过插入sim卡接口195,或从sim卡接口195拔出,实现和电子设备的接触和分离。电子设备可以支持1个或n个sim卡接口,n为大于1的正整数。sim卡接口195可以支持nano sim卡,micro sim卡,sim卡等。
81.电子设备100的软件系统可以采用分层架构,事件驱动架构,微核架构,微服务架构,或云架构。本技术实施例以分层架构的android系统为例,示例性说明电子设备100的软件结构。
82.图3是本技术实施例的电子设备100的软件结构框图。分层架构将软件分成若干个层,每一层都有清晰的角色和分工。层与层之间通过软件接口通信。在一些实施例中,将android系统分为四层,从上至下分别为应用程序层,应用程序框架层,安卓运行时(android runtime)和系统库,以及内核层。应用程序层可以包括一系列应用程序包。
83.如图3所示,应用程序包可以包括相机,图库,日历,通话,地图,导航,wlan,蓝牙,音乐,视频,短信息等应用程序。
84.应用程序框架层为应用程序层的应用程序提供应用编程接口(application programming interface,api)和编程框架。应用程序框架层包括一些预先定义的函数。
85.如图3所示,应用程序框架层可以包括窗口管理器,内容提供器,视图系统,电话管理器,资源管理器,通知管理器等。
86.窗口管理器用于管理窗口程序。窗口管理器可以获取显示屏大小,判断是否有状态栏,锁定屏幕,截取屏幕等。
87.内容提供器用来存放和获取数据,并使这些数据可以被应用程序访问。数据可以包括视频,图像,音频,拨打和接听的电话,浏览历史和书签,电话簿等。
88.视图系统包括可视控件,例如显示文字的控件,显示图片的控件等。视图系统可用于构建应用程序。显示界面可以由一个或多个视图组成的。例如,包括短信通知图标的显示界面,可以包括显示文字的视图以及显示图片的视图。
89.电话管理器用于提供电子设备100的通信功能。例如通话状态的管理(包括接通,挂断等)。
90.资源管理器为应用程序提供各种资源,比如本地化字符串,图标,图片,布局文件,视频文件等等。
91.通知管理器使应用程序可以在状态栏中显示通知信息,可以用于传达告知类型的消息,可以短暂停留后自动消失,无需用户交互。比如通知管理器被用于告知下载完成,消息提醒等。通知管理器还可以是以图表或者滚动条文本形式出现在系统顶部状态栏的通知,例如后台运行的应用程序的通知,还可以是以对话窗口形式出现在屏幕上的通知。例如在状态栏提示文本信息,发出提示音,电子设备振动,指示灯闪烁等。
92.android runtime包括核心库和虚拟机。android runtime负责安卓系统的调度和管理。
93.核心库包含两部分:一部分是java语言需要调用的功能函数,另一部分是安卓的核心库。
94.应用程序层和应用程序框架层运行在虚拟机中。虚拟机将应用程序层和应用程序框架层的java文件执行为二进制文件。虚拟机用于执行对象生命周期的管理,堆栈管理,线程管理,安全和异常的管理,以及垃圾回收等功能。
95.系统库可以包括多个功能模块。例如:表面管理器(surface manager),媒体库(media libraries),三维图形处理库(例如:opengl es),2d图形引擎(例如:sgl),升级服务模块,静默安装服务模块等。
96.表面管理器用于对显示子系统进行管理,并且为多个应用程序提供了2d和3d图层的融合。
97.媒体库支持多种常用的音频,视频格式回放和录制,以及静态图像文件等。媒体库可以支持多种音视频编码格式,例如:mpeg4,h.264,mp3,aac,amr,jpg,png等。
98.三维图形处理库用于实现三维图形绘图,图像渲染,合成和图层处理等。
99.2d图形引擎是2d绘图的绘图引擎。
100.升级服务模块用于获取到定制包后,对定制包进行解压得到app清单文件。然后,升级服务模块根据app清单文件中的至少一个app的标识从app服务器下载对应的apk。
101.静默安装服务模块用于升级服务模块从app服务器下载对应版本的apk后,根据app清单文件调用静默安装服务接口对app同时安装。
102.内核层是硬件和软件之间的层。内核层至少包含显示驱动,摄像头驱动,音频驱动,传感器驱动。
103.由此,电子设备的升级服务模块从app服务器下载得到定制包;其中,定制包中包括app清单文件,升级服务模块根据app清单文件中的多个app标识从服务器下载得到多个app的apk后,静默安装服务模块对多个app的apk进行安装。由此,不仅缩短了开发人员测试定制包的测试周期,还提高了电子设备从app服务器下载定制包的速率,减少了定制包在电子设备中占用的存储空间。此外,还提高了对多个app安装或更新的效率。
104.以下实施例中所涉及到的技术方案均可以在具有上述硬件结构和软件结构的电子设备100中实现。以下以电子设备100为手机为例,对本方案进行示例性说明。
105.在本技术实施例的一种可能的情况下,运营商、企业或者服务商定制app时,定制的app被测试通过后,开发人员将定制的app的清单文件封装在一个定制包中。app管理人员将该定制包上传至app服务器。其中,app清单文件包括至少一个app标识。每个app标识能够唯一标识一个app,比如,app标识可以为app的包名。
106.在本技术实施例的另一种可能的情况下,假设在手机中安装app或者对手机中已安装的app进行更新时,开发人员可以将app的清单文件封装在一个定制包中。
107.需要解释的是,app清单文件中可以包括一个app标识,也可以包括多个app标识,在此不做限定。
108.运营商、企业或者服务商可以定制多个app,比如可以是同一个运营商、企业或者服务商定制多个相关的app,也可以是相互合作的运营商、企业或者服务商定制多个app等等。这种情况下,一个定制包的app清单文件中可以包括多个app标识。
109.下面以定制包中的app清单文件中包括多个app标识为例,对本方案进行示例性说
明。
110.示例性的,如图4所示,app管理人员发布至app服务器的定制包可以包括app清单文件。其中,app清单文件可以包括多个app标识。如app清单文件可以包括3个app标识,分别为app标识1、app标识2以及app标识3。
111.此外,app清单文件还可以包括一些其他信息,比如app个数、每个app的安装路径或每个app的大小等等信息中的一种或多种。其中,app个数能够确定待安装或更新的app个数。安装路径是指app安装到手机的具体路径,例如,假设某一app可以被安装到手机的system/app的目录下。即system/app为该app的安装路径。app的安装路径用于手机下载app对应的apk后,将apk安装到对应的安装路径。多个app的安装路径可以相同,也可以不同,在此不做限定。app的大小是指app占用内存的大小,例如,app的大小为30m、50m或60m,等等。app的大小能够指示app占用手机的存储空间。本技术实施例中,开发人员将app清单文件封装至定制包中,app管理人员将定制包发布至app服务器。由此,不仅减小了定制包在app服务器的存储空间,还缩短了开发人员测试定制包的测试周期,此外,该定制包被推送至手机端后,同样也节省了定制包在手机的存储空间。
112.在一些实施例中,定制包具体可以为定制包镜像的形式,即app服务器中以定制包镜像的方式存储定制包。其中,镜像是一种压缩文件格式,开发人员可以将许多文件做成一个镜像文件,该镜像文件通过软件打开后,可以得到许多文件。例如,开发人员可以将app清单文件、资源以及参数包等文件做成定制包镜像。
113.下面详细介绍手机首次安装多个app的场景下。开发人员可以将app清单文件封装在一个定制包中。其中,该app清单文件可以包括多个app对应的app标识。app管理人员将定制包发布至app服务器。
114.在一种情况下,app服务器向手机推送安装信息,手机的显示界面可以显示提示信息,以使得用户根据提示信息确定是否安装定制包中对应的app。
115.示例性的,如图5所示,假设app清单文件中包括app1、app2和app3的app标识,手机的显示界面可以显示提示信息“是否安装app1、app2和app3”。若检测到用户点击“是”控件的操作,则手机开始从app服务器下载定制包,以实现对该3个app的安装。
116.在另一种情况下,用户主动搜索下载定制包的情况下,手机可以从服务器下载得到定制包。
117.在本技术实施例中,app服务器将定制包推送至手机或手机从app服务器下载定制包后,定制包被存储至存储数据区(data分区)。升级服务模块对定制包进行解压得到app清单文件。进一步地,升级服务模块对app清单文件进行解析得到待安装的多个app的app标识。升级服务模块根据多个app标识从app服务器获取多个app标识对应的apk。手机的静默安装服务模块调用静默安装服务接口对待安装的多个app对应的apk进行安装。
118.在一种可能的情况下,当升级服务模块根据多个app标识从app服务器获取多个app标识对应的apk时,升级服务模块将多个app标识发送至app服务器。app服务器接收到升级服务模块发送的多个app标识后,app服务器可以根据每个app标识,查询得到对应app的下载路径。app服务器将多个app对应的下载路径发送至升级服务模块。升级服务模块根据多个app对应的下载路径从app服务器下载得到对应app的apk。
119.在另一种可能的情况下,当升级服务模块根据多个app标识从app服务器获取多个
app标识对应的apk时,升级服务模块将多个app标识发送至app服务器。app服务器可以根据接收到的多个app标识查询得到对应的apk。app服务器将多个apk发送至升级服务模块,以使得升级服务模块获取到多个app对应的apk。
120.由此,升级服务模块可以根据多个app标识从app服务器获取到多个app对应的apk,静默安装服务模块同时对多个apk进行安装,提高了手机安装多个app的速率。
121.需要解释的是,升级服务模块获取到的多个app的apk中包括对应app的相关文件资源(如,图片、视频或音频等文件资源)。或者,apk中不包括对应app的相关文件资源,升级服务模块获取多个app对应的apk时,从服务器下载对应app的相关文件资源。或者,定制包中包含有多个app的相关文件资源,升级服务模块获取定制包时即可得到多个app的相关文件资源,等等,在此不做限定。
122.在本技术实施例中,在对手机中已经安装的多个app进行更新的场景下。当app服务器侧的定制包更新或者管理人员上传一个新的定制包的情况下。手机从app服务器下载定制包或者app服务器将定制包推送至手机后,对多个app进行更新。下面结合图6详细介绍根据定制包中的app清单文件对手机中已安装的app进行更新的过程。
123.如图6所示,该更新过程可以包括以下步骤:
124.步骤601,app管理人员将定制包存储至app服务器。
125.用于对手机中的多个app进行更新的定制包被测试通过后,app管理人员将定制包上传至app服务器进行存储。定制包的清单文件中包含有多个app标识,以对手机中的多个app进行版本更新。其中,该多个app可以是相关联的app(比如,同一运营商的app,或相互合作的运营商的app等),也可以是相互独立的多个app。
126.步骤602,升级服务模块向app服务器发送搜包请求。
127.在一些实施例中,手机的升级服务模块可以在手机开机时向app服务器发送搜包请求,也可以在手机开机后周期性地(例如,周期可以为8小时、12小时等等)向app服务器发送搜包请求,在此不做限定。
128.步骤603,app服务器检测到服务器侧有新版本的定制包,将新版本的定制包推送至存储数据区。
129.app服务器接收到搜包请求后,app服务器检测服务器侧的定制包是否有新版本。app服务器确定有新版本的定制包,app服务器将新版本的定制包发送至手机的存储数据区。
130.在一种可能的情况下,手机首次联网时,升级服务模块启动。升级服务模块启动后,向app服务器发送搜包请求。app服务器根据搜包请求确定服务器侧有新版本的定制包,app服务器将新版本的定制包发送至手机的data分区。其中,手机首次联网可以为手机开机后首次联网,还可以为手机网络断开后再次联网,等等。
131.在另一种可能的情况下,若手机一直处于联网状态,升级服务模块可以每间隔预设时长(比如,预设时长为12小时、24小时等)向app服务器发送一次搜包请求。app服务器确定服务器侧有新版本的定制包,app服务器将新版本的定制包推送至手机的data分区。其中,预设时长是手机厂商预先设置的。例如,手机厂商生产手机时,在手机的系统里设置预设时长为12小时。
132.需要解释的是,手机的系统版本升级时,手机厂商可以在新版本的系统里重新设
置预设时长。例如,若原本设置的预设时长为12小时,手机厂商可以设置预设时长仍为12小时,也可以设置预设时长为8小时、15小时以及24小时等等,在此不做限定。
133.在一些实施例中,升级服务模块向app服务器发送搜包请求,app服务器接收到升级服务模块发送的搜包请求后,app服务器检测服务器侧的定制包是否有新版本。app服务器确定服务器侧有新版本的定制包。手机会通过界面(比如,显示界面或者设置界面等)提示用户app服务器侧有新版本的定制包,以使得用户根据界面的提示信息确定是否对app进行更新。
134.在另一些实施例中,app服务器侧的定制包更新后,app服务器还可以主动将升级后的定制包推送至手机。
135.示例性的,如图7所示,手机的设置界面的系统和更新处会显示提示标识(如感叹号),以提醒用户app服务器侧有新版本的定制包。用户点击该提示标识,手机响应于用户的点击操作,手机的显示界面显示提示信息“是否下载定制包”,以使得用户确定是否下载更新后的定制包。
136.如图8所示,手机的显示界面显示提示信息“是否下载定制包”。若检测到用户点击“是”控件的操作,则手机开始从app服务器下载定制包,以实现对手机中的app进行版本更新。
137.在一些实施例中,升级服务模块确定app服务器侧有新版本的定制包时,手机的显示界面还可以显示提示信息“下次是否自动更新”,以使得升级服务模块检测到app服务器侧有新版本的定制包,无需用户授权是否更新定制包,升级服务模块可以自动更新定制包。
138.如图9所示,手机的显示界面显示提示信息“下次是否自动更新”。若检测到用户点击“是”控件的操作,则手机的升级服务模块再次检测到app服务器侧有新版本的定制包时,升级服务模块可以自动更新定制包。或者,app服务器侧有新版本的定制包后,app服务器侧将新版本的定制包自动推送至手机。若检测到用户点击“否”控件的操作,则手机的升级服务模块再次检测到app服务器侧有新版本的定制包时,手机的显示界面仍需显示图8所示的提示信息。检测到用户点击“是”控件的操作,手机才开始从app服务器下载新版本的定制包。
139.需要解释的是,手机的升级服务模块可以周期性地(如,检测周期可以为12小时、24小时、48小时等)检测app服务器测是否有新版本的定制包,也可以在手机开机时检测app服务器测是否有新版本的定制包,等等,在此不做限定。
140.步骤604,升级服务模块解压定制包并且解析app清单文件,得到多个待更新的app标识。手机的存储数据区存储有定制包后,升级服务模块对定制包进行解压得到app清单文件,并且解析app清单文件,得到多个待更新的app标识。
141.在本技术实施例中,升级服务模块获取到多个待更新的app标识后,升级服务模块将多个app标识发送至app服务器。app服务器根据每个app的标识将对应的apk发送至升级服务模块。升级服务模块接收到app服务器发送的多个待更新app对应的apk后,手机的静默安装服务模块调用静默安装服务接口将多个app对应的apk进行安装。由此,实现了同时对手机的多个app进行更新,提高了更新多个app的速率。
142.步骤605,app服务器根据多个待更新的app标识,获取到对应的apk。
143.在一种可能的情况下,app服务器接收到升级服务模块发送的多个待更新的app标
识后,app服务器可以根据每个app标识,查询得到对应app的下载路径。app服务器将每个app对应的下载路径发送至升级服务模块。升级服务模块根据每个app对应的下载路径从app服务器下载得到对应app的apk。
144.示例性的,假设app标识为包名,app服务器接收到的待更新的3个app的包名,3个app的包名分别为包名1、包名2和包名3。app服务器根据3个app的包名,查询得到对应的下载路径分别为路径1、路径2和路径3。app服务器将该3个app对应的下载路径发送至升级服务模块。升级服务模块根据接收到的每个app对应的下载路径,从app服务器下载得到对应app的apk。即升级服务模块从路径1下载得到包名1的app的apk,升级服务模块从路径2下载得到包名2的app的apk,升级服务模块从路径3下载得到包名3的app的apk。
145.由此,相较于现有的开发人员将多个待更新app的apk和app的相关资源封装至定制包中,升级服务模块从app服务器下载定制包时存在定制包占用空间大、下载时间长等问题,从而导致手机从app服务器下载定制包的速率较慢。本技术实施例中,升级服务模块根据多个app标识从服务器获取到多个app的下载路径后,升级服务模块根据各app的下载路径从app服务器下载得到对应的apk。由此,不仅提高了升级服务模块从app服务器下载定制包的速率,还减小了定制包在手机中占用的存储空间。
146.在另一种可能的情况下,app服务器接收到升级服务模块发送的多个待更新的app标识后,app服务器还可以根据每个app的标识,查询得到对应的apk。app服务器将查询得到的各app的apk发送至升级服务模块。由此,升级服务模块根据多个待更新的app标识从app服务器查询得到对应的apk,提高了升级服务模块获取待更新app的apk的速率。
147.示例性的,假设app服务器接收到的3个app标识,如3个app包名,3个app的包名分别为包名1、包名2和包名3。app服务器根据3个app包名,查询得到对应的apk。app服务器将该3个app对应的apk发送至升级服务模块。
148.需要解释的是,app服务器中存储了app标识与app的下载路径和/或apk之间的对应关系。比如,app的标识为app的包名,则app服务器可以根据app的包名查询得到对应的下载路径和/或apk。
149.步骤606,静默安装服务模块调用静默安装服务接口对多个app对应的apk进行安装。
150.在一些实施例中,手机的静默安装服务模块可以在app清单文件中包括的多个app的安装路径,对多个app进行更新。手机的静默安装服务模块完成对待更新app的安装后,手机可以在通知管理界面显示提示信息,以提醒用户手机已完成对多个app的更新。
151.示例性的,如图10所示,手机完成对多个待更新app的安装后,手机可以在通知管理界面显示提示信息“app更新完成”,以提醒用户手机已完成对多个app的更新。
152.需要解释的是,上述图5、图7至图10中的显示方式仅作为一种示例,可以在手机的显示界面的上侧、下侧、左侧、右侧等任意位置显示提示信息,在此不做限定。此外,通过在手机的显示界面中显示提示信息的提示方式仅作为示例性描述,还可以采用提示音等方式提示用户,在此不做限定。
153.需要解释的是,手机首次安装app或者对手机中已经安装的app进行更新的情况下,升级服务模块获取到定制包中的多个app的标识后,升级服务模块可以对多个app的标识进行筛选,以得到待安装或待升级的应用程序的标识。例如,定制包中包括app-1的标识,
但是用户或者手机检测到手机中已经安装有app-1的应用。这种情况下,升级服务模块可以筛选掉app-1的标识。还例如,定制包中包括app-2的标识,但是手机检测到该app-2对应的应用已经为最新版本的应用。这种情况下,升级服务模块可以筛选掉app-2的标识。
154.此外,在上述定制包的app清单文件中包括一个普通app的标识时,本技术的方案也可以应用于一个普通app的安装或升级,比如该普通app可以是或等等,在此不做限定。
155.综上所述,本技术实施例中,升级服务模块根据定制包中的app清单文件中的多个app标识同时从服务器下载得到多个app的apk后,静默安装服务模块对多个app的apk进行安装。由此,不仅提高了从app服务器下载定制包的速率,还可以同时对多个app进行安装或更新,解决了现有技术中若对多个app进行安装或更新时,每次只能安装或更新一个app,存在安装或更新速率慢的问题,提高了多个app的安装或更新速率。
156.相较于现有的定制包中包括定制app的相关资源和对应的apk,本技术的定制包中包括定制app的清单文件,并未包括定制app的apk,不仅开发人员测试定制包的测试周期,还提高了定制包的下载速率,还减小了定制包在手机中占用的存储空间。
157.此外,本技术实施例中的定制包不限于定制app,还可以定制其它资源,如定制音频(比如,开机铃声等)、视频以及图片等。这种情况下,定制包中可以包括定制资源的资源清单,其中,资源清单可以包括资源的标识、大小以及下载路径等信息。开发人员将定制资源的资源清单封装至定制包中,并未将原始的资源封装至定制包中,并将定制包上传至服务器侧。手机下载资源时,可以根据资源的标识或下载路径从服务器侧下载对应的资源信息。由此,不仅减小了定制包的在手机端的存储空间,还缩短了定制包的出包周期以及测试周期。
158.如图11所示,本技术实施例公开了一种电子设备,该电子设备可以为上述手机。该电子设备具体可以包括:触摸屏1101,所述触摸屏1101包括触摸传感器1106和显示屏1107;一个或多个处理器1102;存储器1103;一个或多个应用程序(未示出);以及一个或多个计算机程序1104,上述各器件可以通过一个或多个通信总线1105连接。其中,上述一个或多个计算机程序1104被存储在上述存储器1103中并被配置为被该一个或多个处理器1102执行,该一个或多个计算机程序1104包括指令,该指令可以用于执行上述实施例中的相关步骤。
159.可以理解的是,上述终端等为了实现上述功能,其包含了执行各个功能相应的硬件结构和/或软件模块。本领域技术人员应该很容易意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,本技术实施例能够以硬件或硬件和计算机软件的结合形式来实现。某个功能究竟以硬件还是计算机软件驱动硬件的方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明实施例的范围。
160.本技术实施例可以根据上述方法示例对上述终端等进行功能模块的划分,例如,可以对应各个功能划分各个功能模块,也可以将两个或两个以上的功能集成在一个处理模块中。上述集成的模块既可以采用硬件的形式实现,也可以采用软件功能模块的形式实现。需要说明的是,本发明实施例中对模块的划分是示意性的,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。
161.本技术实施例还提供一种电子设备,包括一个或多个处理器以及一个或多个存储
器。该一个或多个存储器与一个或多个处理器耦合,一个或多个存储器用于存储计算机程序代码,计算机程序代码包括计算机指令,当一个或多个处理器执行计算机指令时,使得电子设备执行上述相关方法步骤实现上述实施例中的应用程序的处理方法。
162.本技术的实施例还提供一种计算机可读存储介质,该计算机可读存储介质中存储有计算机指令,当该计算机指令在电子设备上运行时,使得电子设备执行上述相关方法步骤实现上述实施例中的应用程序的处理方法。
163.本技术的实施例还提供了一种计算机程序产品,当该计算机程序产品在计算机上运行时,使得计算机执行上述相关步骤,以实现上述实施例中电子设备执行的应用程序的处理方法。
164.另外,本技术的实施例还提供一种装置,这个装置具体可以是芯片,组件或模块,该装置可包括相连的处理器和存储器;其中,存储器用于存储计算机执行指令,当装置运行时,处理器可执行存储器存储的计算机执行指令,以使装置执行上述各方法实施例中电子设备执行的应用程序的处理方法。
165.其中,本实施例提供的电子设备、计算机可读存储介质、计算机程序产品或装置均用于执行上文所提供的对应的方法,因此,其所能达到的有益效果可参考上文所提供的对应的方法中的有益效果,此处不再赘述。
166.通过以上的实施方式的描述,所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将装置的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。上述描述的系统,装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
167.在本技术实施例各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
168.所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本技术实施例的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)或处理器执行本技术各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:快闪存储器、移动硬盘、只读存储器、随机存取存储器、磁碟或者光盘等各种可以存储程序代码的介质。
169.以上所述,仅为本技术的具体实施方式,但本技术的保护范围并不局限于此,任何在本技术揭露的技术范围内的变化或替换,都应涵盖在本技术的保护范围之内。因此,本技术的保护范围应以所述权利要求的保护范围为准。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1