CN110209416A - 应用软件更新方法、装置、终端及存储介质 - Google Patents

应用软件更新方法、装置、终端及存储介质 Download PDF

Info

Publication number
CN110209416A
CN110209416A CN201910471731.7A CN201910471731A CN110209416A CN 110209416 A CN110209416 A CN 110209416A CN 201910471731 A CN201910471731 A CN 201910471731A CN 110209416 A CN110209416 A CN 110209416A
Authority
CN
China
Prior art keywords
plug
application software
main program
card cage
target
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
CN201910471731.7A
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.)
POLYTRON TECHNOLOGIES Inc
Original Assignee
POLYTRON TECHNOLOGIES Inc
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 POLYTRON TECHNOLOGIES Inc filed Critical POLYTRON TECHNOLOGIES Inc
Priority to CN201910471731.7A priority Critical patent/CN110209416A/zh
Publication of CN110209416A publication Critical patent/CN110209416A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates

Landscapes

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

Abstract

本发明实施例公开了一种应用软件更新方法、装置、终端及存储介质,其中,所述移动终端上的应用软件预先接入有插件框架,该方法包括:所述应用软件的主程序基于获取到的插件管理平台发布的插件列表信息确定插件更新信息;基于所述插件更新信息,所述主程序从插件管理平台发布的至少一个插件数据包中下载待更新的插件数据包;响应于用户对所述应用软件的目标插件入口的触发操作,所述主程序基于所述插件框架安装目标插件的待更新的插件数据包,以便所述应用软件的主程序通过对目标插件的调用实现相应的软件功能。本发明实施例在应用软件接入插件框架的基础上,通过新增或升级功能插件,完成应用软件的更新,使得应用软件维护简单,升级成本降低。

Description

