CN105338025B - 调用组件方法、系统、客户端及集中组件方法和服务器 - Google Patents

调用组件方法、系统、客户端及集中组件方法和服务器 Download PDF

Info

Publication number
CN105338025B
CN105338025B CN201410347726.2A CN201410347726A CN105338025B CN 105338025 B CN105338025 B CN 105338025B CN 201410347726 A CN201410347726 A CN 201410347726A CN 105338025 B CN105338025 B CN 105338025B
Authority
CN
China
Prior art keywords
component
client
application
information
server
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
Application number
CN201410347726.2A
Other languages
English (en)
Other versions
CN105338025A (zh
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.)
Alibaba Group Holding Ltd
Original Assignee
Alibaba Group Holding Ltd
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 Alibaba Group Holding Ltd filed Critical Alibaba Group Holding Ltd
Priority to CN201410347726.2A priority Critical patent/CN105338025B/zh
Publication of CN105338025A publication Critical patent/CN105338025A/zh
Application granted granted Critical
Publication of CN105338025B publication Critical patent/CN105338025B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Stored Programmes (AREA)

Abstract

本申请实施例公开了一种调用组件方法、系统、客户端及集中组件方法和服务器,所述调用组件的方法包括:服务器接收第一客户端发来的描述应用及应用中所包含组件的应用信息,生成与所述应用中包含的组件相对应的组件描述文件集;第二客户端读取所述服务器上组件描述文件集中的第一组件对应的第一组件描述文件;第二客户端根据第一组件描述文件,查找第一组件在所述服务器上的存储位置,下载第一组件;第二客户端安装第一组件至第二客户端的预设地址;第二客户端调用安装在预设地址的第一组件以处理数据。本申请公开的调用组件方法、系统、客户端及集中组件方法和服务器,可以提高调用组件的效率并节省网络资源。

Description

