一种软件更新方法及装置与流程

文档序号:16665846发布日期:2019-01-18 23:16阅读:232来源:国知局
一种软件更新方法及装置与流程

本发明涉及计算机技术领域,尤其涉及一种软件更新方法及装置。



背景技术:

实际中,对于大部分的软件,更新非常快,用户在使用某个软件时,经常会有更新的需求,在更新的时候,可以下载一个新的完整的安装包,但是,完整的安装包的大小比较大,也会占用更大的内存,因此,目前,很多应用软件都支持差异(difference,diff)更新,即对比新旧软件的安装包,找出差异的部分,生成一个diff包,更新过程中不需要下载完整的安装包,可以直接下载diff包,比完整的安装包小很多。

现有技术中,针对新旧软件的安装包,在编译过程中,均采用随机的混淆规则,然后,将编译完成的新旧软件的安装包进行比对,找出差异部分,并将差异部分生成diff包。

但是,在实现本发明的过程中,发明人发现现有技术中在软件更新过程中生成diff包时,例如,针对同一个应用程序(application,app)的两个不同版本,即使代码变更很少,由于在编译过程中,混淆规则都是随机的,最终编译出来的文件,本身差异还是会很大,导致生成的diff包的大小也比较大,进而使得用户下载diff包时,会消耗更多的流量,占用更多的使用带宽。



技术实现要素:

本发明实施例提供一种软件更新方法及装置,以进一步减少软件更新过程中diff包的大小。

本发明实施例提供的具体技术方案如下:

一种软件更新方法,包括:

触发编译流程时,获取软件的新版本的源代码和旧版本的映射文件;其中,所述映射文件表示旧版本的混淆编译规则;

根据所述旧版本的映射文件,对所述新版本的源代码进行编译;

将编译后的新版本和旧版本进行比对,并基于编译后的新版本和旧版本的差异部分生成软件更新的diff包。

根据所述旧版本的映射文件,对所述新版本的源代码进行编译,具体包括:

确定新版本的源代码中的待混淆的名称;

根据所述旧版本的映射文件,对所述待混淆的名称进行混淆,得到所述待混淆的名称对应的混淆后的名称;

根据所述待混淆的名称对应的混淆后的名称,对所述新版本的源代码进行编译。

根据所述旧版本的映射文件,对所述待混淆的名称进行混淆,得到所述待混淆的名称对应的混淆后的名称,具体包括:

判断是否在所述映射文件中记录有所述待混淆的名称对应的混淆后的名称,若是,则直接将所述映射文件中记录的混淆后的名称作为所述待混淆的名称对应的混淆后的名称,否则,则随机生成所述待混淆的名称对应的混淆后的名称。

基于编译后的新版本和旧版本的差异部分生成diff包之后,进一步包括:

通知用户终端有所述软件的diff包。

进一步包括:当接收到用户终端返回的软件更新请求时,将生成的diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

基于编译后的新版本和旧版本的差异部分生成diff包之后,进一步包括:

直接将所述diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

所述待混淆的名称至少为以下一种或任意组合:类名、方法名、变量名、资源名。

一种软件更新装置,包括:

获取模块,用于触发编译流程时,获取软件的新版本的源代码和旧版本的映射文件;其中,所述映射文件表示旧版本的混淆编译规则;

编译模块,用于根据所述旧版本的映射文件,对所述新版本的源代码进行编译;

比对模块,用于将编译后的新版本和旧版本进行比对,并基于编译后的新版本和旧版本的差异部分生成软件更新的diff包。

根据所述旧版本的映射文件,对所述新版本的源代码进行编译时,还包括:

混淆模块,用于确定新版本的源代码中的待混淆的名称,并根据所述旧版本的映射文件,对所述待混淆的名称进行混淆,得到所述待混淆的名称对应的混淆后的名称;

编译模块,具体用于根据所述待混淆的名称对应的混淆后的名称,对所述新版本的源代码进行编译。

根据所述旧版本的映射文件,对所述待混淆的名称进行混淆,得到所述待混淆的名称对应的混淆后的名称时,混淆模块具体用于:

