CN115421785B - 应用程序的移植处理方法、装置和介质 - Google Patents
应用程序的移植处理方法、装置和介质 Download PDFInfo
- Publication number
- CN115421785B CN115421785B CN202211011147.1A CN202211011147A CN115421785B CN 115421785 B CN115421785 B CN 115421785B CN 202211011147 A CN202211011147 A CN 202211011147A CN 115421785 B CN115421785 B CN 115421785B
- Authority
- CN
- China
- Prior art keywords
- application program
- application
- information
- automatic processing
- processing
- 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
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/70—Software maintenance or management
- G06F8/76—Adapting program code to run in a different environment; Porting
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
本申请实施例提供了一种应用程序的移植处理方法、装置和介质,其中的方法具体包括:从第一服务端的内存数据库的列表中获取第一应用程序的应用信息;根据下载地址,从第二服务端下载第一应用程序的安装包;根据第一应用程序的安装包,进行第一应用程序的自动处理;从兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据组件信息,进行自动处理过程中界面的跳转;根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库。本申请实施例可以节省第一应用程序的筛选所耗费的人力成本,且可以提高第一应用程序的筛选效率。
Description
技术领域
本申请实施例涉及计算机技术领域,特别是涉及一种应用程序的移植处理方法、装置和介质。
背景技术
操作***向应用程序提供服务的接口被称作API(应用编程接口,ApplicationProgram Interface)。不同的操作***提供了不同的API,这一特性使得一个应用程序很难不加修改地运行于多个操作***之上。目前,可以利用例如Wine(Wine不是模拟器,Wine IsNot an Emulator)的兼容层软件,将第一操作***的应用程序移植到第二操作***上。由于Wine能够将Windows(视窗)API的调用翻译成为动态的POSIX(可移植操作***接口,Portable Operating System Interface)调用,因此能够使Windows应用程序在Windows之外的操作***中运行。
在利用Wine安装、启动过程和使用Windows应用程序的过程中,经常出现各式各样的错误。为了提高Windows应用程序的可用性和稳定性,相关技术会采用人工筛选方式,从大量的Windows应用程序中筛选出存在错误的目标Windows应用程序。
在实际应用中,人工筛选通常包括:人工调度、人工安装和人工汇总等;其中,人工调度将Windows应用程序分配至对应的计算节点;人工安装在计算节点上安装对应的Windows应用程序;人工汇总对多个计算节点的处理结果进行汇总。由于人工调度、人工安装和人工汇总均需要耗费大量的人力成本,因此,人工筛选方式不仅耗费大量的人力成本,而且存在筛选效率低的问题。
发明内容
本申请实施例提供了一种应用程序的移植处理方法,可以节省第一应用程序的筛选所耗费的人力成本,且可以提高第一应用程序的筛选效率。
相应的,本申请实施例还提供了一种应用程序的移植处理装置、一种电子设备和一种机器可读介质,用以保证上述方法的实现及应用。
为了解决上述问题,本申请实施例公开了一种应用程序的移植处理方法,所述方法应用于运行在第一操作***上的客户端,所述第一操作***中运行有兼容层软件,在兼容层软件中设置预设代码;所述预设代码用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取所述预设交互组件的组件信息;所述方法包括:
从第一服务端的内存数据库的列表中获取第一应用程序的应用信息;所述应用信息包括:应用标识和下载地址;
根据所述下载地址,从第二服务端下载第一应用程序的安装包;
根据第一应用程序的安装包,进行第一应用程序的自动处理;所述自动处理包括:安装;其中,从所述兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据所述组件信息,进行自动处理过程中界面的跳转;
根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则所述自动处理还包括:启动;
将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;所述自动处理结果包括:第一应用程序在自动处理结束情况下的目标处理状态信息。
为了解决上述问题,本申请实施例公开了一种应用程序的移植处理方法,所述方法应用于第一服务端,所述方法包括:
将第一应用程序的应用信息写入内存数据库的列表;所述应用信息包括:应用标识和下载地址;其中,客户端从所述列表中获取所述应用信息,根据所述下载地址,从第二服务端下载第一应用程序的安装包,根据第一应用程序的安装包,进行第一应用程序的自动处理;所述自动处理包括:安装;其中,从所述兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据所述组件信息,进行自动处理过程中界面的跳转;根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则所述自动处理还包括:启动;将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;所述自动处理结果包括:第一应用程序在自动处理结束情况下的目标处理状态信息;
从内存数据库中读取第一应用程序的应用标识、以及自动处理结果;
根据所述目标处理状态信息,对第一应用程序进行筛选。
为了解决上述问题,本申请实施例公开了一种应用程序的移植处理装置,所述装置应用于运行在第一操作***上的客户端,所述第一操作***中运行有兼容层软件,在兼容层软件中设置预设代码;所述预设代码用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取所述预设交互组件的组件信息;所述装置包括:
应用信息获取模块,用于从第一服务端的内存数据库的列表中获取第一应用程序的应用信息;所述应用信息包括:应用标识和下载地址;
下载模块,用于根据所述下载地址,从第二服务端下载第一应用程序的安装包;
自动处理模块,用于根据第一应用程序的安装包,进行第一应用程序的自动处理;所述自动处理包括:安装;其中,从所述兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据所述组件信息,进行自动处理过程中界面的跳转;
状态更新模块,用于根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则所述自动处理还包括:启动;
结果处理模块,用于将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;所述自动处理结果包括:第一应用程序在自动处理结束情况下的目标处理状态信息。
可选地,所述组件信息包括:标识信息和位置信息;所述进行自动处理过程中界面的跳转,包括:
根据所述标识信息,从所述界面中确定出目标预设交互组件;
根据所述目标预设交互组件的位置信息,触发所述目标预设交互组件对应的操作,以进行自动处理过程中界面的跳转。
可选地,所述自动处理结果还包括:第一应用程序在自动处理过程中的错误信息;所述错误信息用于建立并保存错误信息与解决方案之间的映射关系;
所述解决方案包括如下方案种类中的至少一种:
在兼容层软件中设置所述错误信息对应的动态链接库;
在兼容层软件中设置所述错误信息对应的代码;
在兼容层软件中设置所述错误信息对应的处理逻辑;以及
在兼容层软件中设置所述错误信息对应的第三方应用程序的资源;第三方应用程序与错误信息对应应用程序存在依赖关系。
可选地,所述第二服务端根据第二操作***的应用程序的下载地址,进行第二操作***的应用程序的批量下载,对批量下载的第一应用程序进行存储,根据存储的第一应用程序,提供第一应用程序的下载服务,以使客户端根据所述下载服务进行第一应用程序的下载。
可选地,所述装置还包括:
设置模块,用于在兼容层软件的容器中设置预设字符种类、预设开发语言对应软件的运行和3D图像对应的动态链接库。
为了解决上述问题,本申请实施例公开了一种应用程序的移植处理装置,所述装置应用于第一服务端,所述装置包括:
应用信息处理模块,用于将第一应用程序的应用信息写入内存数据库的列表;所述应用信息包括:应用标识和下载地址;其中,客户端从所述列表中获取所述应用信息,根据所述下载地址,从第二服务端下载第一应用程序的安装包,根据第一应用程序的安装包,进行第一应用程序的自动处理;所述自动处理包括:安装;其中,从所述兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据所述组件信息,进行自动处理过程中界面的跳转;根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则所述自动处理还包括:启动;将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;所述自动处理结果包括:第一应用程序在自动处理结束情况下的目标处理状态信息;
结果处理模块,用于从内存数据库中读取第一应用程序的应用标识、以及自动处理结果;
筛选模块,用于根据所述目标处理状态信息,对第一应用程序进行筛选。
可选地,所述自动处理结果还包括:第一应用程序在自动处理过程中的错误信息;所述错误信息用于建立并保存错误信息与解决方案之间的映射关系;
所述解决方案包括如下方案种类中的至少一种:
在兼容层软件中设置所述错误信息对应的动态链接库;
在兼容层软件中设置所述错误信息对应的代码;
在兼容层软件中设置所述错误信息对应的处理逻辑;以及
在兼容层软件中设置所述错误信息对应的第三方应用程序的资源;第三方应用程序与错误信息对应应用程序存在依赖关系;
所述装置还包括:
方案执行模块,用于执行所述映射关系中的解决方案,以对兼容层软件进行更新。
可选地,所述筛选模块,包括:
选择模块,用于在所述目标处理状态信息的数量与写入列表的第一应用程序的预设数量相匹配的情况下,从预设数量的第一应用程序中选择目标处理状态信息为预设处理状态信息的目标第一应用程序。
本申请实施例还公开了一种电子设备,包括:处理器;和存储器,其上存储有可执行代码,当所述可执行代码被执行时,使得所述处理器执行如本申请实施例所述的方法。
本申请实施例还公开了一种机器可读介质,其上存储有可执行代码,当所述可执行代码被执行时,使得处理器执行如本申请实施例所述的方法。
本申请实施例包括以下优点:
本申请实施例的技术方案中,客户端从第一服务端的内存数据库的列表中获取第一应用程序的应用信息,并根据应用信息中的下载地址,自动从第二服务端下载第一应用程序的安装包。由于本申请实施例的客户端能够自动获取应用信息和自动下载第一应用程序的安装包,故能够节省基于人工调度将第一应用程序分配至计算节点的操作成本,因此本申请实施例可以节省第一应用程序的筛选所耗费的人力成本,且可以提高第一应用程序的筛选效率。
并且,本申请实施例在兼容层软件中设置预设代码;该预设代码可用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取该预设交互组件的组件信息;这样,本申请实施例可以根据该预设交互组件的组件信息,进行第一应用程序的自动安装等自动处理。由于上述自动处理可以节省人工安装所耗费的操作成本,因此本申请实施例可以节省第一应用程序的筛选所耗费的人力成本,且可以提高第一应用程序的筛选效率。
进一步,本申请实施例根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新,并将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库。由于第一服务端可以根据内存数据库获取多个客户端的自动处理结果,故可以处理结果的人工汇总所耗费的人力成本,且可以提高第一应用程序的筛选效率。
此外,本申请实施例利用内存数据库进行应用信息的分发和自动处理结果的收集,由于内存数据库具备读写速度快的优点,因此,本申请实施例可以降低第一服务端的访问压力,适用于高并发的访问场景,也即,第一服务端连接多个客户端、且多个客户端频繁访问内存数据库的场景。
附图说明
图1是本申请一个实施例的应用程序的移植***的结构示意图;
图2是本申请一个实施例的应用程序的移植处理方法的步骤流程示意图;
图3是本申请一个实施例的应用程序的处理状态信息的更新方法的步骤流程图;
图4是本申请一个实施例的应用程序的移植处理方法的步骤流程示意图;
图5是本申请一个实施例的应用程序的移植处理方法的步骤流程示意图;
图6是本申请一个实施例的应用程序的移植处理方法的步骤流程示意图;
图7是本申请一个实施例的应用程序的移植处理方法的步骤流程示意图;
图8是本申请一个实施例的应用程序的移植处理装置的结构示意图;
图9是本申请一个实施例的应用程序的移植处理装置的结构示意图;
图10是本申请一个实施例提供的装置的结构示意图。
具体实施方式
为使本申请的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本申请作进一步详细的说明。
本申请实施例可以应用于应用移植场景。在应用移植场景下,可以利用例如Wine的兼容层软件,将第一操作***的应用程序移植到第二操作***上。
兼容层软件是一种能够在多种兼容POSIX(POSIX-compliant)的第一操作***上运行第二操作***的应用程序的兼容层。兼容层软件能够将Windows API的调用翻译成为动态的POSIX调用,因此能够使Windows应用程序在Windows之外的第一操作***中运行。
第一操作***的例子可以包括:Linux,macOS(麦金塔操作***,MacintoshOperating System)及BSD(伯克利软件套件,Berkeley Software Distribution)等。第二操作***的例子可以包括:Windows操作***(视窗操作***)等。可以理解,本申请实施例对于具体的第一操作***和第二操作***不加以限制。
针对相关技术中人工筛选方式不仅耗费大量的人力成本,而且筛选效率低的技术问题,本申请实施例提供了一种应用程序的移植处理方法,该方法应用于运行在第一操作***上的客户端,该第一操作***中运行有兼容层软件,在兼容层软件中设置预设代码;该预设代码用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取所述预设交互组件的组件信息;该方法可以包括:
从第一服务端的内存数据库的列表中获取第一应用程序的应用信息;该应用信息具体可以包括:应用标识和下载地址;
根据该下载地址,从第二服务端下载第一应用程序的安装包;
根据第一应用程序的安装包,进行第一应用程序的自动处理;该自动处理可以包括:安装;其中,从该兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据该组件信息,进行自动处理过程中界面的跳转;
根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则该自动处理还包括:启动;
将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;该自动处理结果包括:第一应用程序在自动处理结束情况下的目标处理状态信息。
本申请实施例的客户端从第一服务端的内存数据库的列表中获取第一应用程序的应用信息,并根据应用信息中的下载地址,自动从第二服务端下载第一应用程序的安装包。由于本申请实施例的客户端能够自动获取应用信息和自动下载第一应用程序的安装包,故能够节省基于人工调度将第一应用程序分配至计算节点的操作成本,因此本申请实施例可以节省第一应用程序的筛选所耗费的人力成本,且可以提高第一应用程序的筛选效率。
并且,本申请实施例在兼容层软件中设置预设代码;该预设代码可用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取该预设交互组件的组件信息;这样,本申请实施例可以根据该预设交互组件的组件信息,进行第一应用程序的自动安装等自动处理。由于上述自动处理可以节省人工安装所耗费的操作成本,因此本申请实施例可以节省第一应用程序的筛选所耗费的人力成本,且可以提高第一应用程序的筛选效率。
进一步,本申请实施例根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新,并将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库。由于第一服务端可以根据内存数据库获取多个客户端的自动处理结果,故可以处理结果的人工汇总所耗费的人力成本,且可以提高第一应用程序的筛选效率。
参考图1,示出了本申请一个实施例的应用程序的移植***的结构示意图,该***具体可以包括:兼容层软件101、至少一个客户端102、第一服务端103和第二服务端104。图1中示出了一个客户端102,可以理解,在实际应用中,客户端102的数量可以为多个。
其中,兼容层软件101和客户端102运行在第一操作***的环境中。兼容层软件101和客户端102可以为不同的软件,或者,兼容层软件101和客户端102可以为相同软件的不同模块。
兼容层软件101和客户端102之间可以经由进程通信方式进行通信。例如,在第一操作***为Linux***的情况下,兼容层软件101和客户端102之间可以经由域套接字(UDS,unix domain sockets)方式进行通信。或者,兼容层软件101和客户端102之间可以经由组件通信等软件内部的通信方式进行通信。可以理解,本申请实施例对于兼容层软件101和客户端102之间的具体通信方式不加以限制。
在兼容层软件101为开源软件的情况下,可以在兼容层软件101的源代码的基础上,设置预设代码。在兼容层软件101为非开源软件的情况下,可以在获得开发方的许可的情况下,在兼容层软件101中设置预设代码。
客户端102可以是与服务端相对应,为客户提供本地服务的程序。客户端102与第一服务端103可以利用有线网络或无线网络进行通信,或者,客户端102与第二服务端104可以利用有线网络或无线网络进行通信。本申请实施例对于第一服务端103或第二服务端104所对应操作***的环境不加以限制,第一服务端103或第二服务端104所对应操作***可以是第一操作***或第二操作***等。
第二服务端104可以根据第二操作***的应用程序的下载地址,进行第二操作***的应用程序的批量下载,对批量下载的第一应用程序进行存储,根据存储的第一应用程序,提供第一应用程序的下载服务,以使客户端102根据所述下载服务进行第一应用程序的下载。下载服务对应的通信协议可以包括:FTP(文件传输协议,File Transfer Protocol)协议、或者BT(比特流,Bit Torrent)协议等。可以理解,本申请实施例对于下载服务对应的具体通信协议不加以限制。
在具体实现中,第二服务端104可以利用爬虫工具,从下载网站等数据源,进行第二操作***的应用程序的批量下载。第二服务端104可以利用数据库存储应用程序的安装包等数据,还可以提供下载服务。
爬虫工具可以获取网页源代码,并从网页源代码中提取第一应用程序的第一下载地址。在有些情况下,网页源代码中可能包含第一应用程序的第一下载地址;此种情况下,可以从网页源代码中成功提取第一应用程序的第一下载地址。
在另一些情况下,网页源代码中可能并不直接包含第一应用程序的第一下载地址。因此,在本申请的一种可选实现方式中,可以对网页源代码进行解析,以得到第一下载地址对应的多个字符串及拼接规则;根据所述拼接规则,对所述多个字符串进行拼接,以得到第一应用程序的第一下载地址。网页源代码可以是网页中下载相关内容的函数对应的函数源代码。本申请实施例可以从函数源代码中解析得到第一下载地址对应的多个字符串及拼接规则,并按照该拼接规则对该多个字符串进行拼接,以得到第一应用程序的第一下载地址。
第二服务端104还可以针对下载的应用程序,记录应用标识、下载地址、数据源、应用类别、信息摘要、版本等应用信息。其中,应用标识可以唯一标识第一应用程序,例如,应用标识可以为安装包的名称等。数据源可用于对应用程序进行溯源。例如,在第三应用程序的错误信息表征第三应用程序包含病毒信息时,可以对第三应用程序对应数据源的多个应用程序进行下架处理和删除处理。其中,下架处理可以将已发布的应用程序进行下架。
应用类别可以用于解决应用移植过程中的后续错误。例如,在后续使用第二应用程序的过程中,可以采用第四应用程序对应的映射关系,解决第二应用程序的错误;其中,第二应用程序与第四应用程序可以对应相同的应用类别。在实际应用中,可以建立并保存应用类别、错误信息与解决方案之间的映射关系。
信息摘要可以避免下载信息摘要相同的多个应用程序,以减少应用程序的冗余。
第一服务端103可以从第二服务端104获取第一应用程序的应用信息,并将第一应用程序的应用信息写入内存数据库的列表,以使客户端102从列表中获取第一应用程序的应用信息。
内存数据库可以指将数据放在内存中直接操作的数据库。相对于磁盘,内存的数据读写速度要高出几个数量级,将数据保存在内存中相比从磁盘上访问能够极大地提高数据读取的性能。
在将第一应用程序的应用信息写入内存数据库的列表之前,可以对第一应用程序的应用信息进行去重处理,以避免一个第一应用程序被多个客户端102重复处理。例如,可以根据信息摘要或应用标识,对第一应用程序的应用信息进行去重处理。又如,可以利用内存数据库的集合(Set)技术,对第一应用程序的应用信息进行去重处理。集合技术是唯一字符串的无序集合,唯一值表示集合中不允许键中有重复的数据。
内存数据库的列表可以包括:队列、链表或堆栈等。列表的进出方向可以包括:左进右出、或左进左出、或右进左出、或右进右出等。本申请实施例可以经由推(Push)操作,向列表中写应用信息;以及,可以经由弹出(Pop)操作,从列表中获取应用信息。弹出操作不仅可以获取列表中位于头部或尾部的一个目标元素,而且可以将目标元素从列表中移除。这样,不仅可以释放列表的存储空间,而且可以减少不同客户端获取的应用信息的重复性。
本申请实施例对兼容层软件101进行了更新,具体而言,在兼容层软件101中设置了预设代码。该预设代码用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取该预设交互组件的组件信息。在实际应用中,服务端103可以访问兼容层软件101的文件路径,以在兼容层软件101的文件路径中设置预设代码。或者,可以为兼容层软件101生成预设代码对应的补丁。或者,可以与兼容层软件101的开发方进行合作,以使开发方在兼容层软件101中设置预设代码。可以理解,本申请实施例对于在兼容层软件101中设置预设代码的具体实现方式不加以限制。
预设交互组件可以指具有交互功能的组件,如用于输入信息或做出选择的组件。预设交互组件的例子可以包括:输入框、复选框、单选按钮、下拉菜单、单击控件、切换控件等,可以理解,本申请实施例对于具体的预设交互组件不加以限制。
客户端102可以根据该预设交互组件的组件信息,进行第一应用程序的自动处理,根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新,并将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库。
客户端102对于一个第一应用程序的处理过程可以包括:客户端102从列表中获取一个第一应用程序的应用信息,根据下载地址进行安装包的下载,进行第一应用程序的自动处理,对第一应用程序的处理状态信息进行更新,并将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库等。在完成一个第一应用程序的处理后,客户端102可以从列表中获取下一个第一应用程序的应用信息,以进行下一个应用程序的处理。
第一服务端103可以从一个或多个客户端102收集第一应用程序的应用标识、以及自动处理结果,由此可以根据自动处理结果中的目标处理状态信息,进行第一应用程序的筛选。
在本申请的一种可选实现方式中,该***还可以包括:第三服务端,第三方服务端可以检测第一服务端和客户端是否正常工作。例如,第三服务端可以按照预设周期向第一服务端和客户端发送消息,若第一服务端或客户端在第一预设时长内未回应,则可以认为第一服务端或客户端未正常工作。
第三服务端可以将未正常工作的第一服务端置为失效状态,启动新的处于有效状态的第一服务端,将处于失效状态的第一服务端的数据迁移到处于有效状态的第一服务端。
第三服务端可以将未正常工作的客户端置为失效状态,启动新的处于有效状态的客户端,将处于失效状态的客户端的数据迁移到处于有效状态的客户端。或者,第三服务端可以将未正常工作的客户端置为失效状态,启动新的处于有效状态的客户端,将处于失效状态的客户端的应用信息写入内存数据库的列表,以等待新的客户端来获取相应的应用信息。
方法实施例一
参考图2,示出了本申请一个实施例的应用程序的移植处理方法的步骤流程示意图,该方法可以应用于运行在第一操作***上的客户端,该第一操作***中运行有兼容层软件,在兼容层软件中设置预设代码;该预设代码用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取该预设交互组件的组件信息;该方法具体可以包括如下步骤:
步骤201、从第一服务端的内存数据库的列表中获取第一应用程序的应用信息;该应用信息可以包括:应用标识和下载地址;
步骤202、根据该下载地址,从第二服务端下载第一应用程序的安装包;
步骤203、根据第一应用程序的安装包,进行第一应用程序的自动处理;该自动处理可以包括:安装;其中,从该兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据该组件信息,进行自动处理过程中界面的跳转;
步骤204、根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则该自动处理还包括:启动;
步骤205、将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;该自动处理结果可以包括:第一应用程序在自动处理结束情况下的目标处理状态信息。
在步骤201中,客户端所在的设备中可以运行有内存数据库的客户端,第一服务端所在的设备中可以运行有内存数据库的服务端,内存数据库的客户端与内存数据库的服务端可以相互访问。这样,客户端可以利用内存数据库的客户端访问内存数据库的服务端,以从第一服务端的内存数据库的列表中获取第一应用程序的应用信息。
客户端可以利用内存数据库的客户端向内存数据库的服务端发送获取请求。内存数据库的服务端在接收到获取请求后,可以利用弹出操作,从列表中获取应用信息,并向内存数据库的客户端发送获取的应用信息。
客户端根据空闲情况,从该列表中获取该应用信息。例如,若客户端本地存在正在处理的第一应用程序,则客户端的空闲情况为忙碌。又如,若客户端本地不存在正在处理的第一应用程序,则客户端的空闲情况为空闲。在空闲情况为空闲的情况下,客户端可以从该列表中获取该应用信息。
在步骤202中,客户端所在的设备中可以运行有下载服务的客户端,第二服务端所在的设备中可以运行有下载服务的服务端,下载服务的客户端与下载服务的服务端可以相互访问。这样,客户端可以利用下载服务的客户端访问下载服务的服务端,以从第二服务端获取第一应用程序的安装包。
客户端可以利用下载服务的客户端向下载服务的服务端发送下载请求。下载服务的服务端在接收到下载请求后,可以根据下载请求中的下载地址,获取安装包,并向下载服务的客户端发送获取的安装包。
在步骤203中,客户端可以触发第一应用程序的自动安装、自动启动和自动使用等自动处理。例如,可以采用双击第一应用程序的安装包的方式,触发第一应用程序的自动安装。又如,可以采用在安装成功界面上勾选具有运行功能的组件、或者双击第一应用程序的图标的方式,触发第一应用程序的自动启动。再如,在自动启动成功的情况下,也即,在第一应用程序的自动启动过程中未采集到错误信息的情况下,可以触发第一应用程序的自动使用。
预设交互组件可以为第一应用程序的相关界面中包含的组件。相关界面可以包括:安装界面、启动界面或使用界面。
在第二操作***的第一应用程序调用预设交互组件的情况下,兼容层软件中设置的预设代码可以从第一操作***获取预设交互组件的组件信息,并采用预设数据结构,向客户端传递该组件信息。而客户端可以基于与兼容层软件之间的交互,获取预设交互组件的组件信息。组件信息可以包括:位置信息和标识信息等。
标识信息可用于标识预设交互组件。标识信息可以为第一操作***对于预设交互组件的表征。本申请实施例可以利用组件字典,确定标识信息对应的组件含义。组件字典中可以记录有标识信息与组件含义之间的映射关系。组件含义可以作为标识信息的识别结果。
例如,第一个安装界面中预设交互组件的组件含义可以包括:“立即安装”、“阅读并同意用户协议”、“卸载”等。又如,中间安装界面中预设交互组件的组件含义可以包括:“上一步”、“下一步”、“取消”等。再如,安装成功界面中预设交互组件的名称可以包括:“完成”、“生成程序图标”、“立即运行”等。
本申请实施例可以根据该标识信息对应的组件含义,从该界面中确定出目标预设交互组件。例如,第一个安装界面中目标预设交互组件的组件含义可以包括:“立即安装”、“阅读并同意用户协议”等。又如,中间安装界面中目标预设交互组件的组件含义可以包括:“下一步”等。再如,安装成功界面中目标预设交互组件的组件含义可以包括:“完成”、“生成程序图标”、“立即运行”等。
本申请实施例可以根据组件含义对应的处理属性,从该界面中确定出目标预设交互组件。处理属性可以包括:正向属性或负向属性,正向属性可以表征下一步流程所对应的属性,负向属性可以表征上一步流程或停止流程所对应的属性。本申请实施例可以根据该标识信息,从该界面中确定出正向属性对应的目标预设交互组件。
本申请实施例可以根据目标预设交互组件的位置信息,触发目标预设交互组件对应的操作,以进行自动处理过程中界面的跳转。例如,从第一个安装界面跳转到中间安装界面,从第i(i可以为正整数)个中间安装界面跳转到第(i+1)个中间安装界面,或者,从中间安装界面跳转到安装完成界面等。
在一种可选实现方式中,可以在兼容层软件的容器中设置预设字符种类、预设开发语言对应软件的运行和3D(三维,3-dimension)图像对应的动态链接库(DLL,DynamicLink Library)。兼容层软件的容器可用于提供第二操作***的环境。
在兼容层软件的容器中设置预设字符种类对应的动态链接库,可以使兼容层软件支持预设字符种类的输入。预设字符种类可以包括:数字、符号、预设语言或预设字体等。
在兼容层软件的容器中设置预设开发语言对应软件的运行对应的动态链接库,可以使兼容层软件更好地支持预设开发语言对应软件的运行。预设开发语言可以为第一应用程序的开发语言,预设开发语言可以包括:VC(Microsoft Visual C++)、VB(Visual Basic)等。
在兼容层软件的容器中设置3D图像对应的动态链接库,可以使兼容层软件支持3D图像的显示等处理。
在步骤204中,可以采集第一应用程序在自动处理过程中的错误信息。该错误信息可以包括:错误日志信息或截图信息。错误日志信息可由兼容层软件提供。可以在检测到错误信息的情况下,基于截取屏幕方式,得到截图信息。
本申请实施例可以提供第一应用程序的处理状态信息,该处理状态信息可以表征第一应用程序的处理进度或处理结果。上述方法还可以包括:根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;该处理状态信息可以包括如下信息中的至少一种:安装失败、启动失败、使用失败和使用成功。
参照表1,示出了本申请一个实施例的第一应用程序的处理状态信息的状态标识和含义的示例。其中,状态标识可以包括:数字。可以理解,状态标识可以包括:数字之外的字符(如符号或汉字等)。
表1
下载失败或下载成功对应的下载,可以指根据第二操作***的应用程序的下载地址,进行第二操作***的应用程序的下载,下载地址可由网站等第三方的数据源提供。在实际应用中,下载失败或下载成功对应的下载,可由第二服务端执行。因此,状态标识-2或状态标识-1对应的处理状态信息可由第二服务端维护。
可以理解,表1中的处理状态信息只是作为示例。实际上,在自动处理包括:安装和启动,而不包括使用的情况下,处理状态信息还可以包括:启动成功。在自动处理包括:安装,而不包括启动的情况下,处理状态信息还可以包括:安装成功。
参考图3,示出了本申请一个实施例的应用程序的处理状态信息的更新方法的步骤流程图,该方法具体可以包括如下步骤:
步骤301、第二服务端根据第二操作***的应用程序的下载地址,进行第二操作***的应用程序的下载,并判断下载是否成功,若否则执行步骤302,若是则执行步骤303;
步骤302、第二服务端将处理状态信息置为下载失败;
步骤303、第二服务端判断能否找到可执行文件,若否,则执行步骤304,若是则执行步骤305;
步骤304、第二服务端将处理状态信息置为下载成功后找不到可执行文件;
步骤305、第二服务端将处理状态信息置为未处理;
步骤306、在从第二服务端下载应用程序后,客户端将处理状态信息置为处理中;
步骤307、客户端判断自动安装过程中是否采集到错误信息,若是,则执行步骤308,否则执行步骤309;
步骤308、客户端将处理状态信息置为安装失败;
步骤309、客户端判断自动启动过程中是否采集到错误信息,若是,则执行步骤310,否则执行步骤311;
步骤310、客户端将处理状态信息置为启动失败;
步骤311、客户端判断自动使用过程中是否采集到错误信息,若是,则执行步骤312,否则执行步骤313;
步骤312、客户端向第一服务端发送错误信息以及对应的应用标识;
步骤313、客户端将处理状态信息置为使用成功。
在实际应用中,第一服务端可以根据错误信息,确定应用标识对应的处理状态信息。例如,在错误信息不影响正常使用的情况下,可以将应用标识对应的处理状态信息置为使用成功。又如,在错误信息影响正常使用的情况下,可以将应用标识对应的处理状态信息置为使用失败。
错误信息可以作为自动处理结果的一种示例,换言之,上述自动处理结果还可以包括:第一应用程序在自动处理过程中的错误信息;该错误信息可用于建立并保存错误信息与解决方案之间的映射关系;
上述解决方案具体可以包括如下方案种类中的至少一种:
在兼容层软件中设置所述错误信息对应的动态链接库;
在兼容层软件中设置所述错误信息对应的代码;
在兼容层软件中设置所述错误信息对应的处理逻辑;以及
在兼容层软件中设置所述错误信息对应的第三方应用程序的资源;第三方应用程序与错误信息对应应用程序存在依赖关系。
可以理解,图3只是作为更新方法的示例,而不理解为本申请实施例的更新方法的限制。例如,对于有些免安装的应用程序而言,其对应的自动处理可以不包括自动安装,因此,其对应的处理状态信息可以包括:不安装失败。
在步骤205中,可以利用内存数据库的客户端向内存数据库的服务端发送第一应用程序的应用标识、以及自动处理结果,以将应用标识和自动处理结果写入第一服务端的内存数据库。
该自动处理结果可以包括:第一应用程序在自动处理结束情况下的目标处理状态信息。自动处理结束可以包括:自动安装结束、或自动启动结束、或自动启动结束等。在实际应用中,若在第二预设时长内未检测到目标预设交互组件对应的操作,则可以认为自动处理结束。
本申请实施例的客户端还可以执行如下步骤:采集第二操作***的第二应用程序在处理过程中的待处理错误信息;根据该待处理错误信息,在预先保存的错误信息与解决方案之间的映射关系中进行查找,以得到该待处理错误信息对应的目标解决方案;执行该目标解决方案。其中,第一服务端可以向客户端下发错误信息与解决方案之间的映射关系。
综上,本申请实施例的应用程序的移植处理方法,客户端从第一服务端的内存数据库的列表中获取第一应用程序的应用信息,并根据应用信息中的下载地址,自动从第二服务端下载第一应用程序的安装包。由于本申请实施例的客户端能够自动获取应用信息和自动下载第一应用程序的安装包,故能够节省基于人工调度将第一应用程序分配至计算节点的操作成本,因此本申请实施例可以节省第一应用程序的筛选所耗费的人力成本,且可以提高第一应用程序的筛选效率。
并且,本申请实施例在兼容层软件中设置预设代码;该预设代码可用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取该预设交互组件的组件信息;这样,本申请实施例可以根据该预设交互组件的组件信息,进行第一应用程序的自动安装等自动处理。由于上述自动处理可以节省人工安装所耗费的操作成本,因此本申请实施例可以节省第一应用程序的筛选所耗费的人力成本,且可以提高第一应用程序的筛选效率。
进一步,本申请实施例根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新,并将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库。由于第一服务端可以根据内存数据库获取多个客户端的自动处理结果,故可以处理结果的人工汇总所耗费的人力成本,且可以提高第一应用程序的筛选效率。
方法实施例二
参考图4,示出了本申请一个实施例的应用程序的移植处理方法的步骤流程示意图,该方法可以应用于第一服务端,该方法具体可以包括如下步骤:
步骤401、将第一应用程序的应用信息写入内存数据库的列表;该应用信息可以包括:应用标识和下载地址;其中,客户端从该列表中获取该应用信息,根据该下载地址,从第二服务端下载第一应用程序的安装包,根据第一应用程序的安装包,进行第一应用程序的自动处理;该自动处理可以包括:安装;其中,从该兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据该组件信息,进行自动处理过程中界面的跳转;根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则该自动处理还可以包括:启动;将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;该自动处理结果可以包括:第一应用程序在自动处理结束情况下的目标处理状态信息;
步骤402、从内存数据库中读取第一应用程序的应用标识、以及自动处理结果;
步骤403、根据该目标处理状态信息,对第一应用程序进行筛选。
在步骤401中,第一服务端可以将第一应用程序的应用信息写入内存数据库的列表,可以使客户端根据空闲情况,从该列表中获取该应用信息,由此可以实现应用信息到客户端的自动分发。
在实际应用中,可以从第二服务端的数据库中获取待处理的应用信息,并将待处理的应用信息存储至内存数据库。其中,可以基于第一服务端与第二服务端之间的数据连接,从第二服务端的数据库中获取待处理的应用信息。
在将第一应用程序的应用信息写入内存数据库的列表之前,可以对第一应用程序的应用信息进行去重处理,以避免一个第一应用程序被多个客户端重复处理。例如,可以根据信息摘要或应用标识,对第一应用程序的应用信息进行去重处理。又如,可以利用内存数据库的集合技术,对第一应用程序的应用信息进行去重处理。集合技术是唯一字符串的无序集合,唯一值表示集合中不允许键中有重复的数据。
第一服务端可以经由推操作,向列表中写应用信息。在接收到客户端发送的获取请求的情况下,第一服务端可以经由弹出操作,从列表中获取应用信息,并向客户端返回应用信息。
在步骤402中,第一服务端可以从内存数据库中读取第一应用程序的应用标识、以及自动处理结果。应用标识、以及自动处理结果的数据格式可以为键值对(key-value)格式,key代表应用标识,value代表自动处理结果。当然,本申请实施例对于应用标识、以及自动处理结果的具体数据格式不加以限制。
在步骤403中,第一服务端可以根据该目标处理状态信息,对第一应用程序进行筛选。
上述筛选过程可以包括:在目标处理状态信息的数量与写入列表的第一应用程序的预设数量相匹配的情况下,从预设数量的第一应用程序中选择目标处理状态信息为预设处理状态的目标第一应用程序。
预设数量可以为待处理的第一应用程序的数量。例如,第一服务端从第二服务端的数据库中获取待处理的应用信息,则待处理的应用信息的数量可以为预设数量。又如,第一服务端从第二服务端的数据库中获取待处理的应用信息,并对待处理的应用信息进行去重处理,则去重处理后的应用信息的数量可以为预设数量。
在目标处理状态信息的数量与写入列表的第一应用程序的预设数量相匹配的情况下,可以认为预设数量的第一应用程序被处理完毕,此种情况下,可以对预设数量的第一应用程序进行筛选。具体而言,可以从预设数量的第一应用程序中选择目标处理状态信息为预设处理状态信息的目标第一应用程序。
预设处理状态信息可由本领域技术人员根据实际应用需求确定,例如,预设处理状态信息可以包括:安装失败、或启动失败、或使用失败等。本申请实施例可以对目标第一应用程序对应的错误信息进行分析,以得到对应的解决方案。
在本申请的一种可选实现方式中,自动处理结果还可以包括:第一应用程序在自动处理过程中的错误信息;所述错误信息用于建立并保存错误信息与解决方案之间的映射关系;
所述方法还可以包括:建立并保存错误信息与解决方案之间的映射关系;执行所述映射关系中的解决方案,以对兼容层软件进行更新。
其中,该解决方案可以包括如下方案种类中的至少一种:
方案种类A、在兼容层软件中设置该错误信息对应的动态链接库;
方案种类B、在兼容层软件中设置该错误信息对应的代码;
方案种类C、在兼容层软件中设置该错误信息对应的处理逻辑;如在预设应用程序的环境下,采用预设处理方式等,可以理解,不同的预设应用程序可以对应不同的预设处理方式。例如,对于图像处理程序而言,其可以采用第一图形接口进行渲染处理,以提升3D图像的渲染速度,其中,第一图形接口可以为支持3D的图形接口。又如,对于除了图像处理程序之外的应用程序而言,由于其可以不涉及3D图像,故可以采用第二图形接口进行渲染处理。以及
方案种类D、在兼容层软件中设置错误信息对应的第三方应用程序的资源;第三方应用程序与错误信息对应应用程序存在依赖关系。
本申请实施例可以对错误信息进行分析,以得到对应的解决方案。本申请实施例可以针对错误信息,确定和执行备选解决方案,并根据备选解决方案的执行结果,判断备选解决方案的有效性。例如,若执行结果表征:执行备选解决方案后、对应的错误信息消失,则备选解决方案的有效性为有效。或者,若执行结果表征:执行备选解决方案后、对应的错误信息仍存在,则备选解决方案的有效性为无效。
在方案种类A对应的应用示例中,假设错误信息A包括:Windows的即时通讯程序X在扫码登录的过程中无法刷新二维码的错误,则错误信息A对应的解决方案A可以为:在兼容层软件中设置该错误信息A对应的动态链接库。
在方案种类B对应的应用示例中,假设错误信息B包括:Windows的即时通讯程序X的窗口遮挡的错误,则错误信息B对应的解决方案B可以为:在兼容层软件中设置该错误信息对应的代码,该代码中可以包括:上层窗口的透明度属性,这样,可以解决下层窗口被上层窗口遮挡的问题。
在方案种类C对应的应用示例中,假设错误信息C包括:Windows的图像处理程序存在3D功能卡顿的错误,则错误信息C对应的解决方案C可以为:在兼容层软件中设置该错误信息对应的处理逻辑,该处理逻辑可用于在图像处理程序的环境下,使用预设图形接口进行3D图像的渲染。
对于方案种类D,可以提供应用程序与第三方应用程序之间的依赖关系,则可以根据该依赖关系,在兼容层软件中设置错误信息对应的第三方应用程序的资源。例如,作业辅导类别或解题类别的应用程序通常依赖于办公类别的第三方应用程序,因此,可以提供作业辅导类别或解题类别的应用程序与办公类别的第三方应用程序之间的依赖关系,并根据该依赖关系,在兼容层软件中设置办公类别的第三方应用程序的资源,如办公套件等。
在具体实现中,可以对多个第一应用程序的错误信息进行聚类,以得到多种错误类别。并且,可以按照错误类别所包含错误信息的数量,确定错误类别的优先级。通常错误类别所包含错误信息的数量越多,错误类别的优先级越高。进一步,可以按照错误类别从高到低的顺序,针对错误类别确定对应的解决方案。
参照表2,示出了本申请一个实施例的错误类别与解决方案之间的映射关系的示例。
表2
本申请实施例执行该映射关系中的解决方案,可以实现兼容层软件的更新和优化,因此可以减少后续错误的出现概率。
假设映射关系中包括M(M为正整数)个解决方案,则可以执行M个解决方案中的部分或全部,以实现兼容层软件的更新和优化。
在实际应用中,随着第二操作***的应用程序的不断更新,第二服务端可以根据第二操作***的应用程序的下载地址,进行第二操作***的应用程序的扩充,由此可以实现第一应用程序的扩充(如新增)。进一步,本申请实施例可以根据新增的第一应用程序,采集新增的错误信息,确定新增的解决方案。因此,本申请实施例还可以利用更新后的兼容层软件,生成新增的解决方案。这样,在后续使用新版本的第一应用程序、或者与第一应用程序不同的应用程序的情况下,可以对后续出现的错误信息提供对应的目标解决方案。
如表1所示,本申请实施例可以将状态标识为-1或-2的应用程序删除,以释放对应的资源。
在执行该映射关系中的解决方案后,第一应用程序包含的错误信息可以有所减少。本申请实施例可以对使用成功或包含错误信息的第一应用程序进行审核,并对审核通过的第一应用程序进行发布。由于审核通过的第一应用程序不包含错误信息或包含较少的错误信息,因此能够提高发布应用程序的稳定性和安全性等性能。
综上,本申请实施例的应用程序的移植处理方法,第一服务端将第一应用程序的应用信息写入内存数据库的列表,可以使客户端自动获取应用信息和自动下载第一应用程序的安装包,故能够节省基于人工调度将第一应用程序分配至计算节点的操作成本,因此本申请实施例可以节省第一应用程序的筛选所耗费的人力成本,且可以提高第一应用程序的筛选效率。
并且,本申请实施例在兼容层软件中设置预设代码;该预设代码可用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取该预设交互组件的组件信息;这样,本申请实施例可以根据该预设交互组件的组件信息,进行第一应用程序的自动安装等自动处理。由于上述自动处理可以节省人工安装所耗费的操作成本,因此本申请实施例可以节省第一应用程序的筛选所耗费的人力成本,且可以提高第一应用程序的筛选效率。
进一步,本申请实施例根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新,并将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库。由于第一服务端可以根据内存数据库获取多个客户端的自动处理结果,故可以处理结果的人工汇总所耗费的人力成本,且可以提高第一应用程序的筛选效率。
此外,由于本申请实施例的错误信息可用于建立并保存错误信息与解决方案之间的映射关系,该映射关系可用于解决应用移植过程中的后续错误。例如,在第一操作***上处理第二操作***的第二应用程序的过程中,若采集到错误信息,则可以执行该错误信息对应的目标解决方案,以实现应用移植过程中错误的自动解决,因此能够提高应用移植过程中的错误解决效率。
方法实施例三
参考图5,示出了本申请一个实施例的应用程序的移植处理方法的步骤流程示意图,该方法可以应用于运行在第一操作***上的客户端,该第一操作***中运行有兼容层软件,该方法具体可以包括如下步骤:
步骤501、采集第二操作***的第二应用程序在处理过程中的待处理错误信息;
步骤502、根据该待处理错误信息,在预先保存的错误信息与解决方案之间的映射关系中进行查找,以得到该待处理错误信息对应的目标解决方案;
步骤503、执行该目标解决方案;
其中,该解决方案具体可以包括如下方案种类中的至少一种:
在兼容层软件中设置错误信息对应的动态链接库;
在兼容层软件中设置错误信息对应的代码;
在兼容层软件中设置错误信息对应的处理逻辑;以及
在兼容层软件中设置错误信息对应的第三方应用程序的资源;第三方应用程序与错误信息对应应用程序存在依赖关系;
在兼容层软件中设置预设代码;该预设代码用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取该预设交互组件的组件信息;该预设交互组件的组件信息用于进行第一应用程序的自动处理;该自动处理包括:安装、启动和使用中的至少一种;该第一应用程序在自动处理过程中的错误信息用于建立和保存错误信息与解决方案之间的映射关系。
在步骤501中,待处理错误信息可以为待处理的错误日志信息。例如,可以从兼容层软件获取第二应用程序在处理过程中出现的、待处理的错误日志信息。处理过程可以包括:安装过程、启动过程和使用过程中的至少一种。
在步骤502中,第一服务端可以向客户端下发错误信息与解决方案之间的映射关系。客户端可以将待处理的错误日志信息与映射关系中的错误信息进行匹配。对应的匹配可以包括:字符串匹配或者语义匹配等。其中,字符串匹配可以包括:对待处理的错误日志信息包含的第一字符串与映射关系中的错误信息包含的第二字符串进行匹配。语义匹配可以首先确定待处理的错误日志信息对应的第一语义信息、以及映射关系中的错误信息对应的第二语义信息,并对第一语义信息与第二语义信息进行匹配。其中,可以利用自然语言理解方法或日志分析方法,确定第一语义信息与第二语义信息。
在一种实现方式中,映射关系可以包括:应用类别、错误信息与解决方案之间的映射关系。这样,不仅对第二应用程序与应用类别进行匹配,而且,对待处理的错误日志信息与映射关系中的错误信息进行匹配。在第二应用程序的过程中,可以采用第四应用程序对应的映射关系,解决第二应用程序的错误;其中,第二应用程序与第四应用程序可以对应相同的应用类别。
在本申请的一种可选实施例中,上述方法还可以包括:根据第二应用程序在处理过程中需要调用的第一动态链接库,确定所述第一动态链接库依赖的第二动态链接库;在兼容层软件中增设所述第二动态链接库。
本申请实施例可以提供第一动态链接库与第二动态链接库之间的对应关系,并根据该对应关系,确定所述第一动态链接库依赖的第二动态链接库,以及在兼容层软件中增设所述第二动态链接库。上述在兼容层软件中增设所述第二动态链接库,可以提升第二应用程序的运行稳定性。其中,第一服务端可以保存有动态链接库的集合,该集合中可以包括第二动态链接库等动态链接库。
在步骤503中,执行该目标解决方案,可以实现应用移植过程中错误的自动解决,因此能够提高应用移植过程中的错误解决效率。
方法实施例四
参考图6,示出了本申请一个实施例的应用程序的移植处理方法的步骤流程示意图,该方法具体可以包括如下步骤:
步骤601、第一服务端将第一应用程序的应用信息写入内存数据库的列表;
步骤602、客户端从第一服务端的内存数据库的列表中获取第一应用程序的应用信息;该应用信息可以包括:应用标识和下载地址;
步骤603、客户端根据该下载地址,从第二服务端下载第一应用程序的安装包;
步骤604、客户端根据第一应用程序的安装包,进行第一应用程序的自动处理;该自动处理可以包括:安装;其中,从该兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据该组件信息,进行自动处理过程中界面的跳转;
步骤605、客户端根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则该自动处理还包括:启动;
步骤606、客户端将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;
步骤607、第一服务端从内存数据库中读取第一应用程序的应用标识、以及自动处理结果;
步骤608、第一服务端根据该目标处理状态信息,对第一应用程序进行筛选。
在本申请的一种可选实现方式中,自动处理结果还可以包括:第一应用程序在自动处理过程中的错误信息;所述错误信息用于建立并保存错误信息与解决方案之间的映射关系;则所述方法还可以包括:执行所述映射关系中的解决方案,以对兼容层软件进行更新。
由于本申请实施例的错误信息可用于建立并保存错误信息与解决方案之间的映射关系,该映射关系可用于解决应用移植过程中的后续错误。例如,在第一操作***上处理第二操作***的第二应用程序的过程中,若采集到错误信息,则可以执行该错误信息对应的目标解决方案,以实现应用移植过程中错误的自动解决,因此能够提高应用移植过程中的错误解决效率。
并且,本申请实施例的解决方案可以涉及:在兼容层软件中设置错误信息对应的动态链接库、代码、处理逻辑和依赖关系等兼容层软件的更新和优化方案,上述兼容层软件的更新和优化方案可以减少后续错误的出现概率。
方法实施例五
参考图7,示出了本申请一个实施例的应用程序的移植处理方法的步骤流程示意图,该方法具体可以包括如下步骤:
步骤701、数据获取。第二服务端可以利用爬虫工具,从下载网站等数据源,进行第二操作***的应用程序的批量下载。
步骤702、数据存储。第二服务端可以利用数据库存储应用程序的安装包等数据,还可以提供FTP、BT等通信协议的下载服务。
步骤703、自动处理。客户端可以从第二服务端下载第一应用程序,并进行第一应用程序的自动安装、自动启动和自动使用等自动处理。
步骤704、错误收集。客户端可以采集第一应用程序在自动处理过程中的错误信息。
步骤705、映射关系的建立。第一服务端可以收集多个客户端采集的错误信息,并建立和保存错误信息与解决方案之间的映射关系。
步骤706、第二应用程序的处理过程。客户端可以根据第二应用程序在处理过程中需要调用的第一动态链接库,确定所述第一动态链接库依赖的第二动态链接库;在兼容层软件中增设所述第二动态链接库。客户端还可以采集第二应用程序在处理过程中的待处理错误信息;,根据该待处理错误信息,在预先保存的错误信息与解决方案之间的映射关系中进行查找,以得到该待处理错误信息对应的目标解决方案,并执行该目标解决方案。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本申请实施例并不受所描述的动作顺序的限制,因为依据本申请实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本申请实施例所必须的。
在上述实施例的基础上,本实施例还提供了一种应用程序的移植处理装置,该装置可以应用于运行在第一操作***上的客户端,该第一操作***中可以运行有兼容层软件,可以在兼容层软件中设置预设代码;该预设代码可以用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取该预设交互组件的组件信息;参照图8,该装置具体可以包括如下模块:
应用信息获取模801,用于从第一服务端的内存数据库的列表中获取第一应用程序的应用信息;该应用信息可以包括:应用标识和下载地址;
下载模块802,用于根据该下载地址,从第二服务端下载第一应用程序的安装包;
自动处理模块803,用于根据第一应用程序的安装包,进行第一应用程序的自动处理;该自动处理可以包括:安装;其中,从该兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据该组件信息,进行自动处理过程中界面的跳转;
状态更新模块804,用于根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则该自动处理还包括:启动;
结果处理模块805,用于将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;该自动处理结果可以包括:第一应用程序在自动处理结束情况下的目标处理状态信息。
可选地,该组件信息可以包括:标识信息和位置信息;该进行自动处理过程中界面的跳转,可以包括:
根据该标识信息,从该界面中确定出目标预设交互组件;
根据该目标预设交互组件的位置信息,触发该目标预设交互组件对应的操作,以进行自动处理过程中界面的跳转。
可选地,该自动处理结果还可以包括:第一应用程序在自动处理过程中的错误信息;该错误信息用于建立并保存错误信息与解决方案之间的映射关系;
该解决方案包括如下方案种类中的至少一种:
在兼容层软件中设置该错误信息对应的动态链接库;
在兼容层软件中设置该错误信息对应的代码;
在兼容层软件中设置该错误信息对应的处理逻辑;以及
在兼容层软件中设置该错误信息对应的第三方应用程序的资源;第三方应用程序与错误信息对应应用程序存在依赖关系。
可选地,该第二服务端根据第二操作***的应用程序的下载地址,进行第二操作***的应用程序的批量下载,对批量下载的第一应用程序进行存储,根据存储的第一应用程序,提供第一应用程序的下载服务,以使客户端根据该下载服务进行第一应用程序的下载。
可选地,该装置还可以包括:
设置模块,用于在兼容层软件的容器中设置预设字符种类、预设开发语言对应软件的运行和3D图像对应的动态链接库。
在上述实施例的基础上,本实施例还提供了一种应用程序的移植处理装置,参照图9,该装置可以应用于第一服务端,具体可以包括如下模块:
应用信息处理模块901,用于将第一应用程序的应用信息写入内存数据库的列表;该应用信息包括:应用标识和下载地址;其中,客户端从该列表中获取该应用信息,根据该下载地址,从第二服务端下载第一应用程序的安装包,根据第一应用程序的安装包,进行第一应用程序的自动处理;该自动处理包括:安装;其中,从该兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据该组件信息,进行自动处理过程中界面的跳转;根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则该自动处理还包括:启动;将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;该自动处理结果包括:第一应用程序在自动处理结束情况下的目标处理状态信息;
结果处理模块902,用于从内存数据库中读取第一应用程序的应用标识、以及自动处理结果;
筛选模块903,用于根据该目标处理状态信息,对第一应用程序进行筛选。
可选地,该自动处理结果还可以包括:第一应用程序在自动处理过程中的错误信息;该错误信息用于建立并保存错误信息与解决方案之间的映射关系;
该解决方案包括如下方案种类中的至少一种:
在兼容层软件中设置该错误信息对应的动态链接库;
在兼容层软件中设置该错误信息对应的代码;
在兼容层软件中设置该错误信息对应的处理逻辑;以及
在兼容层软件中设置该错误信息对应的第三方应用程序的资源;第三方应用程序与错误信息对应应用程序存在依赖关系;
该装置还可以包括:
方案执行模块,用于执行该映射关系中的解决方案,以对兼容层软件进行更新。
可选地,该筛选模块903具体可以包括:
选择模块,用于在该目标处理状态信息的数量与写入列表的第一应用程序的预设数量相匹配的情况下,从预设数量的第一应用程序中选择目标处理状态信息为预设处理状态信息的目标第一应用程序。
本申请实施例还提供了一种非易失性可读存储介质,该存储介质中存储有一个或多个模块(programs),该一个或多个模块被应用在设备时,可以使得该设备执行本申请实施例中各方法步骤的指令(instructions)。
本申请实施例提供了一个或多个机器可读介质,其上存储有指令,当由一个或多个处理器执行时,使得电子设备执行如上述实施例中一个或多个所述的方法。本申请实施例中,所述电子设备包括终端设备、服务器(集群)等各类型的设备。
本公开的实施例可被实现为使用任意适当的硬件,固件,软件,或及其任意组合进行想要的配置的装置,该装置可包括:终端设备、服务器(集群)等电子设备。图10示意性地示出了可被用于实现本申请中所述的各个实施例的示例性装置1100。
对于一个实施例,图10示出了示例性装置1100,该装置具有一个或多个处理器1102、被耦合到(一个或多个)处理器1102中的至少一个的控制模块(芯片组)1104、被耦合到控制模块1104的存储器1106、被耦合到控制模块1104的非易失性存储器(NVM)/存储设备1108、被耦合到控制模块1104的一个或多个输入/输出设备1110,以及被耦合到控制模块1104的网络接口1112。
处理器1102可包括一个或多个单核或多核处理器,处理器1102可包括通用处理器或专用处理器(例如图形处理器、应用处理器、基频处理器等)的任意组合。在一些实施例中,装置1100能够作为本申请实施例中所述终端设备、服务器(集群)等设备。
在一些实施例中,装置1100可包括具有指令1114的一个或多个计算机可读介质(例如,存储器1106或NVM/存储设备1108)以及与该一个或多个计算机可读介质相合并被配置为执行指令1114以实现模块从而执行本公开中所述的动作的一个或多个处理器1102。
对于一个实施例,控制模块1104可包括任意适当的接口控制器,以向(一个或多个)处理器1102中的至少一个和/或与控制模块1104通信的任意适当的设备或组件提供任意适当的接口。
控制模块1104可包括存储器控制器模块,以向存储器1106提供接口。存储器控制器模块可以是硬件模块、软件模块和/或固件模块。
存储器1106可被用于例如为装置1100加载和存储数据和/或指令1114。对于一个实施例,存储器1106可包括任意适当的易失性存储器,例如,适当的DRAM。在一些实施例中,存储器1106可包括双倍数据速率类型四同步动态随机存取存储器(DDR4SDRAM)。
对于一个实施例,控制模块1104可包括一个或多个输入/输出控制器,以向NVM/存储设备1108及(一个或多个)输入/输出设备1110提供接口。
例如,NVM/存储设备1108可被用于存储数据和/或指令1114。NVM/存储设备1108可包括任意适当的非易失性存储器(例如,闪存)和/或可包括任意适当的(一个或多个)非易失性存储设备(例如,一个或多个硬盘驱动器(HDD)、一个或多个光盘(CD)驱动器和/或一个或多个数字通用光盘(DVD)驱动器)。
NVM/存储设备1108可包括在物理上作为装置1100被安装在其上的设备的一部分的存储资源,或者其可被该设备访问可不必作为该设备的一部分。例如,NVM/存储设备1108可通过网络经由(一个或多个)输入/输出设备1110进行访问。
(一个或多个)输入/输出设备1110可为装置1100提供接口以与任意其他适当的设备通信,输入/输出设备1110可以包括通信组件、音频组件、传感器组件等。网络接口1112可为装置1100提供接口以通过一个或多个网络通信,装置1100可根据一个或多个无线网络标准和/或协议中的任意标准和/或协议来与无线网络的一个或多个组件进行无线通信,例如接入基于通信标准的无线网络,如WiFi、2G、3G、4G、5G等,或它们的组合进行无线通信。
对于一个实施例,(一个或多个)处理器1102中的至少一个可与控制模块1104的一个或多个控制器(例如,存储器控制器模块)的逻辑封装在一起。对于一个实施例,(一个或多个)处理器1102中的至少一个可与控制模块1104的一个或多个控制器的逻辑封装在一起以形成***级封装(SiP)。对于一个实施例,(一个或多个)处理器1102中的至少一个可与控制模块1104的一个或多个控制器的逻辑集成在同一模具上。对于一个实施例,(一个或多个)处理器1102中的至少一个可与控制模块1104的一个或多个控制器的逻辑集成在同一模具上以形成片上***(SoC)。
在各个实施例中,装置1100可以但不限于是:服务器、台式计算设备或移动计算设备(例如,膝上型计算设备、手持计算设备、平板电脑、上网本等)等终端设备。在各个实施例中,装置1100可具有更多或更少的组件和/或不同的架构。例如,在一些实施例中,装置1100包括一个或多个摄像机、键盘、液晶显示器(LCD)屏幕(包括触屏显示器)、非易失性存储器端口、多个天线、图形芯片、专用集成电路(ASIC)和扬声器。
其中,检测装置中可采用主控芯片作为处理器或控制模块,传感器数据、位置信息等存储到存储器或NVM/存储设备中,传感器组可作为输入/输出设备,通信接口可包括网络接口。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本申请实施例是参照根据本申请实施例的方法、终端设备(***)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本申请实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本申请实施例范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本申请所提供的一种应用程序的移植处理方法和装置、一种电子设备和一种机器可读介质,进行了详细介绍,本文中应用了具体个例对本申请的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本申请的方法及其核心思想;同时,对于本领域的一般技术人员,依据本申请的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本申请的限制。
Claims (12)
1.一种应用程序的移植处理方法,其特征在于,所述方法应用于运行在第一操作***上的客户端,所述第一操作***中运行有兼容层软件,在兼容层软件中设置预设代码;所述预设代码用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取所述预设交互组件的组件信息;所述方法包括:
从第一服务端的内存数据库的列表中获取第一应用程序的应用信息;所述应用信息包括:应用标识和下载地址;
根据所述下载地址,从第二服务端下载第一应用程序的安装包;
根据第一应用程序的安装包,进行第一应用程序的自动处理;所述自动处理包括:安装;其中,从所述兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据所述组件信息,进行自动处理过程中界面的跳转;
根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则所述自动处理还包括:启动;
将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;所述自动处理结果包括:第一应用程序在自动处理结束情况下的目标处理状态信息。
2.根据权利要求1所述的方法,其特征在于,所述组件信息包括:标识信息和位置信息;所述进行自动处理过程中界面的跳转,包括:
根据所述标识信息,从所述界面中确定出目标预设交互组件;
根据所述目标预设交互组件的位置信息,触发所述目标预设交互组件对应的操作,以进行自动处理过程中界面的跳转。
3.根据权利要求1所述的方法,其特征在于,所述自动处理结果还包括:第一应用程序在自动处理过程中的错误信息;所述错误信息用于建立并保存错误信息与解决方案之间的映射关系;
所述解决方案包括如下方案种类中的至少一种:
在兼容层软件中设置所述错误信息对应的动态链接库;
在兼容层软件中设置所述错误信息对应的代码;
在兼容层软件中设置所述错误信息对应的处理逻辑;以及
在兼容层软件中设置所述错误信息对应的第三方应用程序的资源;第三方应用程序与错误信息对应应用程序存在依赖关系。
4.根据权利要求1所述的方法,其特征在于,所述第二服务端根据第二操作***的应用程序的下载地址,进行第二操作***的应用程序的批量下载,对批量下载的第一应用程序进行存储,根据存储的第一应用程序,提供第一应用程序的下载服务,以使客户端根据所述下载服务进行第一应用程序的下载。
5.根据权利要求1至4中任一所述的方法,其特征在于,所述方法还包括:
在兼容层软件的容器中设置预设字符种类、预设开发语言对应软件的运行和3D图像对应的动态链接库。
6.一种应用程序的移植处理方法,其特征在于,所述方法应用于第一服务端,所述方法包括:
将第一应用程序的应用信息写入内存数据库的列表;所述应用信息包括:应用标识和下载地址;其中,客户端从所述列表中获取所述应用信息,根据所述下载地址,从第二服务端下载第一应用程序的安装包,根据第一应用程序的安装包,进行第一应用程序的自动处理;所述自动处理包括:安装;其中,从兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据所述组件信息,进行自动处理过程中界面的跳转;根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则所述自动处理还包括:启动;将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;所述自动处理结果包括:第一应用程序在自动处理结束情况下的目标处理状态信息;
从内存数据库中读取第一应用程序的应用标识、以及自动处理结果;
根据所述目标处理状态信息,对第一应用程序进行筛选。
7.根据权利要求6所述的方法,其特征在于,所述自动处理结果还包括:第一应用程序在自动处理过程中的错误信息;所述错误信息用于建立并保存错误信息与解决方案之间的映射关系;
所述解决方案包括如下方案种类中的至少一种:
在兼容层软件中设置所述错误信息对应的动态链接库;
在兼容层软件中设置所述错误信息对应的代码;
在兼容层软件中设置所述错误信息对应的处理逻辑;以及
在兼容层软件中设置所述错误信息对应的第三方应用程序的资源;第三方应用程序与错误信息对应应用程序存在依赖关系;
所述方法还包括:
执行所述映射关系中的解决方案,以对兼容层软件进行更新。
8.根据权利要求6所述的方法,其特征在于,所述根据所述目标处理状态信息,对第一应用程序进行筛选,包括:
在所述目标处理状态信息的数量与写入列表的第一应用程序的预设数量相匹配的情况下,从预设数量的第一应用程序中选择目标处理状态信息为预设处理状态信息的目标第一应用程序。
9.一种应用程序的移植处理装置,其特征在于,所述装置应用于运行在第一操作***上的客户端,所述第一操作***中运行有兼容层软件,在兼容层软件中设置预设代码;所述预设代码用于在第二操作***的第一应用程序调用预设交互组件的情况下,获取所述预设交互组件的组件信息;所述装置包括:
应用信息获取模块,用于从第一服务端的内存数据库的列表中获取第一应用程序的应用信息;所述应用信息包括:应用标识和下载地址;
下载模块,用于根据所述下载地址,从第二服务端下载第一应用程序的安装包;
自动处理模块,用于根据第一应用程序的安装包,进行第一应用程序的自动处理;所述自动处理包括:安装;其中,从所述兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据所述组件信息,进行自动处理过程中界面的跳转;
状态更新模块,用于根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则所述自动处理还包括:启动;
结果处理模块,用于将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;所述自动处理结果包括:第一应用程序在自动处理结束情况下的目标处理状态信息。
10.一种应用程序的移植处理装置,其特征在于,所述装置应用于第一服务端,所述装置包括:
应用信息处理模块,用于将第一应用程序的应用信息写入内存数据库的列表;所述应用信息包括:应用标识和下载地址;其中,客户端从所述列表中获取所述应用信息,根据所述下载地址,从第二服务端下载第一应用程序的安装包,根据第一应用程序的安装包,进行第一应用程序的自动处理;所述自动处理包括:安装;其中,从兼容层软件接收第一应用程序的界面中预设交互组件的组件信息,并根据所述组件信息,进行自动处理过程中界面的跳转;根据自动处理过程中是否采集到错误信息,对第一应用程序的处理状态信息进行更新;若某一时刻的处理状态信息为安装成功,则所述自动处理还包括:启动;将第一应用程序的应用标识、以及自动处理结果写入第一服务端的内存数据库;所述自动处理结果包括:第一应用程序在自动处理结束情况下的目标处理状态信息;
结果处理模块,用于从内存数据库中读取第一应用程序的应用标识、以及自动处理结果;
筛选模块,用于根据所述目标处理状态信息,对第一应用程序进行筛选。
11.一种电子设备,其特征在于,包括:处理器;和
存储器,其上存储有可执行代码,当所述可执行代码被执行时,使得所述处理器执行如权利要求1-8中任一项所述的方法。
12.一种机器可读介质,其上存储有可执行代码,当所述可执行代码被执行时,使得处理器执行如权利要求1-8中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211011147.1A CN115421785B (zh) | 2022-08-23 | 2022-08-23 | 应用程序的移植处理方法、装置和介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211011147.1A CN115421785B (zh) | 2022-08-23 | 2022-08-23 | 应用程序的移植处理方法、装置和介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN115421785A CN115421785A (zh) | 2022-12-02 |
CN115421785B true CN115421785B (zh) | 2023-05-12 |
Family
ID=84197751
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211011147.1A Active CN115421785B (zh) | 2022-08-23 | 2022-08-23 | 应用程序的移植处理方法、装置和介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115421785B (zh) |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120246630A1 (en) * | 2011-03-23 | 2012-09-27 | Secure By Design | System and Method for Automating Installation and Updating of Third Party Software |
CN107038041B (zh) * | 2016-12-27 | 2021-03-02 | 创新先进技术有限公司 | 数据处理方法、错误码动态兼容方法、装置和*** |
CN113553124B (zh) * | 2021-05-26 | 2022-06-21 | 武汉深之度科技有限公司 | 一种应用程序的运行方法、计算设备及存储介质 |
CN114443343A (zh) * | 2022-02-10 | 2022-05-06 | 小马国炬(玉溪)科技有限公司 | 一种服务接口反馈异常信息方法、装置、设备、存储介质 |
CN114186280B (zh) * | 2022-02-14 | 2022-05-20 | 统信软件技术有限公司 | 一种文件访问方法、计算设备及可读存储介质 |
-
2022
- 2022-08-23 CN CN202211011147.1A patent/CN115421785B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
CN115421785A (zh) | 2022-12-02 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10114630B2 (en) | Management of software and operating system updates required for the process of creating a virtual machine facsimile of an existing physical or virtual machine | |
US8126859B2 (en) | Updating a local version of a file based on a rule | |
US20170124103A1 (en) | Method and Apparatus for Creating System Disk Snapshot of Virtual Machine | |
US9892122B2 (en) | Method and apparatus for determining a range of files to be migrated | |
CN107632929B (zh) | 一种检测内存泄漏的方法和装置 | |
US20230259358A1 (en) | Documentation enforcement during compilation | |
CN113760306A (zh) | 安装软件的方法、装置、电子设备及存储介质 | |
CN115080114B (zh) | 应用程序的移植处理方法、装置和介质 | |
CN110716804A (zh) | 无用资源的自动删除方法、装置、存储介质及电子设备 | |
US20130246347A1 (en) | Database file groups | |
US11418555B1 (en) | Systems and methods for streaming an application via object storage | |
CN112631621A (zh) | 一种依赖包管理方法、装置、服务器及存储介质 | |
CN116880877A (zh) | 虚拟机增强工具升级方法、装置、计算机设备和存储介质 | |
CN115421785B (zh) | 应用程序的移植处理方法、装置和介质 | |
CN114816772B (zh) | 基于兼容层运行的应用的排错方法、排错***及计算设备 | |
CN115454827B (zh) | 兼容性检测方法、***、设备和介质 | |
CN114816816A (zh) | 崩溃堆栈信息处理方法、装置、设备及存储介质 | |
CN115964061A (zh) | 插件更新方法、装置、电子设备和计算机可读存储介质 | |
CN103514089B (zh) | 软件管理器的软件安装检测方法和*** | |
CN113590225B (zh) | 贴图检测方法、装置、电子设备及存储介质 | |
CN114095494B (zh) | 一种用于快速下载文件的方法和*** | |
US12013774B2 (en) | Verification of core file debugging resources | |
CN111638903B (zh) | 不同软件版本的差异信息生成方法及装置 | |
CN112947846A (zh) | 对象存储***的批处理任务执行方法、装置及电子设备 | |
CN117008837A (zh) | 一种磁盘的分区挂载方法、装置、设备及存储介质 |
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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |