CN102591714A - 一种流程调用方法、系统及应用服务器 - Google Patents
一种流程调用方法、系统及应用服务器 Download PDFInfo
- Publication number
- CN102591714A CN102591714A CN2011104590451A CN201110459045A CN102591714A CN 102591714 A CN102591714 A CN 102591714A CN 2011104590451 A CN2011104590451 A CN 2011104590451A CN 201110459045 A CN201110459045 A CN 201110459045A CN 102591714 A CN102591714 A CN 102591714A
- Authority
- CN
- China
- Prior art keywords
- bpel
- web service
- flow process
- flow
- engine
- 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.)
- Granted
Links
Images
Abstract
本发明实施例公开一种流程调用方法、系统及应用服务器。一种流程调用方法,预先创建Web服务与业务流程执行语言BPEL流程的对应关系,所述方法包括:BPEL引擎接收业务流程服务请求,触发所述BPEL流程;依据预先构建的流程执行顺序,执行所述BPEL流程;判断在所述BPEL流程执行过程中是否需要调用Web服务,如果是,依据所述Web服务与BPEL流程的对应关系,从Web服务容器中获取所述Web服务,并调用所述Web服务,如果否,执行所述BPEL流程,从而在BPEL流程执行过程中,可以根据BPEL流程执行顺序自动调用Web服务。
Description
技术领域
本发明涉及Web服务技术领域,更具体地,特别是涉及一种流程调用方法、系统及应用服务器。
背景技术
随着Web Servcie技术日益成熟和流行,许多企业的很多部门都创建了Web服务。而BPEL(Business Process Execution Language,业务流程执行语言)流程可以在不改变Web服务正常运行的情况下,将多个Web服务集成,生成新的业务流程。
BPEL流程在BPEL引擎上运行。每个BPEL流程创建一个BPEL流程实例,其可以通过抽象的WSDL(Web Services Description Language,Web服务描述语言)接口与服务提供者进行绑定。
然而,服务提供者提供的Web服务被串接,BPEL流程通过WSDL接口无法识别串接的Web服务,在BPEL流程执行过程中,无法调用Web服务,进一步无法根据BPEL流程执行顺序调用Web服务。因此,急需一种流程调用方法,在BPEL流程执行过程中,可以根据BPEL流程执行顺序调用Web服务。
发明内容
有鉴于此,本发明实施例提供一种流程调用方法,实现了在BPEL流程执行过程中,根据BPEL流程执行顺序调用Web服务。
本发明实施例还提供一种流程调用系统及应用服务器,用以保证上述方法在实际中的实现及应用。
基于本发明实施例的一方面,提供一种流程调用方法,预先创建Web服务与业务流程执行语言BPEL流程的对应关系,所述方法包括:
BPEL引擎接收业务流程服务请求,触发所述BPEL流程;
依据预先构建的流程执行顺序,执行所述BPEL流程;
判断在所述BPEL流程执行过程中是否需要调用Web服务,如果是,依据所述Web服务与BPEL流程的对应关系,从Web服务容器中获取所述Web服务,并调用所述Web服务,如果否,执行所述BPEL流程。
优选地,所述业务流程服务请求由Web服务容器接收后,通过消息上下文接口转发至所述BPEL引擎。
优选地,还包括:在BPEL流程执行结束后,将BPEL流程的处理结果通过消息上下文接口反馈到Web服务容器中,再由Web服务容器反馈至发送流程服务请求的客户端。
优选地,所述BPEL引擎通过绑定上下文接口调用Web服务容器中的Web服务。
优选地,在调用所述Web服务之后还包括:将Web服务的执行结果通过绑定上下文接口反馈到所述BPEL引擎。
优选地,所述创建Web服务与BPEL流程的对应关系包括:
Web服务容器依据业务流程,确定业务流程所使用的Web服务,发布到所述Web服务容器中;
BPEL引擎分析业务流程,使用BPEL设计器进行BPEL流程建模,获取BPEL流程,并将所述BPEL流程部署至所述BPEL引擎;
所述BPEL引擎在BPEL流程注册库中注册一个BPEL流程,并通过绑定上下文接口向所述Web服务容器的服务库中注册一个与该BPEL流程对应的Web服务。
基于本发明实施例的另一方面,还提供一种流程调用系统,预先创建Web服务与业务流程执行语言BPEL流程的对应关系,所述系统包括:Web服务容器和BPEL引擎,所述BPEL引擎包括接收单元、执行单元和判断单元;
所述接收单元用于接收业务流程服务请求,触发所述BPEL流程;
所述执行单元,用于依据预先构建的流程执行顺序,执行所述BPEL流程;
所述判断单元,用于判断在所述BPEL流程执行过程中是否需要调用Web服务,如果是,由所述执行单元依据所述Web服务与BPEL流程的对应关系,从Web服务容器中获取所述Web服务,并调用所述Web服务,如果否,由所述执行单元执行所述BPEL流程。
优选地,Web服务容器通过自身的消息上下文接口连接所述BPEL引擎,将所述业务流程服务请求通过所述消息上下文接口转发至所述BPEL引擎,以及将所述BPEL引擎中的BPEL流程的处理结果通过消息上下文接口反馈到Web服务容器中。
优选地,所述BPEL引擎通过自身的绑定上下文接口连接所述Web服务容器,通过所述绑定上下文接口调用Web服务容器中的Web服务,以及将Web服务的执行结果通过绑定上下文接口反馈到所述BPEL引擎。
基于本发明实施例的另一方面,还提供一种应用服务器,包括上述流程调用系统。
在本发明中,预先创建Web服务与业务流程执行语言BPEL流程的对应关系,BPEL引擎接收业务流程服务请求后,触发所述BPEL流程;依据预先构建的流程执行顺序,执行所述BPEL流程;判断在所述BPEL流程执行过程中是否需要调用Web服务,如果是,依据所述Web服务与BPEL流程的对应关系,从Web服务容器中获取所述Web服务,并调用所述Web服务,从而在BPEL流程执行过程中,可以根据BPEL流程执行顺序自动调用Web服务。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明中记载的一些实施例,对于本领域普通技术人员来讲,还可以根据这些附图获得其他的附图。
图1为本发明实施例公开的流程调用方法的流程图;
图2为本发明实施例公开的流程调用方法的子流程图;
图3为本发明实施例公开的流程调用方法的详细流程图;
图4为本发明实施例公开的流程调用系统的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本发明中的技术方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员所获得的所有其他实施例,都应当属于本发明保护的范围。
请参阅图1,其示出了本发明实施例公开的一种流程调用方法的流程图,可以包括以下步骤:
步骤101:BPEL引擎接收业务流程服务请求,触发BPEL流程。
其中,业务流程服务请求中携带有业务流程,且所述业务流程服务请求由Web服务容器接收后,通过自身的消息上下文接口转发至所述BPEL引擎。
本实施例中,在执行步骤101之前,预先创建Web服务与业务流程执行语言BPEL流程的对应关系。对应关系创建过程请参阅图2所示的流程图,可以包括以下步骤:
步骤201:Web服务容器依据业务流程,确定业务流程所使用的Web服务,发布到所述Web服务容器中。
其中,每个业务流程对应一个业务需求,且不同业务需求对应有不同的Web服务,因此Web服务容器可以依据业务流程,确定该业务流程所使用的Web服务。
步骤202:BPEL引擎分析业务流程,使用BPEL设计器进行BPEL流程建模,获取BPEL流程,并将所述BPEL流程部署至所述BPEL引擎。
步骤203:所述BPEL引擎在BPEL流程注册库中注册一个BPEL流程,并通过绑定上下文接口向所述Web服务容器的服务库中注册一个与该BPEL流程对应的Web服务。其中,绑定上下文接口设置在BPEL引擎上。
经过上述步骤201至203,创建了Web服务与BPEL流程的对应关系。
步骤102:依据预先构建的流程执行顺序,执行所述BPEL流程。
其中,不同的业务流程对应有不同的流程执行顺序,在触发BPEL流程后,则可以依据预先构建的流程执行顺序,执行所述BPEL流程。
步骤103:判断在所述BPEL流程执行过程中是否需要调用Web服务,如果是,执行步骤104,如果否,返回执行步骤102。
步骤104:依据所述Web服务与BPEL流程的对应关系,从Web服务容器中获取所述Web服务,并调用所述Web服务。
在本实施例中,BPEL引擎可以通过绑定上下文接口调用Web服务容器中的Web服务。
需要说明的是:在调用所述Web服务之后,Web服务容器通过自身的绑定上下文接口将Web服务的执行结果反馈到所述BPEL引擎。
在BPEL流程执行结束后,BPEL引擎通过自身的消息上下文接口将BPEL流程的处理结果反馈到Web服务容器中,再由Web服务容器反馈至发送流程服务请求的客户端。
本发明实施例公开的流程调用方法的详细流程图如图3所示,图3中充分的表达了,BPEL引擎和Web服务容器在执行BPEL流程的执行过程。
在本发明中,预先创建Web服务与业务流程执行语言BPEL流程的对应关系,BPEL引擎接收业务流程服务请求后,触发所述BPEL流程;依据预先构建的流程执行顺序,执行所述BPEL流程;判断在所述BPEL流程执行过程中是否需要调用Web服务,如果是,依据所述Web服务与BPEL流程的对应关系,从Web服务容器中获取所述Web服务,并调用所述Web服务,从而在BPEL流程执行过程中,可以根据BPEL流程执行顺序自动调用Web服务。
与上述方法实施例相对应,本发明实施例还公开了一种流程调用系统,该系统预先创建Web服务与BPEL流程的对应关系,系统结构示意图如图4所示,可以包括:Web服务容器11和BPEL引擎12,所述BPEL引擎12包括接收单元121、执行单元122和判断单元123。
接收单元121用于接收业务流程服务请求,触发所述BPEL流程。
执行单元122,用于依据预先构建的流程执行顺序,执行所述BPEL流程。
判断单元123,用于判断在所述BPEL流程执行过程中是否需要调用Web服务,如果是,由所述执行单元122依据所述Web服务与BPEL流程的对应关系,从Web服务容器中获取所述Web服务,并调用所述Web服务,如果否,由所述执行单元122执行所述BPEL流程。
在本实施例中,Web服务容器11可以通过自身的消息上下文接口连接所述BPEL引擎12,将所述业务流程服务请求通过所述消息上下文接口转发至所述BPEL引擎12,以及将所述BPEL引擎12中的BPEL流程的处理结果通过消息上下文接口反馈到Web服务容器11中。
BPEL引擎12可以通过自身的绑定上下文接口连接所述Web服务容器11,通过所述绑定上下文接口调用Web服务容器11中的Web服务,以及将Web服务的执行结果通过绑定上下文接口反馈到所述BPEL引擎12。
本实施例所述的系统可以集成到搜索引擎的应用服务器上,也可以单独作为一个实体与搜索引擎服务器相连,另外,需要说明的是,当本发明所述的方法采用软件实现时,可以作为搜索引擎的服务器新增的一个功能,也可以单独编写相应的程序,本发明不限定所述方法或装置的实现方式。
对于系统实施例而言,由于其基本相应于方法实施例,所以相关之处参见方法实施例的部分说明即可。以上所描述的系统实施例仅仅是示意性的,其中所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。本领域普通技术人员在不付出创造性劳动的情况下,即可以理解并实施。
在本发明所提供的几个实施例中,应该理解到,所揭露的系统和方法,在没有超过本发明的精神和范围内,可以通过其他的方式实现。当前的实施例只是一种示范性的例子,不应该作为限制,所给出的具体内容不应该限制本申请的目的。例如,所述单元或子单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或多个子单元结合一起。另外,多个单元可以或组件可以结合或者可以集成到另一个设备,或一些特征可以忽略,或不执行。
以上所述仅是本发明的具体实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也应视为本发明的保护范围。
Claims (10)
1.一种流程调用方法,其特征在于,预先创建Web服务与业务流程执行语言BPEL流程的对应关系,所述方法包括:
BPEL引擎接收业务流程服务请求,触发所述BPEL流程;
依据预先构建的流程执行顺序,执行所述BPEL流程;
判断在所述BPEL流程执行过程中是否需要调用Web服务,如果是,依据所述Web服务与BPEL流程的对应关系,从Web服务容器中获取所述Web服务,并调用所述Web服务,如果否,执行所述BPEL流程。
2.根据权利要求1所述的流程调用方法,其特征在于,所述业务流程服务请求由Web服务容器接收后,通过消息上下文接口转发至所述BPEL引擎。
3.根据权利要求2所述的流程调用方法,其特征在于,还包括:在BPEL流程执行结束后,将BPEL流程的处理结果通过消息上下文接口反馈到Web服务容器中,再由Web服务容器反馈至发送流程服务请求的客户端。
4.根据权利要求1所述的流程调用方法,其特征在于,所述BPEL引擎通过绑定上下文接口调用Web服务容器中的Web服务。
5.根据权利要求4所述的流程调用方法,其特征在于,在调用所述Web服务之后还包括:将Web服务的执行结果通过绑定上下文接口反馈到所述BPEL引擎。
6.根据权利要求1至5任意一项所述的流程调用方法,其特征在于,所述创建Web服务与BPEL流程的对应关系包括:
Web服务容器依据业务流程,确定业务流程所使用的Web服务,发布到所述Web服务容器中;
BPEL引擎分析业务流程,使用BPEL设计器进行BPEL流程建模,获取BPEL流程,并将所述BPEL流程部署至所述BPEL引擎;
所述BPEL引擎在BPEL流程注册库中注册一个BPEL流程,并通过绑定上下文接口向所述Web服务容器的服务库中注册一个与该BPEL流程对应的Web服务。
7.一种流程调用系统,其特征在于,预先创建Web服务与业务流程执行语言BPEL流程的对应关系,所述系统包括:Web服务容器和BPEL引擎,所述BPEL引擎包括接收单元、执行单元和判断单元;
所述接收单元用于接收业务流程服务请求,触发所述BPEL流程;
所述执行单元,用于依据预先构建的流程执行顺序,执行所述BPEL流程;
所述判断单元,用于判断在所述BPEL流程执行过程中是否需要调用Web服务,如果是,由所述执行单元依据所述Web服务与BPEL流程的对应关系,从Web服务容器中获取所述Web服务,并调用所述Web服务,如果否,由所述执行单元执行所述BPEL流程。
8.根据权利要求7所述的流程调用系统,其特征在于,Web服务容器通过自身的消息上下文接口连接所述BPEL引擎,将所述业务流程服务请求通过所述消息上下文接口转发至所述BPEL引擎,以及将所述BPEL引擎中的BPEL流程的处理结果通过消息上下文接口反馈到Web服务容器中。
9.根据权利要求7所述的流程调用系统,其特征在于,所述BPEL引擎通过自身的绑定上下文接口连接所述Web服务容器,通过所述绑定上下文接口调用Web服务容器中的Web服务,以及将Web服务的执行结果通过绑定上下文接口反馈到所述BPEL引擎。
10.一种应用服务器,其特征在于,包括如权利要求7至9任意一项所述的流程调用系统。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201110459045.1A CN102591714B (zh) | 2011-12-31 | 2011-12-31 | 一种流程调用方法、系统及应用服务器 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201110459045.1A CN102591714B (zh) | 2011-12-31 | 2011-12-31 | 一种流程调用方法、系统及应用服务器 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN102591714A true CN102591714A (zh) | 2012-07-18 |
CN102591714B CN102591714B (zh) | 2014-07-09 |
Family
ID=46480421
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201110459045.1A Active CN102591714B (zh) | 2011-12-31 | 2011-12-31 | 一种流程调用方法、系统及应用服务器 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN102591714B (zh) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103065221A (zh) * | 2012-12-27 | 2013-04-24 | 北京仿真中心 | 基于bpel的多学科协同优化流程建模与调度的方法和系统 |
CN107274023A (zh) * | 2017-06-20 | 2017-10-20 | 阿里巴巴集团控股有限公司 | 投保流程生成方法、投保请求处理方法及装置和电子设备 |
CN107517259A (zh) * | 2017-08-28 | 2017-12-26 | 四川长虹电器股份有限公司 | 一种简易Web服务器实现方法 |
CN107832161A (zh) * | 2017-11-06 | 2018-03-23 | 东软集团股份有限公司 | 服务调用方法及装置、存储介质、电子设备 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101320453A (zh) * | 2008-07-22 | 2008-12-10 | 北京航空航天大学 | 基于Web服务的电子公文流转自动化方法 |
EP2023279A1 (en) * | 2007-07-24 | 2009-02-11 | Siemens Aktiengesellschaft | A method and an apparatus for maintaining a quality of service of a business process |
-
2011
- 2011-12-31 CN CN201110459045.1A patent/CN102591714B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP2023279A1 (en) * | 2007-07-24 | 2009-02-11 | Siemens Aktiengesellschaft | A method and an apparatus for maintaining a quality of service of a business process |
CN101320453A (zh) * | 2008-07-22 | 2008-12-10 | 北京航空航天大学 | 基于Web服务的电子公文流转自动化方法 |
Non-Patent Citations (2)
Title |
---|
张功源,李必信,邱栋,吉顺慧: "一种基于并发的BPEL控制流模型的分析及验证", 《第六届中国测试学术会议论文集》 * |
韩雪,黄双喜,范玉顺: "基于BPEL的工作流引擎研究与开发", 《制造业自动化》 * |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103065221A (zh) * | 2012-12-27 | 2013-04-24 | 北京仿真中心 | 基于bpel的多学科协同优化流程建模与调度的方法和系统 |
CN107274023A (zh) * | 2017-06-20 | 2017-10-20 | 阿里巴巴集团控股有限公司 | 投保流程生成方法、投保请求处理方法及装置和电子设备 |
CN107517259A (zh) * | 2017-08-28 | 2017-12-26 | 四川长虹电器股份有限公司 | 一种简易Web服务器实现方法 |
CN107832161A (zh) * | 2017-11-06 | 2018-03-23 | 东软集团股份有限公司 | 服务调用方法及装置、存储介质、电子设备 |
Also Published As
Publication number | Publication date |
---|---|
CN102591714B (zh) | 2014-07-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102591714A (zh) | 一种流程调用方法、系统及应用服务器 | |
CN103605764A (zh) | 一种网络爬虫系统及网络爬虫多任务执行和调度方法 | |
CN103997452A (zh) | 多平台之间的信息分享方法及装置 | |
CN105224396A (zh) | 一种业务数据处理方法和装置 | |
CN104932892B (zh) | 一种基于WebWorker实现的Web应用中间件异步嵌套调用方法 | |
CN102467411A (zh) | 一种工作流处理及工作流代理方法、装置和系统 | |
CN106095603A (zh) | 一种Android系统相同的应用程序可同时开启多个的方法 | |
CN111125219A (zh) | 一种修改云平台上Redis集群参数的方法 | |
CN103002039A (zh) | 服务器调度系统和方法 | |
CN103179153B (zh) | 移动终端和基于云端服务器的移动终端数据备份方法 | |
CN101470626A (zh) | 一种任务排序方法 | |
CN104636211A (zh) | 一种软件系统间的信息交互方法及中间件系统 | |
CN104660639A (zh) | 云终端升级处理方法及装置 | |
CN102693318B (zh) | 一种报表查询方法及设备 | |
CN101470631A (zh) | 一种任务排序装置 | |
CN101834885A (zh) | 一种软件下载方法和装置 | |
CN101458628A (zh) | 一种程序版本管理方法 | |
CN113672205B (zh) | 一种基于业务事件驱动的工作流框架 | |
CN102866895B (zh) | 一种快速定位功能定制入口的方法 | |
CN109684115A (zh) | 一种应用于插件间的通信方法及相关设备 | |
CN108319420A (zh) | 一种图片加载方法及装置 | |
CN101751260B (zh) | 一种基于动态标签的业务对象持久化处理方法 | |
CN102981889A (zh) | 虚拟机创建方法和装置 | |
CN105718536A (zh) | 一种移动终端订单查询方法及系统 | |
US20130219412A1 (en) | System and method to provide bpel support for correlation aggregation |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant | ||
TR01 | Transfer of patent right | ||
TR01 | Transfer of patent right |
Effective date of registration: 20211206 Address after: 250014 No. 41-1 Qianfo Shandong Road, Lixia District, Jinan City, Shandong Province Patentee after: SHANDONG CIVIC SE COMMERCIAL MIDDLEWARE Co.,Ltd. Address before: 250014 No. 41-1 Qianfo Shandong Road, Jinan City, Shandong Province Patentee before: SHANDONG CVIC SOFTWARE ENGINEERING Co.,Ltd. Patentee before: Shandong Zhongchuang software commercial middleware Co., Ltd |