判断是否在所述映射文件中记录有所述待混淆的名称对应的混淆后的名称,若是,则直接将所述映射文件中记录的混淆后的名称作为所述待混淆的名称对应的混淆后的名称,否则,则随机生成所述源代码中的待混淆的名称对应的混淆后的名称。

基于编译后的新版本和旧版本的差异部分生成diff包之后,进一步包括:

通知模块,用于通知用户终端有所述软件的diff包。

进一步包括:第一发送模块,用于当接收到用户终端返回的软件更新请求时,将生成的diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

基于编译后的新版本和旧版本的差异部分生成diff包之后,进一步包括:

第二发送模块,用于直接将所述diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

所述待混淆的名称至少为以下一种或任意组合:类名、方法名、变量名、资源名。

一种服务器,包括:

至少一个存储器,用于存储程序指令;

至少一个处理器,用于调用所述存储器中存储的程序指令,按照获得的程序指令执行上述任一种软件更新方法。

本发明实施例中,触发编译流程时,获取软件的新版本的源代码和旧版本的映射文件;其中,所述映射文件表示旧版本的混淆编译规则;根据所述旧版本的映射文件,对所述新版本的源代码进行编译;将编译后的新版本和旧版本进行比对,并基于编译后的新版本和旧版本的差异部分生成软件更新的diff包,这样,针对软件进行更新时,对新版本进行编译,基于旧版本的映射文件进行混淆,因此,编译之后的两个版本受混淆的影响达到最小,进而使得其差异化达到最小,生成的diff包的大小也会大大减小,最大限度地减少了混淆对diff包大小的影响。

附图说明

图1为本发明实施例一提供的软件更新方法的流程图;

图2为本发明实施例二提供的新版本编译方法的执行过程流程图;

图3为本发明实施例三提供的服务器架构环境示意图;

图4为本发明实施例四提供的软件更新装置结构示意图;

图5为本发明实施例五提供的服务器结构示意图。

具体实施方式

下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,并不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。

为便于对本发明实施例的理解,下面先对几个概念进行简单介绍:

映射(mapping)文件:由于java代码很容易被反编译,所以经常在编译过程中,将java的类名、变量名和方法名等替换成a、b和c等无意义的名字,然后将替换规则,记录到一个文件中,这个文件就叫做mapping文件,是一个文本文件,以下将映射文件统称为mapping文件。

差异(diff)包:对比新旧软件的安装包,找出差异的部分,生成diff包,更新的时候只需要下载diff包即可,比完整的安装包要小很多。

基础(base)版本:在生成diff包时,需要有一个对比版本,将新版本和对应的base版本进行对比,将差异部分生成diff包。

编译:是采用编译程序从源语言编写的源程序,产生目标程序的过程或动作,就是把高级语言(即源代码)变成计算机可以识别的二进制语言。

实施例一:

如图1所示,本发明实施例一提供的软件更新方法,具体包括以下步骤:

步骤100:触发编译流程时,获取软件的新版本的源代码和旧版本的mapping文件;其中,所述mapping文件表示旧版本的混淆编译规则。

实际中,目前大部分app的软件开发,都是基于java语言,但因为java代码很容易被反编译,所以在编译过程中,进行代码混淆,例如将java的类名、变量名、方法名等替换成a、b、c等无意义的名字,然后将替换规则(也可以称为混淆编译规则),记录到app的mapping文件中,这个过程也称为混淆编译。

本发明实施例中,在编译过程中,对新版本的源代码,不再仅仅采用随机混淆规则进行混淆,而是需要参考base版本的mapping文件,其中,本发明实施例中的base版本,即是指软件的旧版本。

其中,上述旧版本,例如为当前的本地版本,上述新版本,例如为该软件的最新版本,这样,当针对该软件开发出最新版本,需要对该软件进行更新时,可以获取该软件的当前的本地版本的mapping文件。

例如,用户终端安装有qq软件,由于新功能的开发、或软件修复等原因,经常会有软件更新的需求,当有新版本,需要对终端当前的版本进行更新时,服务器端触发编译流程,不仅获取软件的新版本的源代码,还需获取旧版本的mapping文件。

步骤110:根据所述旧版本的mapping文件,对所述新版本的源代码进行编译。