应用软件更新方法、装置、终端及存储介质
技术领域
本发明实施例涉及软件技术领域,尤其涉及一种应用软件更新方法、装置、终端及存储介质。
背景技术
随着移动互联网的发展,用户的需求正以前所未有的速度增长。软件产品尤其是面向企业的,需要更加灵活、更加人性化,且扩展并提供客户定制。
而现有的应用软件app,因为自身框架技术和研发模式的限制,在业务层面上,团队各个成员维护着同一个app的不同功能模块,如果app新增或修改功能,只能通过整个app升级来完成实现,由此导致维护成本大,升级成本代价大。
发明内容
本发明实施例提供了一种应用软件更新方法、装置、终端及存储介质,以解决现有技术中应用软件app新增或修改功能时,只能通过升级整个app来实现的技术问题。
第一方面,本发明实施例提供了一种应用软件更新方法,应用于移动安卓终端,所述移动终端上的应用软件预先接入有插件框架,所述方法包括:
所述应用软件的主程序基于获取到的插件管理平台发布的插件列表信息确定插件更新信息;
基于所述插件更新信息,所述主程序从插件管理平台发布的至少一个插件数据包中下载待更新的插件数据包;
响应于用户对所述应用软件的目标插件入口的触发操作,所述主程序基于所述插件框架安装目标插件的待更新的插件数据包,以便所述应用软件的主程序通过对目标插件的调用实现相应的软件功能。
可选的,所述应用软件的主程序与所述目标插件之间通过本地服务提供的AIDL接口库进行能力调用和数据通信。
可选的,在所述主程序与所述目标插件之间进行数据通信之前,所述方法还包括:
所述应用软件的主程序基于接收到的所述目标插件的安全密钥和进程标识,对所述目标插件进行校验;
将所述主程序的安全密钥发送给所述目标插件,以便所述目标插件对所述主程序进行校验。
可选的,所述方法还包括:
基于安全验证后的插件框架数据包对所述应用软件已接入的所述插件框架进行更新。
可选的,对插件框架数据包进行安全验证的操作包括:
所述应用软件的主程序基于接收到的所述插件框架的安全密钥,对所述插件框架进行校验,并将所述主程序的安全密钥发送给所述插件框架,以便所述插件框架对所述主程序进行校验;
将所述主程序的包名数据发送给所述插件框架,以便所述插件框架对所述主程序进行校验。
可选的,所述方法还包括:
响应于启动目标插件的指令,所述主程序对所述目标插件的MD5进行校验,以确保所述目标插件未被篡改以及所述目标插件文件完整。
第二方面,本发明实施例提供了一种应用软件更新装置,配置在移动终端,所述移动终端上的应用软件预先接入有插件框架,所述装置包括:
获取模块,用于实现所述应用软件的主程序基于获取到的插件管理平台发布的插件列表信息确定插件更新信息;
下载模块,用于实现基于所述插件更新信息,所述主程序从插件管理平台发布的至少一个插件数据包中下载待更新的插件数据包;
更新模块,用于响应于用户对所述应用软件的目标插件入口的触发操作,所述主程序基于所述插件框架安装目标插件的待更新的插件数据包,以便所述应用软件的主程序通过对目标插件的调用实现相应的软件功能。
可选的,所述应用软件的主程序与所述目标插件之间通过本地服务提供的AIDL接口库进行能力调用和数据通信。
可选的,所述装置还包括第一校验模块,所述第一校验模块具体用于:
在所述主程序与所述插件之间进行数据通信之前,所述应用软件的主程序基于接收到的所述目标插件的安全密钥和进程标识,对所述目标插件进行校验;将所述主程序的安全密钥发送给所述目标插件,以便所述目标插件对所述主程序进行校验。
可选的,所述装置还包括:
框架更新模块,用于基于安全验证后的插件框架数据包对所述应用软件已接入的所述插件框架进行更新。
可选的,所述装置还包括第二校验模块,所述第二校验模块具体用于:
所述应用软件的主程序基于接收到的所述插件框架的安全密钥,对所述插件框架进行校验,并将所述主程序的安全密钥发送给所述插件框架,以便所述插件框架对所述主程序进行校验;
将所述主程序的包名数据发送给所述插件框架,以便所述插件框架对所述主程序进行校验。
可选的,所述装置还包括:
第三校验模块,用于响应于启动目标插件的指令,所述主程序对所述目标插件的MD5进行校验,以确保所述目标插件未被篡改以及所述目标插件文件完整。
第三方面,本发明实施例还提供了终端,所述终端包括:
一个或多个处理器;
存储器,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如本发明任一实施例所述的应用软件更新方法。
第四方面,本发明实施例还提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本发明任一实施例所述的应用软件更新方法。
本发明实施例提供的应用软件更新方法、装置、终端及存储介质,在应用软件接入插件框架的基础上,通过获取插件更新信息,下载待更新的插件数据包,并在用户触发目标插件时,基于插件框架安装目标插件的待更新的插件数据包,由此实现了通过新增功能插件或升级功能插件,实现应用软件的更新,使得应用软件维护简单,且降低了升级成本。
附图说明
图1是本发明实施例一提供的一种应用软件更新方法的流程示意图;
图2是本发明实施例二提供的一种应用软件启动安全校验与通信方法的流程示意图;
图3是本发明实施例三提供的一种应用软件更新装置的结构示意图;
图4是本发明实施例四提供的一种终端的结构示意图。
具体实施方式
下面结合附图和实施例对本发明作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明相关的部分而非全部结构。
实施例一
图1是本发明实施例一提供的一种应用软件更新方法的流程图,本实施例可适用于应用软件动态升级的情况,该方法可以由应用软件更新装置执行,该装置可配置在终端上,例如智能手机或平板电脑。
如图1所示,本发明实施例中提供的应用软件更新方法可以包括:
S110、所述应用软件的主程序基于获取到的插件管理平台发布的插件列表信息确定插件更新信息。
其中,插件化管理平台用于管理和发布插件信息,具体的,插件化管理平台将测试通过的插件数据包以及插件列表发布到服务器,例如插件数据包发布到Nginx服务器,插件列表发布到应用服务器。如此,应用软件的主程序在启动时,向服务器发送配置接口请求,通过接口获取服务器中存储的插件列表信息数据,并与本地存储的插件列表信息进行比对,以确定插件更新信息,其中,插件更新信息包括新增的功能插件信息或对原有插件升级信息。
S120、基于所述插件更新信息,所述主程序从插件管理平台发布的至少一个插件数据包中下载待更新的插件数据包。
插件更新信息包括新增的功能插件信息或对原有插件升级信息,主程序从插件管理平台发布的至少一个插件数据包中下载待更新的插件数据包。进一步的,在待更新的插件数据包下载完成后,对下载的插件数据包进行安全校验,示例性的,对已下载插件数据包的MD5进行验证,例如将已下载插件数据包的MD5与预先获取的插件列表信息数据中存储的该插件数据包的MD5进行比对,相同,则表明下载的插件数据包是合法且完整的,由此保证下载的插件数据包与服务器存储的数据包同一性。其中,MD5(Message-DigestAlgorithm5,消息摘要)是根据公开的MD5算法对原信息进行数学变换后得到的一个128位(bit)的特征码,用于确保信息传输完整一致。在此需要说明的是,下载的插件不占用应用软件初始安装包的大小。
S130、响应于用户对所述应用软件的目标插件入口的触发操作,所述主程序基于所述插件框架安装目标插件的待更新的插件数据包,以便所述应用软件的主程序通过对目标插件的调用实现相应的软件功能。
其中,移动终端上的应用软件预先接入有插件框架,示例性的,将插件框架的核心Jar包引入应用软件,并导入插件调用库(例如util-release.aar),将自定义的应用程序类继承插件应用程序类(PluginApplication),通过路径获取函数(getPluginPath()),返回核心包的绝对路径。由此将插件框架接入应用软件。
插件框架系统包括系统层、框架层和插件层,其中,系统层为Android Framework层,包括Context(上下文)、ClassLoader(类加载器)、Resources(资源)、Application(应用程序)、Package Manger(包管理器)、Intent(跳转机制)、Application info(应用程序信息)和Android OS等。其中,只有ClassLoader(类加载器)是Hook的,由此确保了系统层稳定性。
框架层即Plugin框架层,包括插件框架(Plugin Framework)、插件框架动态更新(Dynamic Update)和RPC通信(AIDL RPC Framework)三个模块,Plugin Framework模块包括plugin context对象、plugin classloader类加载器、plugin service服务等对系统层相应对象进行hook改造,保障插件可以正常稳定运行;Dynamic Update模块是保障PluginFramework核心Jar包可以实现动态更新,以避免因Plugin Framework核心框架故障引起的不可修复性bug;AIDL RPC Framework模块可保应用软件的主程序和插件进行RPC通信。
插件层包括业务插件和基础插件,业务插件譬如流量业务、充值业务等,基础插件譬如下载功能、web容器功能。
应用软件接入上述插件框架的基础上,应用软件具有了安装渲染插件的能力。而在用户对应用软件的目标插件入口进行触发操作时,在本地检测目标插件的合法性和版本号,若合法性或版本号校验通过,则主程序基于插件框架安装已经下载后的目标插件的待更新的插件数据包,并对安装好的插件数据包进行渲染,以将插件的功能渲染出来,由此应用软件的主程序通过对目标插件的调用实现相应的软件功能。在此需要说明的是,插件渲染是原生渲染,而不是H5渲染,使得用户体验更好。由此,通过新增或升级插件,可以为应用软件新增或升级业务功能,完成应用软件的动态更新,而不需要整个软件进行升级更新。进一步的,如果S120中下载的待更新插件包中没有目标插件的更新包时,则需要从服务器下载目标插件的更新包,然后基于插件框架进行安装和渲染。
进一步的,为了避免因插件框架故障而影响应用软件的使用,在插件框架故障时,利用新下载的且经过安全验证后的插件框架数据包对应用软件已接入的原插件框架包进行更新升级。示例性的,可预先将插件框架的核心JAR包上传到服务器,在应用软件的插件框架故障时,应用软件主程序自动从服务器下载修复后的新插件框架的核心JAR包,并在安全验证后将其替换更新到应用软件,具体的接入过程如上,在此不再赘述。
具体的插件框架JAR包验证时,应用软件主程序和插件框架JAR包分别从服务器获取安全密钥,并进行互传验证。具体的,应用软件的主程序基于接收到的插件框架JAR包的安全密钥,对插件框架JAR包进行校验,并将主程序的安全密钥发送给插件框架JAR包,以便插件框架JAR包对主程序进行校验;并将主程序的包名信息发送给插件框架JAR包,以便插件框架JAR包对主程序进行合法性校验,具体的,插件框架JAR包可以通过context对象直接获取应用软件包名数据。只有验证安全的基础上,再对插件框架进行更新替换。
本发明实施例中,在应用软件接入插件框架的基础上,通过获取插件更新信息,下载待更新的插件数据包,并在用户触发目标插件时,基于插件框架安装目标插件的待更新的插件数据包,由此实现了通过新增功能插件或升级功能插件,实现应用软件的更新,使得应用软件维护简单,且降低了升级成本,同时,在插件框架故障时,可动态更新插件框架,确保应用软件正常运行,而且更新插件框架前还对新下载的插件框架JAR包进行安全验证,提升应用软件的安全性。
实施例二
图2为本发明实施例二提供的一种应用软件启动安全校验与通信方法的流程示意图。本实施例以上述实施例为基础进行优化,增加了应用软件主程序和插件之间通信以及相互安全校验的操作。
在目标插件基于插件框架安装渲染后,基于Plugin框架层的RPC通信模块,应用软件的主程序和目标插件之间可以通信。具体的,应用软件的主程序与目标插件之间通过本地服务提供的AIDL接口库进行通信能力开发,包括能力调用和数据通信。具体的,插件通过持有AIDL接口对象,而AIDL接口对象自身与应用软件建立有通信通道,通过该通道即可实现数据通信和能力调用。示例性的,数据通信可以为插件获取主应用的数据,例如获取主程序的登录session;能力调用可以为插件调用主应用能力,例如插件调用主应用的分享能力、打开相册图库能力、拍照能力等。
而为了确保目标插件和主程序之间可以进行数据通信和能力调用,需要将RPCSDK导入应用软件主程序和目标插件中,其中RPC SDK支持能力调用和数据通信。示例性的,主应用接入RPC SDK时,首先导入aidlserviceserverjar.jar,再注册rpc service组件。目标插件接入RPC SDK时,先导入aidlserviceclientjar.jar,再注册rpc service组件。
在上述基础上,在应用软件主程序和插件进行通信之前进行还需要安全校验。相应的,如图2所示,本发明实施例中提供的应用软件更新方法还包括:
S210、响应于启动目标插件的指令,所述主程序对所述目标插件的MD5进行校验,以确保所述目标插件未被篡改以及所述目标插件文件完整。
响应于启动目标插件的指令,主程序从本地存储的目标插件的文件中获取该目标插件的MD5,并与该目标插件合法的MD5进行比对,若相同,则表明本地存储的目标插件文件完整且未被非法程序篡改。其中,每次启动应用软件后,主程序通过接口从服务器获取最新的插件列表,其中插件列表中包括每个插件的MD5,因此将最新获取的插件列表中目标插件的MD5作为该目标插件合法的MD5。
进一步的,在启动目标插件后,若目标插件与主程序存在数据通信,则按照S220-S230进行安全验证。
S220、所述应用软件的主程序基于接收到的所述目标插件的安全密钥和进程标识,对所述目标插件进行校验。
为了保证用户通信安全,避免恶意插件盗取用户敏感信息,在主程序与目标插件之间进行数据通信之前,对主程序和目标插件进行双重验证。首先进行安全密钥验证,主程序和目标插件通过接口从服务器获取各自的安全密钥后,目标插件将其安全密钥发送给主程序,以便主程序验证目标插件的安全性。其次目标插件还将目标插件的进程标识(即进程ID)发送给主程序,确定主程序和目标插件跑在同一个进程上,以防止非法通信请求盗取用户敏感数据和非法能力调用。
S230、将所述主程序的安全密钥发送给所述目标插件,以便所述目标插件对所述主程序进行校验。
同时,主程序还将自身安全密钥发送给目标插件,以便目标插件对主程序进行校验,在校验一致后进行数据通信接收。
本发明实施例中,实现业务功能插件和应用软件的主应用的RPC通信,同时在插件与主应用通信交互过程进行安全校验,由此使得通信过程安全可靠。
实施例三
图3是本发明实施例三提供的一种应用软件更新装置的结构示意图。该装置配置在移动终端,移动终端上的应用软件预先接入有插件框架,如图3所示,该装置包括:
获取模块310,用于实现所述应用软件的主程序基于获取到的插件管理平台发布的插件列表信息确定插件更新信息;
下载模块320,用于实现基于所述插件更新信息,所述主程序从插件管理平台发布的至少一个插件数据包中下载待更新的插件数据包;
更新模块330,用于响应于用户对所述应用软件的目标插件入口的触发操作,所述主程序基于所述插件框架安装目标插件的待更新的插件数据包,以便所述应用软件的主程序通过对目标插件的调用实现相应的软件功能。
本发明实施例中,在应用软件接入插件框架的基础上,通过获取插件更新信息,下载待更新的插件数据包,并在用户触发目标插件时,基于插件框架安装目标插件的待更新的插件数据包,由此实现了通过新增功能插件或升级功能插件,实现应用软件的更新,使得应用软件维护简单,且降低了升级成本。
在上述实施例的基础上,所述应用软件的主程序与所述目标插件之间通过本地服务提供的AIDL接口库进行能力调用和数据通信。
在上述实施例的基础上,所述装置还包括第一校验模块,所述第一校验模块具体用于:
在所述主程序与所述插件之间进行数据通信之前,所述应用软件的主程序基于接收到的所述目标插件的安全密钥和进程标识,对所述目标插件进行校验;将所述主程序的安全密钥发送给所述目标插件,以便所述目标插件对所述主程序进行校验。
在上述实施例的基础上,所述装置还包括:
框架更新模块,用于基于安全验证后的插件框架数据包对所述应用软件已接入的所述插件框架进行更新。
在上述实施例的基础上,所述装置还包括第二校验模块,所述第二校验模块具体用于:
所述应用软件的主程序基于接收到的所述插件框架的安全密钥,对所述插件框架进行校验,并将所述主程序的安全密钥发送给所述插件框架,以便所述插件框架对所述主程序进行校验;
将所述主程序的包名数据发送给所述插件框架,以便所述插件框架对所述主程序进行校验。
在上述实施例的基础上,所述装置还包括:
第三校验模块,用于响应于启动目标插件的指令,所述主程序对所述目标插件的MD5进行校验,以确保所述目标插件未被篡改以及所述目标插件文件完整。
本发明实施例所提供的应用软件更新装置可执行本发明任意实施例所提供的存应用软件更新方法,具备执行方法相应的功能模块和有益效果。
实施例四
图4为本发明实施例四提供的终端的结构示意图。图4示出了适于用来实现本发明实施方式的示例性终端12的框图。图4显示的终端12仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图4所示,终端12以通用计算设备的形式表现。终端12的组件可以包括但不限于:一个或者多个处理器或者处理器16,存储器28,连接不同系统组件(包括存储器28和处理器16)的总线18。
总线18表示几类总线结构中的一种或多种,包括存储器总线或者存储器控制器,外围总线,图形加速端口,处理器或者使用多种总线结构中的任意总线结构的局域总线。举例来说,这些体系结构包括但不限于工业标准体系结构(ISA)总线,微通道体系结构(MAC)总线,增强型ISA总线、视频电子标准协会(VESA)局域总线以及外围组件互连(PCI)总线。
终端12典型地包括多种计算机系统可读介质。这些介质可以是任何能够被终端12访问的可用介质,包括易失性和非易失性介质,可移动的和不可移动的介质。
存储器28可以包括易失性存储器形式的计算机系统可读介质,例如随机存取存储器(RAM)30和/或高速缓存存储器32。终端12可以进一步包括其它可移动/不可移动的、易失性/非易失性计算机系统存储介质。仅作为举例,存储系统34可以用于读写不可移动的、非易失性磁介质(图4未显示,通常称为“硬盘驱动器”)。尽管图4中未示出,可以提供用于对可移动非易失性磁盘(例如“软盘”)读写的磁盘驱动器,以及对可移动非易失性光盘(例如CD-ROM,DVD-ROM或者其它光介质)读写的光盘驱动器。在这些情况下,每个驱动器可以通过一个或者多个数据介质接口与总线18相连。存储器28可以包括至少一个程序产品,该程序产品具有一组(例如至少一个)程序模块,这些程序模块被配置以执行本发明各实施例的功能。
具有一组(至少一个)程序模块42的程序/实用工具40,可以存储在例如存储器28中,这样的程序模块42包括但不限于操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。程序模块42通常执行本发明所描述的实施例中的功能和/或方法。
终端12也可以与一个或多个外部设备14(例如键盘、指向设备、显示器24等)通信,还可与一个或者多个使得用户能与该终端12交互的设备通信,和/或与使得该终端12能与一个或多个其它计算设备进行通信的任何设备(例如网卡,调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口22进行。并且,终端12还可以通过网络适配器20与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器20通过总线18与终端12的其它模块通信。应当明白,尽管图中未示出,可以结合终端12使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
处理器16通过运行存储在存储器28中的程序,从而执行各种功能应用以及数据处理,例如实现本发明实施例所提供的应用软件更新方法,移动终端上的应用软件预先接入有插件框架,所述方法包括:
所述应用软件的主程序基于获取到的插件管理平台发布的插件列表信息确定插件更新信息;
基于所述插件更新信息,所述主程序从插件管理平台发布的至少一个插件数据包中下载待更新的插件数据包;
响应于用户对所述应用软件的目标插件入口的触发操作,所述主程序基于所述插件框架安装目标插件的待更新的插件数据包,以便所述应用软件的主程序通过对目标插件的调用实现相应的软件功能。
实施例五
本发明实施例中提供一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由终端处理器执行时用于执行应用软件更新方法,移动终端上的应用软件预先接入有插件框架,所述方法包括:
所述应用软件的主程序基于获取到的插件管理平台发布的插件列表信息确定插件更新信息;
基于所述插件更新信息,所述主程序从插件管理平台发布的至少一个插件数据包中下载待更新的插件数据包;
响应于用户对所述应用软件的目标插件入口的触发操作,所述主程序基于所述插件框架安装目标插件的待更新的插件数据包,以便所述应用软件的主程序通过对目标插件的调用实现相应的软件功能。
当然,本发明实施例中所提供的一种包含计算机可执行指令的存储介质,其计算机可执行指令不限于如上所述的方法操作,还可以执行本发明任意实施例中所提供的应用软件更新方法中的相关操作。
本发明实施例的计算机存储介质,可以采用一个或多个计算机可读的介质的任意组合。计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本文件中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括——但不限于无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本发明操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。

Claims (10)

1.一种应用软件更新方法,其特征在于,应用于移动安卓终端,所述移动终端上的应用软件预先接入有插件框架,所述方法包括:
所述应用软件的主程序基于获取到的插件管理平台发布的插件列表信息确定插件更新信息;
基于所述插件更新信息,所述主程序从插件管理平台发布的至少一个插件数据包中下载待更新的插件数据包;
响应于用户对所述应用软件的目标插件入口的触发操作,所述主程序基于所述插件框架安装目标插件的待更新的插件数据包,以便所述应用软件的主程序通过对目标插件的调用实现相应的软件功能。
2.根据权利要求1所述的方法,其特征在于,所述应用软件的主程序与所述目标插件之间通过本地服务提供的AIDL接口库进行能力调用和数据通信。
3.根据权利要求2所述的方法,其特征在于,在所述主程序与所述目标插件之间进行数据通信之前,所述方法还包括:
所述应用软件的主程序基于接收到的所述目标插件的安全密钥和进程标识,对所述目标插件进行校验;
将所述主程序的安全密钥发送给所述目标插件,以便所述目标插件对所述主程序进行校验。
4.根据权利要求1所述的方法,其特征在于,所述方法还包括:
基于安全验证后的插件框架数据包对所述应用软件已接入的所述插件框架进行更新。
5.根据权利要求4所述的方法,其特征在于,对插件框架数据包进行安全验证的操作包括:
所述应用软件的主程序基于接收到的所述插件框架的安全密钥,对所述插件框架进行校验,并将所述主程序的安全密钥发送给所述插件框架,以便所述插件框架对所述主程序进行校验;
将所述主程序的包名数据发送给所述插件框架,以便所述插件框架对所述主程序进行校验。
6.根据权利要求1所述的方法,其特征在于,所述方法还包括:
响应于启动目标插件的指令,所述主程序对所述目标插件的MD5进行校验,以确保所述目标插件未被篡改以及所述目标插件文件完整。
7.一种应用软件更新装置,其特征在于,配置在移动安卓终端,所述移动终端上的应用软件预先接入有插件框架,所述装置包括:
获取模块,用于实现所述应用软件的主程序基于获取到的插件管理平台发布的插件列表信息确定插件更新信息;
下载模块,用于实现基于所述插件更新信息,所述主程序从插件管理平台发布的至少一个插件数据包中下载待更新的插件数据包;
更新模块,用于响应于用户对所述应用软件的目标插件入口的触发操作,所述主程序基于所述插件框架安装目标插件的待更新的插件数据包,以便所述应用软件的主程序通过对目标插件的调用实现相应的软件功能。
8.根据权利要求7所述的装置,其特征在于,所述应用软件的主程序与所述目标插件之间通过本地服务提供的AIDL接口库进行能力调用和数据通信。
9.一种移动安卓终端,其特征在于,包括:
一个或多个处理器;
存储器,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-6中任一所述的应用软件更新方法。
10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-6中任一所述的应用软件更新方法。
CN201910471731.7A 2019-05-31 2019-05-31 应用软件更新方法、装置、终端及存储介质 Pending CN110209416A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910471731.7A CN110209416A (zh) 2019-05-31 2019-05-31 应用软件更新方法、装置、终端及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910471731.7A CN110209416A (zh) 2019-05-31 2019-05-31 应用软件更新方法、装置、终端及存储介质

Publications (1)

Publication Number Publication Date
CN110209416A true CN110209416A (zh) 2019-09-06

Family

ID=67790072

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910471731.7A Pending CN110209416A (zh) 2019-05-31 2019-05-31 应用软件更新方法、装置、终端及存储介质

Country Status (1)

Country Link
CN (1) CN110209416A (zh)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110673890A (zh) * 2019-09-11 2020-01-10 天翼电子商务有限公司 插件调用方法、系统、介质及装置
CN110688171A (zh) * 2019-09-26 2020-01-14 深圳市奋源科技有限公司 应用程序的插件化配置方法、装置、设备以及存储介质
CN110990177A (zh) * 2019-11-05 2020-04-10 贝壳技术有限公司 故障修复方法、装置、系统、存储介质及电子设备
CN111796802A (zh) * 2020-06-30 2020-10-20 北京字节跳动网络技术有限公司 功能包生成方法、装置和电子设备
CN112148331A (zh) * 2020-09-30 2020-12-29 亮风台(上海)信息科技有限公司 宿主程序的动态更新方法及终端设备
CN114661371A (zh) * 2022-03-01 2022-06-24 深圳前海环融联易信息科技服务有限公司 一种客户端程序插件化方法
CN114756271A (zh) * 2022-04-29 2022-07-15 深圳市欧瑞博科技股份有限公司 界面更新方法、装置及电子设备
CN115914451A (zh) * 2022-10-27 2023-04-04 兴业银行股份有限公司 安卓应用版本的强制更新方法及系统

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103685138A (zh) * 2012-08-30 2014-03-26 卓望数码技术(深圳)有限公司 移动互联网上的Android平台应用软件的认证方法和系统
CN104462949A (zh) * 2014-10-27 2015-03-25 中国建设银行股份有限公司 一种插件的调用方法及装置
CN107992308A (zh) * 2017-11-22 2018-05-04 竞技世界(北京)网络技术有限公司 一种安卓终端应用程序的插件化管理方法
CN108595221A (zh) * 2018-04-26 2018-09-28 Oppo广东移动通信有限公司 PaaS平台的插件加载方法、装置、服务器及存储介质
CN108683712A (zh) * 2018-04-25 2018-10-19 咪咕文化科技有限公司 应用程序校验及校验密钥的生成方法、装置及存储介质
CN108845812A (zh) * 2018-05-31 2018-11-20 康键信息技术(深圳)有限公司 插件更新方法、装置、计算机设备和存储介质

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103685138A (zh) * 2012-08-30 2014-03-26 卓望数码技术(深圳)有限公司 移动互联网上的Android平台应用软件的认证方法和系统
CN104462949A (zh) * 2014-10-27 2015-03-25 中国建设银行股份有限公司 一种插件的调用方法及装置
CN107992308A (zh) * 2017-11-22 2018-05-04 竞技世界(北京)网络技术有限公司 一种安卓终端应用程序的插件化管理方法
CN108683712A (zh) * 2018-04-25 2018-10-19 咪咕文化科技有限公司 应用程序校验及校验密钥的生成方法、装置及存储介质
CN108595221A (zh) * 2018-04-26 2018-09-28 Oppo广东移动通信有限公司 PaaS平台的插件加载方法、装置、服务器及存储介质
CN108845812A (zh) * 2018-05-31 2018-11-20 康键信息技术(深圳)有限公司 插件更新方法、装置、计算机设备和存储介质

Cited By (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110673890A (zh) * 2019-09-11 2020-01-10 天翼电子商务有限公司 插件调用方法、系统、介质及装置
CN110673890B (zh) * 2019-09-11 2023-06-16 天翼电子商务有限公司 插件调用方法、系统、介质及装置
CN110688171A (zh) * 2019-09-26 2020-01-14 深圳市奋源科技有限公司 应用程序的插件化配置方法、装置、设备以及存储介质
CN110688171B (zh) * 2019-09-26 2023-11-10 深圳市奋源科技有限公司 应用程序的插件化配置方法、装置、设备以及存储介质
CN110990177A (zh) * 2019-11-05 2020-04-10 贝壳技术有限公司 故障修复方法、装置、系统、存储介质及电子设备
CN110990177B (zh) * 2019-11-05 2023-10-20 贝壳技术有限公司 故障修复方法、装置、系统、存储介质及电子设备
CN111796802B (zh) * 2020-06-30 2023-09-12 北京字节跳动网络技术有限公司 功能包生成方法、装置和电子设备
CN111796802A (zh) * 2020-06-30 2020-10-20 北京字节跳动网络技术有限公司 功能包生成方法、装置和电子设备
CN112148331A (zh) * 2020-09-30 2020-12-29 亮风台(上海)信息科技有限公司 宿主程序的动态更新方法及终端设备
CN114661371A (zh) * 2022-03-01 2022-06-24 深圳前海环融联易信息科技服务有限公司 一种客户端程序插件化方法
CN114756271A (zh) * 2022-04-29 2022-07-15 深圳市欧瑞博科技股份有限公司 界面更新方法、装置及电子设备
CN114756271B (zh) * 2022-04-29 2023-07-28 深圳市欧瑞博科技股份有限公司 界面更新方法、装置及电子设备
CN115914451A (zh) * 2022-10-27 2023-04-04 兴业银行股份有限公司 安卓应用版本的强制更新方法及系统

Similar Documents

Publication Publication Date Title
CN110209416A (zh) 应用软件更新方法、装置、终端及存储介质
US10338933B2 (en) Method for generating custom BIOS setup interface and system therefor
US20220214932A1 (en) Methods, devices and computer storage media for inter-mini program platform communication
US8880651B2 (en) Method and system for efficient download of data package
CN104685471B (zh) 软件平台到设备生态系统的自动配设
CN110009362A (zh) 区块链智能合约修改方法、装置和计算机可读存储介质
US20220245005A1 (en) Methods, devices and computer storage media for inter-mini program platform discovery
KR101707549B1 (ko) 클라우드 서버를 이용한 디지털 사이니지 시스템 및 그 제어 방법
US20180343242A1 (en) Protecting a web server against an unauthorized client application
US11496304B2 (en) Information processing device, information processing method, and storage medium
CN107835181A (zh) 服务器集群的权限管理方法、装置、介质和电子设备
CN114640533B (zh) 传输消息的方法、装置、存储介质及电子设备
CN110457049A (zh) 实现插件自动化的方法、装置、电子设备及存储介质
US10719456B2 (en) Method and apparatus for accessing private data in physical memory of electronic device
JP7445017B2 (ja) ユーザ識別子および署名収集を利用したモバイルアプリケーション偽造・変造探知方法、コンピュータプログラム、コンピュータ読み取り可能な記録媒体およびコンピュータ装置
CN111274551B (zh) 基于编译器的java代码保护方法、装置及电子设备
KR20150047001A (ko) 애플리케이션 프로그램 보호 방법 및 장치
CN114637525A (zh) Sdk与接入应用的兼容方法、装置、设备及介质
CN111831566A (zh) 测试方法、装置、电子设备和计算机可读存储介质
WO2014098387A1 (ko) 악성 애플리케이션 진단장치 및 방법
CN111310175A (zh) 基于插件化的iOS应用安全监测与防护方法及装置
CN111367590A (zh) 中断事件处理方法及其装置
CN113641966B (zh) 一种应用集成方法、系统、设备及介质
US10635571B2 (en) Apparatus with test execution environment
KR102348312B1 (ko) 사용자 식별자 및 서명 수집을 이용한 모바일 애플리케이션 위변조 탐지 방법 및 시스템

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
WD01 Invention patent application deemed withdrawn after publication

Application publication date: 20190906