调用组件方法、系统、客户端及集中组件方法和服务器
技术领域
本申请涉及数据通信技术领域,特别涉及调用组件方法、系统、客户端及集中组件方法和服务器。
背景技术
应用被广泛应用于计算机、手机等电子设备。一个应用中通常可以包括多个组件。一个客户端上的应用在处理数据的过程中,可能需要采用另一客户端上的应用包含的组件处理数据的结果。调用组件的方法应运而生。
现有的调用组件的方法通常采用网络服务(web service)的方法,例如远程过程调用(Remote Procedure Call,简称RPC)的方法。所述远程过程调用方法的流程主要包括:第一客户端上的第一应用处理数据过程中,需要获取该数据在第二客户端上第二应用的组件A的处理结果时,通常可以将所述第一客户端与所述第二客户端都接入同一通信网络,两个客户端之间可以预先约定好数据传输的接口,利用所述通信网络,第一客户端将需要处理的数据从第一客户端发送至第二客户端,第二客户端上的组件A处理该数据,并将该数据的处理结果通过所述通信网络返回至第一客户端的第一应用。
在实现本申请过程中,发明人发现现有技术中至少存在如下问题:当某一客户端上的一个组件需要同时被多台客户端调用时,被调用的组件需要逐一处理各个客户端发来的数据;被调用的组件处理其中一个客户端发来的数据时,其他需要调用该组件的客户端可能因为等待调用该组件处理的结果而处于空闲状态。所述的远程调用的方法不能合理利用上述空闲状态的客户端资源,降低了调用组件的效率。
发明内容
本申请实施例的目的是提供一种调用组件方法、系统、客户端及集中组件方法和服务器,以提高调用组件的效率。
为解决上述技术问题,本申请实施例提供的调用组件方法、系统、客户端及集中组件方法和服务器是这样实现的:
一种调用组件的方法,包括:服务器接收第一客户端发来的描述应用及应用中所包含组件的应用信息,生成与所述应用中包含的组件相对应的组件描述文件集;第二客户端读取所述服务器上组件描述文件集中的第一组件对应的第一组件描述文件;第二客户端根据第一组件描述文件,查找第一组件在所述服务器上的存储位置,从所述存储位置下载第一组件;第二客户端安装第一组件至第二客户端的预设地址;第二客户端调用安装在预设地址的第一组件以处理数据。
一种调用组件的方法,包括:包含第一应用及第一应用的应用信息的客户端读取所述服务器上组件描述文件集中的第一组件对应的第一组件描述文件;所述客户端根据第一组件描述文件,查找第一组件在所述服务器上的存储位置,从所述存储位置下载第一组件;所述客户端安装第一组件至所述客户端的预设地址;所述客户端调用安装在预设地址的第一组件以处理数据。
一种集中组件的方法,包括:服务器接收第一客户端发来的描述应用及应用中所包含组件的应用信息,生成与所述应用中包含的组件相对应的组件描述文件集;具体地,服务器接收第一客户端发来的应用信息;服务器比对接收到的应用信息中的组件信息与已存储的组件信息,查找所述接收到的应用信息中未存储的组件信息;服务器将未存储的组件信息,以及与所述未存储的组件信息对应的组件程序存储到服务器上;服务器根据所述未存储的组件信息生成相应的组件描述文件,所述一个或多个组件描述文件组成组件描述文件集。
一种调用组件的系统,包括:服务器和第二客户端;其中,所述服务器,用于接收第一客户端发来的描述应用及应用中所包含组件的应用信息,生成与所述应用的组件相对应的组件描述文件;所述第二客户端,用于读取服务器上组件描述文件集中第一组件对应的第一组件描述文件;根据第一组件描述文件,查找所述第一组件在服务器上的存储位置,从所述存储位置下载第一组件;安装第一组件至第二客户端的预设地址;调用安装在所述预设地址的第一组件以处理数据。
一种调用组件的客户端,包括:文件读取单元、组件查找下载单元、安装单元和组件调用单元;其中,所述文件读取单元,用于读取服务器上组件描述文件集中第一组件对应的第一组件描述文件;所述组件查找下载单元,用于根据第一组件描述文件,查找第一组件在服务器的存储位置,从所述存储位置下载第一组件;所述安装单元,用于安装所述第一组件至客户端的预设地址;所述组件调用单元,用于调用安装在预设地址的第一组件处理数据。
一种集中组件的服务器,包括:应用信息接收单元、组件信息比对单元、组件存储单元和描述文件生成单元;其中,所述应用信息接收单元,用于接收客户端发来的描述应用及应用中所包含组件的应用信息;所述应用信息包括:应用名称、操作时间、组件信息、组件程序和组件调用信息;所述组件信息比对单元,用于比对接收到的应用信息中的组件信息与已存储的组件信息,查找应用信息中未存储的组件信息;所述组件存储单元,用于存储所述未存储的组件信息、以及与所述未存储的组件信息对应的组件程序;所述描述文件生成单元,用于根据所述未存储的组件信息生成相应的组件描述文件;一个或多个组件描述文件组成组件描述文件集。
由以上本申请实施例提供的技术方案可见,本申请实施例公开的调用组件方法、系统、客户端及集中组件方法和服务器,当不同客户端需要同时调用同一组件时,不同客户端可以同时下载所述被调用组件并安装在各自的预设地址中,各客户端可以在本地的预设地址中调用安装好的组件来处理数据,而不需要等待通信网络中的其他客户端调用组件过程结束。因此,本申请实施例公开的调用组件的方法及系统提高了调用组件的效率。
本申请公开的调用组件方法、系统、客户端及集中组件方法和服务器实现的另一技术效果包括:客户端下载并安装调用组件至本地,当客户端再次调用该组件时,可以直接调用安装在本地的组件,不需要再次利用网络服务调用组件,节省了网络资源。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请中记载的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1是本申请一种调用组件的方法的一个实施例的流程图;
图2是本申请一种调用组件的方法以客户端为主体的一个实施例的流程图;
图3是本申请一种调用组件的系统的一个实施例的功能模块图;
图4是本申请一种调用组件的系统中实施例中客户端的功能模块图;
图5是本申请系统实施例中客户端的组件查找下载单元的功能模块图;
图6是本申请系统实施例中客户端的组件安装调用单元的功能模块图;
图7是本申请一种调用组件的系统实施例中服务器的功能模块图。
具体实施方式
本申请实施例提供一种调用组件方法、系统、客户端及集中组件方法和服务器。
为了使本技术领域的人员更好地理解本申请中的技术方案,下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都应当属于本申请保护的范围。
图1是本申请调用组件的方法的一个实施例的流程图。如图1所示,所述调用组件的方法可以包括:
S101:服务器接收第一客户端发来的描述应用及应用中所包含组件的应用信息,生成与所述应用中包含的组件相对应的组件描述文件集。
在计算机领域,客户端与服务器相对应,客户端通常包括:包含了为客户提供本地服务的程序的软件或硬件。
通常客户端上可以包含一个或多个应用,每个应用都能实现不同的功能。客户端上的一个应用可以包括多个组件,每个组件可以提供一种服务。例如,客户端包含的一个应用为计算器,可以实现计算功能。该应用中包含的组件可以包括提供加法运算的组件和提供减法运算的组件等。每一应用可以有对应的应用信息,所述应用信息可以用于描述该应用的应用名称、组件信息、组件程序、调用时间等信息。例如,应用B可以包含组件B1、组件B2和组件B3,应用A需要应用B中的组件B1、B2,则应用信息中可以包括描述该调用关系的信息,如:(A,B1);(A,B2)。
每一应用开始运行时,客户端可以将用于描述应用的应用信息发送至服务器。例如,客户端A可以包括应用A。所述应用A可以包括组件A1。客户端B可以包括应用B,所述应用B可以包括组件B1、B2。应用A和应用B在开始运行时,客户端A和客户端B可以分别将应用信息发送至服务器。所述应用信息可以包括:应用名称、操作时间、组件信息、组件程序和组件调用信息等。
服务器可以接收每一客户端发来的用于描述应用以及应用中包含的组件的应用信息。例如,服务器可以接收客户端A发来的描述应用A以及应用A中包含的组件的应用信息,服务器还可以接收客户端B发来的描述应用B以及应用B中包含的组件的应用信息。服务器可以将所述应用信息存储在服务器的存储设备中,例如可以存储在服务器的组件仓库中。
服务器接收到客户端发来的应用信息后,可以根据所述应用信息,生成与应用中包含的组件对应的组件描述文件。每一组件都可以生成对应的组件描述文件。所述组件描述文件中可以包含组件的基本信息,例如可以包括该组件程序的唯一标识、组件程序存放路径、组件程序的版本号等信息。服务器生成的一个或多个组件描述文件可以组成组件描述文件集。
服务器接收第一客户端发来的描述应用及应用中所包含组件的应用信息,生成与所述应用中包含的组件相对应的组件描述文件集,具体可以包括:服务器可以接收第一客户端发来的应用信息。所述应用信息可以包括:应用名称、操作时间、组件信息、组件程序和组件调用信息等。服务器可以将接收的应用信息存储在服务器上预设的组件仓库中。所述应用信息可以由第一客户端在预设时间自动发送给服务器,也可以由第一客户端接收到发送指示后发送给服务器。
服务器可以比对接收到的应用信息中的组件信息与已存储的组件信息,查找应用信息中未存储的组件信息。所述已存储的组件信息可以存储在组件仓库中。所述服务器比对接收到的应用信息中的组件信息与已存储的组件信息包括:比对组件信息中组件程序的名称、组件程序的版本号和组件程序的大小等信息。
若所述接收到的应用信息中包含未存储的组件信息,即包含与已存储的组件信息不完全相同的组件信息,服务器可以将所述未存储的组件信息,以及与所述未存储的组件信息对应的组件程序存储到服务器上,例如存储到组件仓库中。
服务器可以根据所述未存储的组件信息生成相应的组件描述文件。所述服务器生成的一个或多个组件描述文件可以组成组件描述文件集。
S102:第二客户端读取所述服务器上组件描述文件集中的第一组件对应的第一组件描述文件。
第二客户端可以用于调用组件。所述第二客户端可以包含第一应用。所述第二客户端可以根据第一应用的应用信息中的调用信息,确定所述第二客户端需要调用的第一组件。所述第二客户端可以读取服务器上组件描述文件集中与所述第一组件对应的第一组件描述文件。所述第二客户端可以存储所述第一组件描述文件至第二客户端的存储设备。所述第一组件描述文件可以包括:第一组件程序的唯一标识、第一组件程序存放路径和第一组件程序的版本号等信息。
例如,第二客户端上应用B的应用信息中包含的调用信息包括:调用应用A中的A1组件。则第二客户端可以读取服务器上与A1组件对应的组件描述文件,并可以将所述与A1对应的组件描述文件存储至第二客户端的存储设备上。
S103:第二客户端根据第一组件描述文件,查找第一组件在所述服务器上的存储位置,从所述存储位置下载第一组件。
所述第二客户端可以包含需要调用第一组件的第一应用。所述第二客户端可以根据第一组件描述文件,查找所述第一组件在服务器上的存储位置。所述第一组件描述文件可以用于描述第一组件的基本信息,可以包括:组件程序的唯一标识、组件程序存放路径和组件程序的版本号等信息。第二客户端根据查找到的第一组件在服务器上的存储位置,可以从所述存储位置下载所述第一组件。所述下载,可以是计算机之间交换数据的一种方式,例如一台计算机与提供文件的计算机取得联系并将提供文件的计算机上的文件搬到自己的计算机中来。
例如:组件A1的描述文件可以用于描述组件A1的基本信息,可以包括:组件A1的标识、组件A1的名称、组件A1的程序在服务器上的存放路径、组件A1的程序的版本号。第二客户端将组件A1的描述文件存储至第二客户端的存储设备后,包含应用B的第二客户端可以根据描述文件中组件A1的程序在服务器上的存放路径下载组件A1。假设组件A1在服务器上的存放路径为http://www.example.com/examplefile.jar,则第二客户端可以根据上述的路径下载组件A1。
进一步地,第二客户端下载所述第一组件后,还可以将所述客户端下载所述第一组件的下载信息发送至所述服务器。所述下载信息可以包括:下载时间、调用该组件的应用名称和组件程序的唯一标识等。
例如,包含应用B的第二客户端下载组件A1后,可以将第二客户端下载组件A1的下载信息发送至服务器,所述的下载信息可以包括:应用B的应用名称、组件A1的程序的唯一标识、下载的时间等信息。
上述步骤中将所述下载信息发至服务器可以便于服务器管理组件的调用信息。
S104:第二客户端安装第一组件至第二客户端的预设地址。
第二客户端可以包含需要调用第一组件的第一应用。所述客户端下载第一组件后,可以将所述第一组件安装至第二客户端上的预设地址。在计算机领域中,软件安装可以包括:将程序文件和文件夹添加到硬盘并将相关数据添加到注册表,以使软件能够正常运行。所述预设地址可以用于安装第一应用需要调用的组件。所述预设地址可以包括:第一应用的程序存储路径。例如,可以在客户端第一应用的程序存储路径中设置一个第一应用的容器(container)。所述容器用于安装第一应用的组件。所述第一应用可以通过预设的通信方式读取安装在所述容器中的组件。采用所述container模式安装第一组件,使用方式与原有开发模式一样,可以在不改变原有应用系统架构的基础上,实现组件的调用、维护,从而降低了维护成本。
S105:第二客户端调用安装在预设地址的第一组件以处理数据。
所述第二客户端可以调用所述安装在预设地址中的第一组件来处理数据。例如,第一应用可以调用安装在容器中的第一组件以处理数据。
下面介绍本申请以需要调用组件的客户端为主体的调用组件的方法的实施例。图2是本申请以客户端为主体的调用组件的方法实施例的流程图。如图2所示,所述调用组件的方法可以包括:
S201:包含第一应用及第一应用的应用信息的客户端读取服务器上组件描述文件集中与第一组件对应的第一组件描述文件。
客户端可以用于调用组件。所述客户端可以包含调用第一组件的第一应用。所述客户端可以根据第一应用的调用信息,确定所述客户端需要调用的第一组件。所述客户端可以读取服务器上组件描述文件集中与所述第一组件对应的第一组件描述文件。所述客户端可以存储所述第一组件描述文件至客户端的存储设备。
例如,客户端上应用B的应用信息中包含的调用信息包括:调用应用A中的A1组件,则客户端可以读取服务器上与A1组件对应的组件描述文件,并将所述与A1对应的组件描述文件存储至客户端的存储设备上。
S202:所述客户端根据第一组件描述文件,查找第一组件在所述服务器上的存储位置,从所述存储位置下载第一组件。
所述客户端可以包含需要调用第一组件的第一应用。所述客户端可以根据存储的第一组件描述文件,查找所述第一组件在服务器上的存储位置。所述第一组件描述文件可以用于描述第一组件的基本信息,可以包括:组件程序的唯一标识、组件程序存放路径和组件程序的版本号等信息。客户端根据查找到的第一组件在服务器上的存储位置,可以从所述存储位置下载所述第一组件。所述下载,可以是计算机之间交换数据的一种方式,例如一台计算机与提供文件的计算机取得联系并将提供文件的计算机上的文件搬到自己的计算机中来。
例如:组件A1的描述文件可以用于描述组件A1的基本信息,可以包括:组件A1的标识、组件A1的名称、组件A1的程序在服务器上的存放路径、组件A1的程序的版本号。客户端将组件A1的描述文件存储至客户端的存储设备后,包含应用B的客户端可以根据描述文件中组件A1的程序在服务器上的存放路径下载组件A1。假设组件A1在服务器上的存放路径为http://www.example.com/examplefile.jar,则客户端可以根据上述的路径下载组件A1。
进一步地,客户端下载所述第一组件后,还可以将所述客户端下载所述第一组件的下载信息发送至所述服务器。所述下载信息可以包括:下载时间、调用该组件的应用名称和组件程序的唯一标识等。
例如,包含应用B的客户端下载组件A1后,可以将客户端下载组件A1的下载信息发送至服务器,所述的下载信息可以包括:应用B的应用名称、组件A1的程序的唯一标识、下载的时间等信息。
上述步骤中将所述下载信息发至服务器可以便于服务器管理组件的调用信息。
S203:所述客户端安装第一组件至所述客户端的预设地址。
客户端可以包含需要调用第一组件的第一应用。所述客户端下载第一组件后,可以将所述第一组件安装至客户端上的预设地址。在计算机领域中,软件安装可以包括:将程序文件和文件夹添加到硬盘并将相关数据添加到注册表,以使软件能够正常运行。所述预设地址可以用于安装第一应用需要调用的组件。所述预设地址可以包括:第一应用的程序存储路径。例如,可以在客户端第一应用的程序存储路径中设置一个第一应用的容器(container)。所述容器用于安装第一应用的组件。所述第一应用可以通过预设的通信方式读取安装在所述容器中的组件。采用所述container模式安装第一组件,使用方式与原有开发模式一样,可以在不改变原有应用系统架构的基础上,实现组件的调用、维护,从而降低了维护成本。
S204:所述客户端调用安装在预设地址的第一组件以处理数据。
所述客户端可以调用所述安装在预设地址中的第一组件来处理数据。例如,第一应用可以调用安装在容器中的第一组件以处理数据。
上述实施例公开的调用组件方法,服务器可以接收各个客户端发来的应用信息,并为应用中的每一组件生成对应的组件描述文件。客户端可以根据客户端上第一应用的调用信息,读取服务器上被调用的第一组件的第一组件描述文件并存储至客户端的存储设备,客户端可以查找所述存储的第一组件描述文件中记录的第一组件在服务器上的存储位置,从查找到的存储位置处下载所述第一组件并安装在客户端的预设地址中,客户端可以调用预设地址中安装好的第一组件来处理数据。上述调用组件方法实施例,当不同客户端需要同时调用同一组件时,不同客户端可以同时下载所述被调用组件并安装在各自的预设地址中,客户端可以在本地的预设地址中调用安装好的组件来处理数据,而不需要等待网络中的其他客户端调用组件过程结束。本申请公开的调用组件方法提高了调用组件的效率。本申请公开的调用组件方法的另一技术效果是:客户端下载并安装调用组件至本地,当客户端再次调用该组件时,可以直接调用安装在本地的组件,不需要再次利用网络服务调用组件,节省了网络资源。
图3是本申请一种调用组件的系统的一个实施例的功能模块图。如图3所示,所述调用组件的系统可以包括:服务器100和客户端200。其中,
所述服务器100,可以用于集中组件,包括:接收描述应用及应用中所包含组件的应用信息,生成与所述应用的组件相对应的组件描述文件。
所述客户端200,可以包含需要调用第一组件的第一应用;所述客户端200,可以用于读取服务器上组件描述文件集中的第一组件对应的第一组件描述文件;根据第一组件描述文件,可以查找所述第一组件在服务器上的存储位置,从所述存储位置下载第一组件;安装第一组件至客户端的预设地址;调用安装在所述预设地址的第一组件以处理数据。
图4是本申请一种调用组件的系统实施例中客户端的功能模块图;如图4所示,所述客户端200,可以包括:文件读取单元210、组件查找下载单元220、安装单元230和组件调用单元240。其中,
所述文件读取单元210,可以用于读取服务器上组件描述文件集中的第一组件对应的第一组件描述文件。
所述组件查找下载单元220,可以用根据第一组件描述文件,查找第一组件在服务器的存储位置,从所述存储位置下载所述第一组件。
图5是本申请系统实施例中客户端的组件查找下载单元的功能模块图。如图5所示,所述组件查找下载单元220,可以包括:组件查找单元221和组件下载单元222。其中,
所述组件查找单元221,可以用于根据第一组件描述文件,查找所述第一组件在服务器的存储位置。
所述组件下载单元222,可以用于从组件查找单元221中查找到的第一组件在服务器的存储位置下载第一组件。
进一步地,所述组件查找下载单元220还可以包括:下载信息发送单元223。所述下载信息发送单元223,可以用于发送组件下载单元222中客户端下载第一组件的下载信息至服务器。
所述安装单元230,可以用于安装第一组件至客户端的预设地址。
图6是本申请系统实施例中客户端的组件安装调用单元的功能模块图。如图6所示,所述安装单元230,可以包括:预设地址单元231和组件安装单元232。其中,
所述预设地址单元231,可以用于确定客户端上用于安装组件的预设地址。
所述组件安装单元232,可以用于将组件下载单元222中下载的第一组件安装至预设地址单元231中的预设地址。
所述组件调用单元240,可以用于调用安装单元230安装在预设地址的第一组件以处理数据。
进一步地,所述客户端200还可以包括:文件存储单元250。所述文件存储单元250,可以用于存储所述文件读取单元210中读取的第一组件描述文件。
图7是本申请一种调用组件的系统实施例中服务器的功能模块图;如图7所示,所述服务器100可以包括:应用信息接收单元110、组件信息比对单元120、组件存储单元130和描述文件生成单元140。其中,
所述应用信息接收单元110,可以用于接收第一客户端发来的应用信息。所述应用信息可以包括:应用名称、操作时间、组件信息、组件程序和组件调用信息等。所述应用信息可以由第一客户端在预设时间自动发送给服务器,也可以由第一客户端接收到发送指示后发送给服务器。
所述组件信息比对单元120,可以用于比对接收到的应用信息中的组件信息与已存储的组件信息,查找应用信息中未存储的组件信息。
所述组件存储单元130,可以用于存储所述未存储的组件信息,以及与所述未存储的组件信息对应的组件程序。
所述描述文件生成单元140,可以用于根据所述未存储的组件信息生成相应的组件描述文件。一个或多个组件描述文件可以组成组件描述文件集。
上述公开的一种调用组件的系统实施例,服务器可以接收第一客户端发来的应用信息,并为应用中的每一组件生成对应的组件描述文件。第二客户端可以根据需要调用第一组件的第一应用的应用信息,读取服务器上被调用的第一组件的第一组件描述文件并存储至客户端的存储设备,第二客户端可以查找所述存储的第一组件描述文件中记录的第一组件在服务器上的存储位置,从查找到的存储位置处下载所述第一组件并安装在第二客户端的预设地址中,第二客户端可以调用预设地址中安装好的第一组件来处理数据。上述调用组件的系统可以实现本申请调用组件的方法实施例所取得的技术效果。
在20世纪90年代,对于一个技术的改进可以很明显地区分是硬件上的改进(例如,对二极管、晶体管、开关等电路结构的改进)还是软件上的改进(对于方法流程的改进)。然而,随着技术的发展,当今的很多方法流程的改进已经可以视为硬件电路结构的直接改进。设计人员几乎都通过将改进的方法流程编程到硬件电路中来得到相应的硬件电路结构。因此,不能说一个方法流程的改进就不能用硬件实体模块来实现。例如,可编程逻辑器件(Programmable Logic Device,PLD)(例如现场可编程门阵列(Field Programmable GateArray,FPGA))就是这样一种集成电路,其逻辑功能由用户对器件编程来确定。由设计人员自行编程来把一个数字系统“集成”在一片PLD上,而不需要请芯片制造厂商来设计和制作专用的集成电路芯片2。而且,如今,取代手工地制作集成电路芯片,这种编程也多半改用“逻辑编译器(logic compiler)”软件来实现,它与程序开发撰写时所用的软件编译器相类似,而要编译之前的原始代码也得用特定的编程语言来撰写,此称之为硬件描述语言(Hardware Description Language,HDL),而HDL也并非仅有一种,而是有许多种,如ABEL(Advanced Boolean Expression Language)、AHDL(Altera Hardware DescriptionLanguage)、Confluence、CUPL(Cornell University Programming Language)、HDCal、JHDL(Java Hardware Description Language)、Lava、Lola、MyHDL、PALASM、RHDL(RubyHardware Description Language)等,目前最普遍使用的是VHDL(Very-High-SpeedIntegrated Circuit Hardware Description Language)与Verilog2。本领域技术人员也应该清楚,只需要将方法流程用上述几种硬件描述语言稍作逻辑编程并编程到集成电路中,就可以很容易得到实现该逻辑方法流程的硬件电路。
控制器可以按任何适当的方式实现,例如,控制器可以采取例如微处理器或处理器以及存储可由该(微)处理器执行的计算机可读程序代码(例如软件或固件)的计算机可读介质、逻辑门、开关、专用集成电路(Application Specific Integrated Circuit,ASIC)、可编程逻辑控制器和嵌入微控制器的形式,控制器的例子包括但不限于以下微控制器:ARC625D、Atmel AT91SAM、Microchip PIC18F26K20以及Silicone Labs C8051F320,存储器控制器还可以被实现为存储器的控制逻辑的一部分。
本领域技术人员也知道,除了以纯计算机可读程序代码方式实现控制器以外,完全可以通过将方法步骤进行逻辑编程来使得控制器以逻辑门、开关、专用集成电路、可编程逻辑控制器和嵌入微控制器等的形式来实现相同功能。因此这种控制器可以被认为是一种硬件部件,而对其内包括的用于实现各种功能的装置也可以视为硬件部件内的结构。或者甚至,可以将用于实现各种功能的装置视为既可以是实现方法的软件模块又可以是硬件部件内的结构。
上述实施例阐明的系统、装置、模块或单元,具体可以由计算机芯片或实体实现,或者由具有某种功能的产品来实现。
为了描述的方便,描述以上装置时以功能分为各种单元分别描述。当然,在实施本申请时可以把各单元的功能在同一个或多个软件和/或硬件中实现。
通过以上的实施方式的描述可知,本领域的技术人员可以清楚地了解到本申请可借助软件加必需的通用硬件平台的方式来实现。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/输出接口、网络接口和内存。该计算机软件产品可以包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本申请各个实施例或者实施例的某些部分所述的方法。该计算机软件产品可以存储在内存中,内存可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM)。内存是计算机可读介质的示例。计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括短暂电脑可读媒体(transitory media),如调制的数据信号和载波。
本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于系统实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
本申请可用于众多通用或专用的计算机系统环境或配置中。例如:个人计算机、服务器计算机、手持设备或便携式设备、平板型设备、多处理器系统、基于微处理器的系统、置顶盒、可编程的消费电子设备、网络PC、小型计算机、大型计算机、包括以上任何系统或设备的分布式计算环境等等。
本申请可以在由计算机执行的计算机可执行指令的一般上下文中描述,例如程序模块。一般地,程序模块包括执行特定任务或实现特定抽象数据类型的例程、程序、对象、组件、数据结构等等。也可以在分布式计算环境中实践本申请,在这些分布式计算环境中,由通过通信网络而被连接的远程处理设备来执行任务。在分布式计算环境中,程序模块可以位于包括存储设备在内的本地和远程计算机存储介质中。
虽然通过实施例描绘了本申请,本领域普通技术人员知道,本申请有许多变形和变化而不脱离本申请的精神,希望所附的权利要求包括这些变形和变化而不脱离本申请的精神。