执行步骤110时,具体包括:

首先,获取新版本的源代码中的待混淆的名称。

其中,上述源代码中的待混淆的名称,至少为以下一种或任意组合:类名、方法名、变量名、资源名,当然,本发明实施例中,源代码中的待混淆的名称并不仅限于上述几种,可以是在编译过程中能够混淆的任意待混淆的名称。

然后,根据所述旧版本的mapping文件,对所述待混淆的名称进行混淆,得到所述待混淆的名称对应的混淆后的名称。

具体为:判断是否在所述mapping文件中记录有所述待混淆的名称对应的混淆后的名称,若是,则直接将所述mapping文件中记录的混淆后的名称作为所述待混淆的名称对应的混淆后的名称,否则,则随机生成所述待混淆的名称对应的混淆后的名称。

例如,对于某个软件的源代码中的待混淆的名称,变量名为view和creator,该软件的旧版本的mapping文件中记录有view对应的混淆后的名称为a,这样,触发编译流程时,在旧版本的mapping文件中进行查找,查找到该条记录,则将a作为新版本的源代码中view混淆后的名称,并且由于没有查找到creator对应的混淆后的名称,则随机生成creator混淆后的名称,例如为b,则确定creator混淆后的名称为b。

也就是说,本发明实施例中,需要参考旧版本的mapping文件,根据旧版本的混淆编译规则,确定新版本的混淆编译规则,不再仅仅是采用随机混淆规则,这样,编译后的新版本与旧版本之间的差异,受混淆编译的影响减小,使得其差异达到最小。

最后,根据所述待混淆的名称对应的混淆后的名称,对所述新版本的源代码进行编译。

这样,执行步骤110之后,就完成了对软件的新版本的源代码的编译。

进一步地,为避免混淆编译之后的代码执行错误,因此,对于不需要或不能混淆的名称,在对源代码编译时,可以预先对其进行声明,也就是说,本发明实施例中,确定混淆后的名称,也都是针对源代码中能够混淆的待混淆的名称。

步骤120:将编译后的新版本和旧版本进行比对,并基于编译后的新版本和旧版本的差异部分生成软件更新的diff包。

执行步骤120时,具体包括:

首先,将编译后的新版本和旧版本进行比对,获得编译后的新版本和旧版本的差异部分。

然后,基于编译后的新版本和旧版本的差异部分生成diff包。

值得说明的是,生成diff包时,进行比对的是编译后的版本,本发明实施例中,由于对新版本的编译过程中,是基于旧版本,即旧版本的mapping文件进行混淆的,因此,编译之后的两个版本的差异化就会达到最小,进而使得生成的diff包的大小也会大大减小,最大限度地减少了混淆对diff包大小的影响。

进一步地,本发明实施例中,执行步骤120之后,软件更新方法还可以包括以下几种实施方式:

第一种方式:通知用户终端有所述软件的diff包。

也就是说,通知用户终端该软件有diff包存在,提示给用户终端,进而用户终端决定是否进行软件更新。

例如,服务器在生成diff包后,立即向用户终端推送通知消息,提示用户终端是否更新该软件。

又例如,服务器确定用户终端打开该软件时推送通知消息,提示用户终端是否更新该软件。

又例如,服务器确定用户终端打开应用商店时推送通知消息,提示用户终端是否更新该软件。

这样,用户可以得知软件有更新,进而可以根据需求选择是否进行软件更新,更加灵活。

第二种方式:通知用户终端有所述软件的diff包,并当接收到用户终端返回的软件更新请求时,将生成的diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

例如,用户终端接收到通知消息后,若确定需要更新,用户可以点击相应的更新按钮或下载按钮,服务器就将diff包推送至用户终端,用户终端执行下载安装,完成软件更新。

这样,接收到通知消息后,当用户有软件更新需求时,就可以根据该通知消息完成软件更新。

第三种方式:直接将所述diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

例如,生成diff包后,服务器不通知用户终端,不需要用户终端的其它操作,直接将diff包推送至用户终端,用户点击安装或自动安装,即可以实现软件的自动更新,可以减少用户的操作。

第四种方式:通知用户终端有所述软件的diff包,并直接将所述diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