Claims (21)

1.一种调用组件的方法,其特征在于,包括:
服务器接收并存储第一客户端发来的描述应用及应用中所包含组件的应用信息,生成与所述应用中包含的组件相对应的组件描述文件集;
第二客户端读取所述服务器上所述组件描述文件集中的第一组件对应的第一组件描述文件;
第二客户端根据第一组件描述文件,查找第一组件在所述服务器上的存储位置,从所述存储位置下载第一组件;
第二客户端安装第一组件至第二客户端的预设地址;
第二客户端调用安装在所述预设地址的第一组件以处理数据。
2.如权利要求1所述的一种调用组件的方法,其特征在于,所述应用信息包括:应用名称、操作时间、组件信息、组件程序和组件调用信息。
3.一种调用组件的方法,其特征在于,包括:
包含第一应用及第一应用的应用信息的客户端读取服务器上组件描述文件集中与第一组件对应的第一组件描述文件;
所述客户端根据第一组件描述文件,查找第一组件在所述服务器上的存储位置,从所述存储位置下载第一组件;
所述客户端安装第一组件至所述客户端的预设地址;
所述客户端调用安装在所述预设地址的第一组件以处理数据。
4.如权利要求3所述的一种调用组件的方法,其特征在于,所述应用信息包括:应用名称、操作时间、组件信息、组件程序和组件调用信息。
5.如权利要求4所述的一种调用组件的方法,其特征在于,所述包含第一应用及第一应用的应用信息的客户端读取服务器上组件描述文件集中的第一组件对应的第一组件描述文件,包括:
所述客户端根据客户端上第一应用的应用信息中包含的组件调用信息,确定第一组件;
所述客户端读取所述服务器上所述组件描述文件集中与所述第一组件对应的第一组件描述文件。
6.如权利要求3所述的一种调用组件的方法,其特征在于,所述第一组件描述文件包括:第一组件程序的唯一标识、第一组件程序存放路径和第一组件程序的版本号。
7.如权利要求3所述的一种调用组件的方法,其特征在于,所述客户端的预设地址用于安装第一应用调用的组件,所述客户端的预设地址包括:所述客户端上第一应用的程序存储路径。
8.如权利要求7所述的一种调用组件的方法,其特征在于,所述客户端的预设地址包括:设置在所述客户端第一应用的程序存储路径中的第一应用的容器;所述容器用于安装第一应用的组件。
9.如权利要求3所述的一种调用组件的方法,其特征在于,还包括:所述客户端读取所述服务器上组件描述文件集中的第一组件对应的第一组件描述文件后,所述客户端存储第一组件描述文件至所述客户端。
10.如权利要求3所述的一种调用组件的方法,其特征在于,还包括:所述客户端下载第一组件后,所述客户端将所述客户端下载第一组件的下载信息发送至所述服务器。
11.一种集中组件的方法,所述方法在服务器执行,其特征在于,包括:所述服务器接收第一客户端发来的描述应用及应用中所包含组件的应用信息,生成与所述应用中包含的组件相对应的组件描述文件集;具体地,
服务器接收第一客户端发来的应用信息;
所述服务器比对接收到的应用信息中的组件信息与已存储的组件信息,查找所述接收到的应用信息中未存储的组件信息;
所述服务器将所述未存储的组件信息,以及与所述未存储的组件信息对应的组件程序存储到所述服务器上;
所述服务器根据所述未存储的组件信息生成相应的组件描述文件,所述一个或多个组件描述文件组成组件描述文件集。
12.如权利要求11所述的集中组件的方法,其特征在于,所述服务器比对接收到的应用信息中的组件信息与已存储的组件信息,包括:比对组件程序的名称、组件程序的版本号和组件程序的大小。
13.如权利要求11所述的集中组件的方法,其特征在于,所述未存储的组件信息包括:所述接收到的应用信息中与已存储的组件信息不完全相同的组件信息。
14.如权利要求11所述的集中组件的方法,其特征在于,所述第一客户端发来的应用信息,包括:所述第一客户端在预设时间自动发送给所述服务器的应用信息,或者,所述第一客户端接收到发送指示后发送给所述服务器的应用信息。
15.一种调用组件的系统,其特征在于,包括:服务器和第二客户端;其中,
所述服务器,用于集中组件,包括:接收第一客户端发来的描述应用及应用中所包含组件的应用信息,生成与所述应用的组件相对应的组件描述文件;
所述第二客户端,用于读取所述服务器上组件描述文件集中第一组件对应的第一组件描述文件;根据第一组件描述文件,查找所述第一组件在所述服务器上的存储位置,从所述存储位置下载第一组件;安装第一组件至所述第二客户端的预设地址;调用安装在所述预设地址的第一组件以处理数据。
16.一种调用组件的客户端,其特征在于,包括:文件读取单元、组件查找下载单元、安装单元和组件调用单元;其中,
所述文件读取单元,用于读取服务器上组件描述文件集中第一组件对应的第一组件描述文件;
所述组件查找下载单元,用于根据第一组件描述文件,查找第一组件在所述服务器的存储位置,从所述存储位置下载第一组件;
所述安装单元,用于安装所述第一组件至所述客户端的预设地址;
所述组件调用单元,用于调用安装在所述预设地址的第一组件处理数据。
17.如权利要求16所述的一种调用组件的客户端,其特征在于,所述组件查找下载单元,包括:组件查找单元和组件下载单元;其中,
所述组件查找单元,用于根据第一组件描述文件,查找所述第一组件在所述服务器的存储位置;
所述组件下载单元,用于从所述组件查找单元中查找到的第一组件在所述服务器的存储位置下载第一组件。
18.如权利要求17所述的一种调用组件的客户端,其特征在于,所述组件查找下载单元,还包括:下载信息发送单元;
所述下载信息发送单元,用于发送组件下载单元中所述客户端下载第一组件的下载信息至所述服务器。
19.如权利要求16所述的一种调用组件的客户端,其特征在于,所述安装单元,包括:预设地址单元和组件安装单元;其中,
所述预设地址单元,用于确定所述客户端上用于安装组件的预设地址;
所述组件安装单元,用于将所述组件下载单元中下载的第一组件安装至所述预设地址单元中的预设地址。
20.如权利要求16所述的一种调用组件的客户端,其特征在于,所述客户端还包括:文件存储单元;所述文件存储单元,用于存储所述文件读取单元中读取的第一组件描述文件。
21.一种集中组件的服务器,其特征在于,包括:应用信息接收单元、组件信息比对单元、组件存储单元和描述文件生成单元;其中,
所述应用信息接收单元,用于接收客户端发来的描述应用及应用中所包含组件的应用信息;所述应用信息包括:应用名称、操作时间、组件信息、组件程序和组件调用信息;
所述组件信息比对单元,用于比对接收到的应用信息中的组件信息与已存储的组件信息,查找应用信息中未存储的组件信息;
所述组件存储单元,用于存储所述未存储的组件信息、以及与所述未存储的组件信息对应的组件程序;
所述描述文件生成单元,用于根据所述未存储的组件信息生成相应的组件描述文件;一个或多个组件描述文件组成组件描述文件集。
CN201410347726.2A 2014-07-21 2014-07-21 调用组件方法、系统、客户端及集中组件方法和服务器 Active CN105338025B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201410347726.2A CN105338025B (zh) 2014-07-21 2014-07-21 调用组件方法、系统、客户端及集中组件方法和服务器

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201410347726.2A CN105338025B (zh) 2014-07-21 2014-07-21 调用组件方法、系统、客户端及集中组件方法和服务器

Publications (2)

Publication Number Publication Date
CN105338025A CN105338025A (zh) 2016-02-17
CN105338025B true CN105338025B (zh) 2019-04-09

Family

ID=55288304

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201410347726.2A Active CN105338025B (zh) 2014-07-21 2014-07-21 调用组件方法、系统、客户端及集中组件方法和服务器

Country Status (1)

Country Link
CN (1) CN105338025B (zh)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109189591B (zh) * 2018-08-30 2022-04-12 百度在线网络技术(北京)有限公司 用于调用应用组件的方法和装置
CN115906104A (zh) * 2023-02-23 2023-04-04 国网山东省电力公司泰安供电公司 一种二次封装后开源组件的安全检测方法及装置

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1916856A (zh) * 2005-08-15 2007-02-21 中兴通讯股份有限公司 一种分布式服务系统的服务提供方法
WO2012142854A1 (zh) * 2011-04-18 2012-10-26 北京新媒传信科技有限公司 一种应用服务平台系统及其实现方法

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1916856A (zh) * 2005-08-15 2007-02-21 中兴通讯股份有限公司 一种分布式服务系统的服务提供方法
WO2012142854A1 (zh) * 2011-04-18 2012-10-26 北京新媒传信科技有限公司 一种应用服务平台系统及其实现方法