例如,生成diff包后,服务器通知给用户终端,并同时将diff包发送给用户终端,完成软件的自动更新,这样,既可以实现自动更新,还可以使用户获知更新情况。

这样,基于本发明实施例中的方法,生成diff包后,用户终端下载安装该diff包,完成软件更新,由于diff包的大小得到进一步的减小,因此,下载该diff包时也节省了流量,减少了使用带宽,也减少了占用内存。

实施例二:

下面采用一个具体的应用场景对上述实施例作出进一步详细说明。具体参阅图2所示,本发明实施例二中,软件更新方法中新版本编译方法的执行过程具体如下:

步骤200:新建编译任务。

例如,针对某个软件,进行了改进,生成了新版本时,服务器端开始新建编译任务,也即触发编译流程。

步骤201:获取base版本的mapping文件和新版本的源代码。

其中,上述base版本为该软件的旧版本。

步骤202:任务执行。

步骤203:编译模块编译时,将源代码中的待混淆的名称发送给混淆模块。

其中,源代码中的待混淆的名称,例如为类名、方法名、变量名等,编译模块将这些待混淆的名称发送给混淆模块。

步骤204:混淆模块接收到编译模块发送的待混淆的名称后,根据base版本的mapping文件,返回待混淆的名称对应的混淆后的名称。

具体为:读取base版本的mapping文件,并在该mapping文件中查找是否记录有源代码中的待混淆的名称对应的混淆后的名称,若查找到,则返回查找到的该待混淆的名称对应的混淆后的名称,若没有查找到,则返回随机生成的混淆后的名称。

步骤205:编译模块接收到返回的混淆后的名称,完成对新版本的源代码的编译。

其中,混淆模块和编译模块,可以分别基于混淆器和编译器来实现,可以基于混淆编译器来实现,本发明实施例中并不进行限定。

本发明实施例中,在编译过程中,需要混淆时,基于base版本的mapping文件,对新版本的源代码进行定制化混淆,不再仅仅采用随机混淆规则,减小新版本和base版本均采用随机混淆规则时,可能由于对于同一个待混淆的名称生成的混淆后的名称不同造成的差异,能够最大程度地降低混淆对新版本和base版本的差异化的影响,进一步减小了diff包的大小。

实施例三:

基于上述实施例,参阅图3所示,本发明实施例三中,服务器架构环境示意图。本发明实施例中,软件更新方法的执行主体为服务器。

服务器与用户终端连接,开发商开发出软件,将软件的源代码编译后,将软件推广到用户终端。

其中,用户终端可以为手机、电脑、ipad等任何智能设备,本发明实施例三中仅以3个手机为例进行说明。

例如,用户终端下载了某个软件,例如微信,当针对微信开发了新版本时,服务器获取到微信的新版本的源代码和旧版本的mapping文件,并根据旧版本的mapping文件,对新版本的源代码进行编译,然后,将编译后的新版本和旧版本进行比对,生成diff包,最后,将diff包发送给该用户终端,进而该用户终端就可以完成对微信的更新。

实施例四:

基于上述实施例,参阅图4所示,本发明实施例四中,软件更新装置,具体包括:

获取模块40,用于触发编译流程时,获取软件的新版本的源代码和旧版本的mapping文件;其中,所述mapping文件表示旧版本的混淆编译规则;

编译模块41,用于根据所述旧版本的mapping文件,对所述新版本的源代码进行编译;

比对模块42,用于将编译后的新版本和旧版本进行比对,并基于编译后的新版本和旧版本的差异部分生成软件更新的diff包。

根据所述旧版本的mapping文件,对所述新版本的源代码进行编译时,还包括:

混淆模块43,用于确定新版本的源代码中的待混淆的名称,并根据所述旧版本的mapping文件,对所述待混淆的名称进行混淆,得到所述待混淆的名称对应的混淆后的名称;

编译模块41,具体用于根据所述待混淆的名称对应的混淆后的名称,对所述新版本的源代码进行编译。

根据所述旧版本的mapping文件,对所述待混淆的名称进行混淆,得到所述待混淆的名称对应的混淆后的名称时,混淆模块43具体用于:

判断是否在所述mapping文件中记录有所述待混淆的名称对应的混淆后的名称,若是,则直接将所述mapping文件中记录的混淆后的名称作为所述待混淆的名称对应的混淆后的名称,否则,则随机生成所述源代码中的待混淆的名称对应的混淆后的名称。

基于编译后的新版本和旧版本的差异部分生成diff包之后,进一步包括:

通知模块44,用于通知用户终端有所述软件的diff包。

进一步包括:第一发送模块45,用于当接收到用户终端返回的软件更新请求时,将生成的diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

基于编译后的新版本和旧版本的差异部分生成diff包之后,进一步包括:

第二发送模块46,用于直接将所述diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

所述待混淆的名称至少为以下一种或任意组合:类名、方法名、变量名、资源名。

本发明实施例中,在对新版本的源代码进行编译时,根据旧版本的mapping文件进行混淆,这样,保证新版本和旧版本的源代码中的待混淆的名称,对应的混淆后的名称基本是相同的,使得新版本和旧版本的差异达到最小,进而减小了diff包的大小。

实施例五:

基于上述实施例,参阅图5所示,本发明实施例五中,一种服务器的结构示意图。

本发明实施例五提供了一种服务器,该服务器可以包括处理器510(centerprocessingunit,cpu)、存储器520、输入设备530和输出设备540等,输入设备530可以包括键盘、鼠标、触摸屏等,输出设备540可以包括显示设备,如液晶显示器(liquidcrystaldisplay,lcd)、阴极射线管(cathoderaytube,crt)等。

存储器520可以包括只读存储器(rom)和随机存取存储器(ram),并向处理器510提供存储器520中存储的程序指令和数据。在本发明实施例中,存储器520可以用于存储软件更新方法的程序。

处理器510通过调用存储器520存储的程序指令,处理器510用于按照获得的程序指令执行:

触发编译流程时,获取软件的新版本的源代码和旧版本的mapping文件;其中,所述mapping文件表示旧版本的混淆编译规则;

根据所述旧版本的mapping文件,对所述新版本的源代码进行编译;

将编译后的新版本和旧版本进行比对,并基于编译后的新版本和旧版本的差异部分生成软件更新的diff包。

根据所述旧版本的mapping文件,对所述新版本的源代码进行编译,处理器510具体用于:

确定新版本的源代码中的待混淆的名称;

根据所述旧版本的mapping文件,对所述待混淆的名称进行混淆,得到所述待混淆的名称对应的混淆后的名称;

根据所述待混淆的名称对应的混淆后的名称,对所述新版本的源代码进行编译。

根据所述旧版本的mapping文件,对所述待混淆的名称进行混淆,得到所述待混淆的名称对应的混淆后的名称,处理器510具体用于:

判断是否在所述映射mapping文件中记录有所述待混淆的名称对应的混淆后的名称,若是,则直接将所述mapping文件中记录的混淆后的名称作为所述待混淆的名称对应的混淆后的名称,否则,则随机生成所述待混淆的名称对应的混淆后的名称。

基于编译后的新版本和旧版本的差异部分生成diff包之后,处理器510进一步用于:

通知用户终端是否有所述软件的diff包。

处理器510进一步用于:

当接收到用户终端返回的软件更新请求时,将生成的diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

处理器510进一步用于:

直接将所述diff包推送至用户终端,以使所述用户终端根据所述diff包完成软件更新操作。

本发明实施例中,编译新版本时,根据旧版本的mapping文件,进行混淆,使得新版本和旧版本的差异达到最小,进而能够最大程度地减小了混淆对diff包大小的影响。

本领域内的技术人员应明白,本发明的实施例可提供为方法、系统、或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、cd-rom、光学存储器等)上实施的计算机程序产品的形式。

本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。

这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。

这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。

尽管已描述了本发明的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例作出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明范围的所有变更和修改。

显然,本领域的技术人员可以对本发明实施例进行各种改动和变型而不脱离本发明实施例的精神和范围。这样,倘若本发明实施例的这些修改和变型属于本发明权利要求及其等同技术的范围之内,则本发明也意图包含这些改动和变型在内。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1