Also Published As

Publication number Publication date
CN105338025A (zh) 2016-02-17

Similar Documents

Publication Publication Date Title
CN109002362B (zh) 一种服务方法、装置、系统以及电子设备
CN109669709B (zh) 一种区块链升级的数据迁移方法及数据迁移系统
CN107092475B (zh) 一种交互控件的调用方法及装置
CN104391690A (zh) 一种应用开发系统及方法
CN107038041B (zh) 数据处理方法、错误码动态兼容方法、装置和系统
CN110032358B (zh) 一种应用程序生成方法、装置、设备及系统
CN105589658B (zh) 资源处理方法、系统及服务器、仓库管理方法及装置
US20070282801A1 (en) Dynamically creating and executing an application lifecycle management operation
CN108647032B (zh) 应用加载方法及装置、计算机装置和计算机可读存储介质
CN109947643B (zh) 一种基于a/b测试的实验方案的配置方法、装置及设备
CN113495797B (zh) 一种消息队列及消费者动态创建方法及系统
CN106990979A (zh) 一种配置信息更新方法、系统、客户端及服务器
CN107578338B (zh) 一种业务发布方法、装置及设备
CN111212183B (zh) 一种用于运行寄宿应用的方法、设备及计算机可读介质
US8127271B2 (en) Method and system for accessing a resource implemented in a computer network
CN109343970B (zh) 基于应用程序的操作方法、装置、电子设备及计算机介质
CN111045746B (zh) 代码扩展方法和框架
CN105338025B (zh) 调用组件方法、系统、客户端及集中组件方法和服务器
CN111949297B (zh) 一种区块链智能合约升级方法、装置及电子设备
CN106156050B (zh) 一种数据处理方法及装置
CN110046052A (zh) 一种服务调用方法及装置
CN110941443B (zh) 修改sdk中文件名的方法、装置及电子设备
CN110502251B (zh) 应用安装方法及装置
WO2015007183A1 (en) Methods for adapting a dual-sim terminal, dual-sim terminal, and server
CN111796864A (zh) 一种数据校验的方法及装置

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant