CN109347940B - 处理跨域业务请求及对跨域业务的请求方法和装置 - Google Patents

处理跨域业务请求及对跨域业务的请求方法和装置 Download PDF

Info

Publication number
CN109347940B
CN109347940B CN201811174611.2A CN201811174611A CN109347940B CN 109347940 B CN109347940 B CN 109347940B CN 201811174611 A CN201811174611 A CN 201811174611A CN 109347940 B CN109347940 B CN 109347940B
Authority
CN
China
Prior art keywords
processing
time
cross
domain service
request
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
CN201811174611.2A
Other languages
English (en)
Other versions
CN109347940A (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.)
Advanced New Technologies Co Ltd
Advantageous New Technologies Co Ltd
Original Assignee
Advanced New Technologies Co 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 Advanced New Technologies Co Ltd filed Critical Advanced New Technologies Co Ltd
Priority to CN201811174611.2A priority Critical patent/CN109347940B/zh
Publication of CN109347940A publication Critical patent/CN109347940A/zh
Application granted granted Critical
Publication of CN109347940B publication Critical patent/CN109347940B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/62Establishing a time schedule for servicing the requests
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/51Discovery or management thereof, e.g. service location protocol [SLP] or web services

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Hardware Redundancy (AREA)
  • Computer And Data Communications (AREA)

Abstract

本说明书实施例提供一种处理跨域业务请求,以及对跨域业务的请求方法和装置。对于发生在第一***和第二***之间的跨域业务,在第二***向第一***发送对跨域业务的处理请求时,通过设置对跨域业务进行处理的处理时间条件,使得:第一***在对跨域业务进行处理之前,先判断当前时间是否满足处理时间条件,并基于检测结果确定对处理请求的处理结果;第二***在发出对跨域业务的处理请求之后,至少在处理时间条件限定的第一***对跨域业务进行处理的最晚时间,向第一***发送对跨域业务处理情况的查询请求。如此,可以保持跨域业务中业务状态的一致性。

Description

处理跨域业务请求及对跨域业务的请求方法和装置
技术领域
本说明书一个或多个实施例涉及计算机技术领域,尤其涉及通过计算机对跨域业务请求进行处理的方法和装置,以及对跨域业务进行请求的方法和装置。
背景技术
跨域业务,通常是发生在分开部署的两个服务化***之间的业务。跨域业务发生的两个***中,一个***如果需要完成和另一个***有关业务,往往只能需要通过另外一个***提供的服务化接口请求来完成操作。跨域业务发生的两个***例如可以是,不同域名下的两个***、不同APP(应用)、同一APP下的两个子***等等。举例而言,在面向服务的架构SOA中,应用程序的不同功能单元(也可以称为服务)通过这些功能单元之间定义的接口和契约进行通信。由于接口是采用中立的方式进行定义的,它独立于实现服务的硬件平台、操作***和编程语言,这使得SOA下,构建在各种各样的***中的服务可以以一种统一和通用的方式进行交互。此时,跨域业务发生的两个***可以是SOA下的两个不同功能单元(服务)。
在上述跨域业务中,往往需要对时序进行控制。例如在金融***中,跨域业务往往在发出处理请求后,对跨域业务的处理结果进行查询,以获取对跨域业务是否处理成功。由于网络延迟,重发或者抖动等原因,如果查询请求先于处理请求到达对方***,则可能使双方对跨域业务的记录结果不一致,从而造成资金差异,可能增加账务人员工作量,或产生重大资金风险。
因此,希望能有改进的方案,对跨域业务中可能出现的时序异常进行规避,从而保障跨域业务发生的两个***中,业务状态的一致性。
发明内容
本说明书一个或多个实施例描述了一种对跨域业务请求进行处理的方法和装置,以及一种对跨域业务的请求方法和装置,分别用于跨域业务中的两个***,对跨域业务中可能出现的时序混乱进行规避,保障跨域业务发生的两个***中,业务状态的一致性。
根据第一方面,提供了一种处理跨域业务请求的方法,所述跨域业务包括发生在第一***和第二***之间的业务,所述方法通过所述第一***执行,包括:在第一时刻,获取来自所述第二***的对跨域业务的处理请求,其中,所述处理请求中包含对所述跨域业务进行处理的处理时间条件;检测所述第一时刻是否满足所述处理时间条件;在所述第一时刻满足所述处理时间条件的情况下,对所述跨域业务进行处理,得到处理结果;在所述第一时刻不满足所述处理时间条件的情况下,确定对所述跨域业务的处理结果包括处理失败。
根据一个可能的实施例,所述检测所述第一时刻是否满足所述处理时间条件包括:根据所述处理时间条件确定允许处理所述处理请求的最晚时间;将所述第一时刻与所述最晚时间进行对比;在所述第一时刻早于所述最晚时间的情况下,确定所述第一时刻满足所述处理时间条件;否则,确定所述第一时刻不满足所述处理时间条件。
根据一种可能的设计,所述方法还包括:在第二时刻,接收到来自所述第二***针对所述跨域业务的查询请求,所述查询请求于第三时刻从所述第二***发出,所述第三时刻晚于通过所述处理时间条件限定的允许处理所述跨域业务的最晚时间;获取对所述跨域业务的查询结果,并向所述第二***反馈所述查询结果。
进一步地,在一个实施例中,在所述第二时刻早于所述第一时刻的情况下,所述查询结果包括以下中的一项:未接收到相应的处理请求;处理失败;等待处理。
在另一个实施例中,在所述第二时刻晚于所述第一时刻的情况下,所述查询结果包括对所述跨域业务进行处理得到的处理结果。
根据第二方面,提供一种对跨域业务的请求方法,所述跨域业务包括发生在第一***和第二***之间的业务,所述方法通过所述第二***执行,所述方法包括:向所述第一***发送所述跨域业务的处理请求,所述处理请求包含对所述跨域业务进行处理的处理时间条件;基于所述处理时间条件,确定对所述跨域业务的查询起始时间,其中,所述查询起始时间不早于通过所述处理时间条件确定的、允许所述第一***处理所述跨域业务的最晚时间;根据所述查询起始时间,向所述第一***发送查询请求,以获取所述第一***对所述跨域业务处理情况的查询结果。
根据一个实施方式,所述查询结果包括以下至少一项:
所述第一***按照所述处理时间条件获取的对所述跨域业务的处理结果;
所述第一***未接收到所述处理请求的结果。
在一个实施例中,所述根据所述查询起始时间,向所述第一***发送查询请求包括:从所述查询起始时间开始,向所述第一***循环发送查询请求,直至接收到对所述跨域业务的查询结果。
根据第三方面,提供一种处理跨域业务请求的装置,所述跨域业务包括发生在第一***和第二***之间的业务,所述装置设于所述第一***,所述装置包括:获取单元,配置为在第一时刻,获取来自所述第二***的对跨域业务的处理请求,其中,所述处理请求中包含对所述跨域业务进行处理的处理时间条件;检测单元,配置为检测所述第一时刻是否满足所述处理时间条件;处理单元,配置为:在所述第一时刻满足所述处理时间条件的情况下,对所述跨域业务进行处理,得到处理结果;在所述第一时刻不满足所述处理时间条件的情况下,确定所述跨域业务处理失败。
根据第四方面,提供一种用对跨域业务的查询装置,所述跨域业务包括发生在第一***和第二***之间的业务,所述装置设于所述第二***,所述装置包括:发送单元,配置为向所述第一***发送所述跨域业务的处理请求,所述处理请求包含对所述跨域业务进行处理的处理时间条件;确定单元,配置为基于所述处理时间条件,确定对所述跨域业务的查询起始时间,其中,所述查询起始时间不早于通过所述处理时间条件确定的、允许所述第一***处理所述跨域业务的最晚时间;所述发送单元,还配置为根据所述查询起始时间,向所述第一***发送查询请求,以获取所述第一***对所述跨域业务处理情况的查询结果。
根据第五方面,提供了一种计算机可读存储介质,其上存储有计算机程序,当所述计算机程序在计算机中执行时,令计算机执行第一方面或第二方面的方法。
根据第六方面,提供了一种计算设备,包括存储器和处理器,其特征在于,所述存储器中存储有可执行代码,所述处理器执行所述可执行代码时,实现第一方面或第二方面的方法。
通过本说明书实施例提供的处理跨域业务请求的方法和装置,以及对跨域业务的请求方法和装置,对于发生在第一***和第二***之间的跨域业务,在第二***向第一***发送对跨域业务的处理请求时,通过设置对跨域业务进行处理的处理时间条件,使得:第一***在对跨域业务进行处理之前,先判断当前时间是否满足处理时间条件,并基于检测结果确定对处理请求的处理结果;第二***在发出对跨域业务的处理请求之后,至少在处理时间条件限定的第一***对跨域业务进行处理的最晚时间,向第一***发送对跨域业务处理情况的查询请求。如此,可以对跨域业务中可能出现的时序混乱进行规避,从而可以提高跨域业务的有效性。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其它的附图。
图1~图3示出本说明书披露的一个实施例的实施场景示意图;
图4示出根据一个实施例的处理跨域业务请求的方法流程图;
图5示出根据一个实施例的对跨域业务的请求方法流程图;
图6示出根据一个实施例的处理跨域业务请求的装置的示意性框图;
图7示出根据一个实施例的对跨域业务的请求装置的示意性框图。
具体实施方式
下面结合附图,对本说明书提供的方案进行描述。
本说明书实施例主要应用于在第一***和第二***之间发生跨域业务的过程。其中,第一***和第二***是两个相互独立的***,例如第一***是网上支付平台(如支付宝等),第二***是网上购物平台(如淘宝网等),跨域业务可能支付业务(如通过支付平台为网上购物平台中的交易行为进行支付)等。为了更清楚地说明本说明书实施例的方案,首先介绍本说明书实施例的应用背景。
图1是用户通过第二***发起与第一***相关联的业务1的情况下,第二***与第一***之间的正常交互时序图。如图1所示,在正常情况下,第二***首先在t时刻向第一***发送业务1的处理请求。第一***接收到业务1的处理请求,可以直接对业务1进行处理,也可以先存入缓存中,按照业务优先级排列,处理业务1。第一***在处理业务1时,可以先记录业务1,在对业务1进行处理,并记录处理结果。处理结果可以包括处理成功、处理失败等。在与时刻t具有预定时间间隔(如30秒)的时刻T,第二***向第一***发送关于业务1的查询请求。第一***查询业务1的处理结果,并反馈至第二***。其中,第一***在处理业务1的过程中,可能根据处理情况修改数据库,例如,业务1为对第二***中的交易行为进行支付的支付业务,第一***可以在数据库中将消费方的账户余额减去相关数值,还可以将商家的相应账户余额增加相关数值。此时,第二***可以通过向第一***查询对业务1处理情况,来进行后续流程。例如,对支付业务处理,则可以根据返回的处理成功的查询结果,形成订单。值得说明的是,如果第一***未收到业务1的处理请求,则可以返回未收到的查询结果。如果第一***异常、繁忙或者正在处理业务1,也可以返回相应的结果,此时,第二***可以循环发送业务1的查询请求,直至收到与处理成功、处理失败、未接收到等对应的查询结果的信息。
请参考图2,假设由于网络或硬件设备故障原因,第二***t时刻发送的业务1的处理请求,在T时刻第一***还未收到。而T时刻,第二***又向第一***发送了业务1的查询请求。第一***返回未收到或不存在等的查询结果。第二***则根据该查询结果按照业务1处理失败继续后续流程。例如重新发送编号为业务2的转账请求等。之后,第一***又收到了业务1的处理请求,并对业务1进行处理,例如将用户对应的账户余额减去相关数值等,并记录处理结果。也就是说,第一***按照对业务1的正常处理继续后续流程。在这种情况下,第一***和第二***对业务1的处理结果记录不再一致。实际应用中,往往通过在T时刻与t时刻之间设置较大时间间隔来尽量避免这种情况的发生。然而,一方面,在T时刻与t时刻之间设置较大时间间隔,影响业务交互的效率,另一方面,在不确定因素的影响下,很难找到一个较佳的时间间隔,确保第一***不会在T时刻之后获取业务1的处理请求,并对业务1进行处理。
在上述背景下,图3示出了本说明书披露的一个实施例的实施场景示意图。在图3中,第二***向第一***发送业务1的处理请求时,可以在处理请求中包含对处理请求进行处理的处理时间条件。第一***在获取该处理请求时,可以先检测处理时间条件是否满足。并根据检测结果确定处理请求是否有效,根据处理请求是否有效来获取对处理请求的处理结果。在一个实施例中,如果处理时间条件满足,则确定处理请求有效。处理请求有效,则处理结果为第一***正常处理业务1得到的结果。在另一个实施例中,如果处理时间条件不满足,则确定处理请求无效。处理请求无效,则可以确定处理结果为处理失败。另一方面,第二***可以按照上述处理时间条件向第一***发送查询请求。亦即,在满足处理时间条件之外的时刻再发送查询请求。例如,第二***在t时刻向第一***发送了业务1的处理请求,处理请求包含的处理时间条件为t+H,即仅在t+H时刻内,第一***可以确定业务1有效,而进行处理,否则,确定业务1无效。而第二***在t+H时刻之后向第一***发送查询请求。如此,可以保证第一***不会在返回查询结果之后又对同一跨域业务的处理请求进行处理。
为了更明确本说明书实施例在上述场景下的有益效果,请参考图3。假设仍然出现图2所示的问题,查询请求先于处理请求到达第一***。如图3所示,在t时刻,第二***向第一***发送业务1的处理请求,与图1、图2不同的是,在图3中发送的处理请求包含了对业务1进行处理的处理时间条件,例如是t+H时刻之前处理。假设第一***在t+H时刻之前没有收到该处理请求。在T时刻,第二***又向第一***发送了业务1的查询请求,其中,T时刻不早于t+H时刻(T≥t+H)。第一***向第二***返回查询结果,例如是未接收到该处理请求。假设在T时刻之后的某个时刻T+S(T+S≥t+H),第一***接收到了该业务1的处理请求,且欲处理该业务。则第一***先根据处理时间判断T+S时刻是否满足上述处理时间条件,即在t+H时刻之前处理该业务1。经过判断,T+S时刻晚于t+H时刻,则可以确定处理请求无效,从而获取对处理请求处理失败的处理结果。这样,在第一***和第二***中,对于业务1,处理结果保持一致。例如业务1为上述支付业务,则第一***实际未进行支付,和第二***得到的处理失败的结果一致。
如此,针对第二***向第一***发送跨域业务的处理请求时,通过在该处理请求中加入处理时间条件:一方面,第二***根据该处理时间条件确定处理请求是否有效,对有效的处理请求,处理相关跨域业务得到处理结果,对超出处理时间条件限定的时间范围的处理请求确认无效,并获取对跨域业务处理失败的处理结果;另一方面,第一***在处理请求发出后,根据处理时间条件确定查询起始时间,避免在处理请求有效的时间内发出查询请求,造成图2所示的情形。从而,可以对跨域业务中可能出现的时序混乱情况进行规避,提高跨域业务的有效性。
通过以上描述可知,本说明书实施例的处理跨域业务请求及对跨域业务的请求方法,尤其适用于具有独立功能的两个服务化***。两个服务化***可以通过一定的协议和确定的接口进行通信。可以理解,由于接口是独立于实现服务的硬件平台、操作***和编程语言的,这使得构建在各种各样的***中的服务可以以一种统一和通用的方式进行交互。举例而言,针对面向服务架构SOA而言,这两个***可以是同一个服务平台的两个功能单元,例如一个支付平台中的理财单元(如余额宝)和支付单元(如转账)等等,也可以是不同类别的服务平台下的功能单元,例如水电管理平台下的计算单元和银行资产管理平台下的支付单元等等。可以理解,由于第一***和第二***可以提供不同的服务,在一个***向另一个***发起跨域业务的处理请求之后,还需要再查询该跨域业务的处理情况,以保证两个***间对跨域业务记录的业务状态的一致性。
下面描述上述场景的具体执行过程。
图4示出根据一个实施例的处理跨域业务请求的方法流程图。其中的跨域业务是发生在两个***间的业务,例如发生在网络购物平台和网络支付平台之间的支付业务、发生在某个银行***的前置子***和账务子***之间的存取款业务等等。这里,网络购物平台和网络支付平台就是两个***,例如分别是图1~图3所示的第一***和第二***。该方法的执行主体可以是图1~图3所示的第一***等。该第一***可以是任何具有计算、处理能力的***、设备、装置、平台或服务器。
如图4示,该方法可以包括以下步骤:步骤41,在第一时刻,获取来自第二***的对跨域业务的处理请求,其中,处理请求中包含对跨域业务进行处理的处理时间条件;步骤42,检测第一时刻是否满足处理时间条件;步骤43,基于检测结果获取对跨域业务的处理结果,其中:在第一时刻满足处理时间条件的情况下,对跨域业务进行处理,得到处理结果;在第一时刻不满足处理时间条件的情况下,确定对跨域业务的处理结果包括处理失败。
首先,通过步骤41,在第一时刻,获取来自第二***的对跨域业务的处理请求。可以理解,跨域业务的处理请求是由第二***发送来的,该处理请求可能被立即处理,也可能被放入缓存的任务序列等待处理。因此,这里的第一时刻可以是第一***接收到该跨域业务的处理请求的时刻,也可以是第一***按照缓存中的任务顺序,执行到跨域业务的处理请求的时刻。
其中,上述跨域业务的处理请求中还可以包含对处理请求进行处理的处理时间条件。该处理时间条件可以用于限定处理请求的有效时限。处理时间条件的形式可以有多种。例如,在一个实施例中,该处理时间条件可以为30秒,表示从第二***向第一***发起处理请求的时刻(如上午9点20分10秒09:20:10)开始,仅仅在该时刻后的30秒内(如09:20:10至09:20:40),允许第一***正常处理该跨域业务。本领域技术人员容易理解,对于第二***向第一***发起处理请求的时刻,可以通过处理请求中的时间戳等获得,在此不再赘述。再例如,在另一个实施例中,该处理时间条件可以为截止时间(如09:20:40),用于表示第一***可以正常处理该跨域业务的最晚时间。实践中,处理时间条件还可以是通过各种其他方式表示的条件,在此不再一一例举。
接着,在步骤42,检测第一时刻是否满足处理时间条件。可以理解,由于处理时间条件可以用于确定处理请求的有效时限,所以可以通过第一时刻是否满足处理时间条件来确定处理请求是否有效。
在一个实施例中,检测第一时刻是否满足处理时间条件,可以通过判断第一时刻是否落入处理时间条件限定的时间范围内来进行。例如,在处理时间条件为在从第二***发送处理请求起的30秒内,允许第一***处理相应跨域业务的情况下,根据从第二***发送处理请求的时刻,如09:20:10,以及处理时间条件,可以确定处理该跨域业务的时间范围为,09:20:10至09:20:40。此时,可以检测第一时刻是否落入该时间范围09:20:10至09:20:40。如果落入,则检测结果为第一时刻满足处理时间条件,否则,检测结果可以为不满足处理时间条件。
在另一个实施例中,检测第一时刻是否满足处理时间条件,可以通过判断第一时刻是否落入处理时间条件限定的最晚处理时间来进行。此时,可以先根据处理时间条件确定允许处理跨域业务的最晚时间(如09:20:40),然后将第一时刻(如09:20:35)与该最晚时间进行对比,并且,在该第一时刻早于该最晚时间的情况下,确定该第一时刻满足处理时间条件,否则,确定该第一时刻不满足处理时间条件。
在其他实施例中,检测第一时刻是否满足处理时间条件还可以通过其他合理的方式进行,在此不再赘述。值得说明的是,在以上具体例子中,时刻以秒为最小单位进行计算,实践中,为了使处理时间条件更加精确,还可以通过毫秒、微秒等单位进行计算,本说明书实施例对此不作限定。
进一步地,根据以上检测结果可以确定处理请求是否有效。通常,在第一时刻满足处理时间条件的情况下,确定处理请求有效,在第一时刻不满足处理时间条件的情况下,确定处理请求无效。但根据处理时间条件的不同设置方式,也可能得到相反的结论。例如,如果处理时间条件为“晚于09:20:40,不再处理该跨域业务”,则在第一时刻满足处理时间条件“晚于09:20:40”的情况下,确定处理请求无效。
然后,在步骤43中,根据检测结果获取对跨域业务的处理结果。可以理解,如果上述处理请求有效,则第一***可以对该处理请求所涉及的跨域业务正常处理,否则,不再处理该跨域业务。
一方面,在处理请求有效的情况下,对跨域业务正常处理出现的处理结果可能包括:处理成功或处理失败。举例而言,当跨域业务为支付业务时,第一***需要将数据库中各个对应的账户余额增加或减少相应数值。如果对数据库操作正常,则处理结果可以为处理成功,但是如果出现诸如数据库无法访问、用户对应的账户余额减少相应数值会成为负值之类的情况时,则处理结果可能为处理失败。
另一方面,在处理请求无效的情况下,第一***对跨域业务可以不作处理。此时,可以确定对跨域业务的处理结果包括处理失败。值得说明的是,处理失败的表达方式可以有多种,例如扣款失败、请求过期等等。
如此,第一***可以在获取跨域业务的处理请求时,先根据处理请求中包含的处理时间条件,判断处理请求是否有效,并根据处理请求是否有效来获取跨域业务的处理结果,避免了网络或硬件设备原因造成的处理请求接收滞后,无限期处理的情况。
根据一种实施方式,该处理跨域业务请求的方法还可以包括以下步骤:
在第二时刻,接收到来自第二***针对跨域业务的查询请求,查询请求于第三时刻从第二***发出,第三时刻晚于通过处理时间条件限定的允许处理跨域业务的最晚时间;获取对跨域业务处理情况的查询结果,并向第二***反馈查询结果。
可以理解,第二***在向第一***发出对跨域业务的处理请求后,经过一定时间间隔后的第三时刻,还可以向第一***发出对跨域业务的查询请求,以确定跨域业务的处理情况,并根据跨域业务的处理情况进行后续数据处理。其中,为了保证第一***在处理请求的有效时限内开始处理跨域业务都能得到相应的处理结果以供查询,第三时刻可以是不在有效时限内的一个时刻。例如,第三时刻可以晚于通过处理时间条件限定的允许处理跨域业务的最晚时间。
在第二时刻,第一***接收到第二***发送来的查询请求,此时,第一***可以查询上述跨域业务。具体地:
一方面,如果第二时刻早于第一时刻,就是说第一***还没有处理该跨域业务,也不会记录有跨域业务的处理结果,则第一***可以向第二***返回诸如请求超时、未接收到相关业务请求、未处理或等待处理、处理失败之类的信息作为查询结果;
另一方面,在第二时刻晚于第一时刻的情况下,如果处理请求有效,并且第一***已经对跨域业务进行处理并获取了处理结果,该处理结果可能是处理成功或者处理失败,则第一***可以将对处理请求的处理结果作为查询结果返回第二***。如果处理请求有效,但第一***仍正在处理该跨域业务,则第一***可以返回诸如处理中之类的查询结果。如果处理请求无效,则第一***还可以向第二***返回处理失败之类的查询结果。
其中,在一些实现中,如果查询结果是确定的处理结果,如处理成功、处理失败、未接收到等时,第二***可以终止查询,如果查询结果是处理中等时,第二***可以继续向第一***发送查询请求,直至查询到确定的处理结果。
通过第二***在处理请求的有效时限之后发送查询请求,可以进一步避免查询到确定处理结果后又收到处理请求,对跨域业务进行处理,造成的数据混乱现象。
图5示出根据一个实施例的对跨域业务的请求方法流程图。其中的跨域业务是发生在两个***间的业务,例如发生在网络购物平台和网络支付平台之间的支付业务、发生在某个银行***的前置子***和账务子***之间的存取款业务等等。这里,网络购物平台和网络支付平台就是两个***,例如分别是图1~图3所示的第一***和第二***。该方法的执行主体可以是图1~图3所示的第二***等。该第二***可以是任何具有计算、处理能力的***、设备、装置、平台或服务器。需要明确的是,该对跨域业务的查询的流程适用于第二***向第一***发出对某个跨域业务的处理请求之后,经过预定的时间间隔(如30秒),再去向第一***查询该跨域业务的处理状态的过程。
如图5示,该方法包括以下步骤:步骤51,向第一***发送跨域业务的处理请求,处理请求包含对跨域业务进行处理的处理时间条件;步骤52,基于上述处理时间条件,确定对跨域业务的查询起始时间,其中,查询起始时间不早于通过处理时间条件确定的、允许第一***处理跨域业务的最晚时间;步骤53,根据查询起始时间,向第一***发送查询请求,以获取第一***对跨域业务处理情况的查询结果。
首先,在步骤51,向第一***发送跨域业务的处理请求,处理请求包含对跨域业务进行处理的处理时间条件。在本说明书实施例中,第二***向第一***发出跨域业务的处理请求时,可以在处理请求中包含处理时间条件,用于第一***确定处理请求的有效时限。例如,第一***可以根据该处理时间条件确定出对跨域业务进行处理的有效时限或最晚时间等。
第二***在向第一***发送跨域业务的处理请求时,可以先获取跨域业务,根据预设的处理时间条件生成规则(如当前时间增加30秒作为最晚处理时间等),或者人为指定的处理时间,确定处理时间条件,并将跨域业务和处理时间条件生成跨域业务的处理请求。该处理请求可以是通过网络设备间通过确定的通信协议约定格式的各种请求消息,例如HTTP请求、android-http异步请求等等,本说明书实施例对此不作限定。
接着,在步骤52,基于上述处理时间条件,确定对跨域业务的查询起始时间。可以理解,查询起始时间就是开始查询的时间。也就是说,对跨域业务的查询可以是一次,也可以是多次,而查询起始时间可以是第一次发起查询请求的时间。可以理解,为了确保第一***不会在接收到第二***发送的查询请求之后,再开始处理相应的跨域业务,第二***可以先确定发起查询请求的查询起始时间不早于允许第一***处理跨域业务的最晚时间。
然后,在步骤53,根据查询起始时间,向第一***发送查询请求,以获取第一***对跨域业务处理情况的查询结果。其中,该查询结果可以用于跨域业务的进展状况。例如,在第一***未接收到相应跨域业务的处理请求的情况下,查询结果可能是未接收到处理请求。在第一***接收到相应跨域业务的处理请求的情况下,查询结果可以是第一***按照处理时间条件获取的对跨域业务的处理结果。此时,该处理结果可能是处理成功,也可能是处理失败。举例而言,如果第一***在获取了相应跨域业务的处理请求,并通过判断,该获取时刻不符合处理时间条件,则该处理请求无效,第一***可以将对相应跨域业务的处理结果确定为处理失败。如果通过判断,该获取时刻符合处理时间条件,则该处理请求有效,第一***对该跨域业务进行处理。在第一***对该跨域业务进行处理的过程中,如果顺利完成,则处理结果可以为处理成功,否则(如数据库操作失败等),处理结果可以为处理失败。
在一个实施例中,查询请求到达第一***时,第一***还可能正在处理相应的跨域业务,此时,查询结果还可以是诸如“正在处理”、“数据异常”、“服务器忙”等等之类的结果。
根据一种实施方式,第二***仅发送一次查询请求。在接收到任意查询结果后可以停止查询。如果接收到第一***正在处理相应的跨域业务的查询结果,还可以向第一***发送终止业务的请求。
根据另一种实施方式,第二***可以多次发送查询请求。例如,可以从查询起始时间开始,向第一***循环发送查询请求,直至接收到对跨域业务的预定查询结果。该预定查询结果例如可以是处理成功、处理失败、未接收到之类的查询结果。这样,在接收到诸如“正在处理”这样的查询结果的情况下,可以由第一***继续处理跨域业务,直至处理完毕。
可以理解,本说明书实施例中“处理成功”、“处理失败”、“正在处理”之类的查询结果或处理结果仅仅是结果状态的一种表达方式,实践中也可以使用其他表达方式,本说明书实施例对此不作限定。
需要指出,图4示出的实施例和图5示出的实施例,分别适应于跨域业务发生的第一***和第二***。第二***和第一***分别作为请求和处理跨域业务的一端,在配合完成跨域业务的过程,有一些信息的交互,因此一些概念、流程是可以相互适应或补充的。
值得说明的是,第一***对跨域业务进行处理的处理模块和用于处理查询请求的查询模块,可以是设置在一起,也可以分开设置。例如,处理模块可以将处理结果写入数据库,查询***只针对数据库进行查询,等等。
回顾以上过程,对于发生在第一***和第二***之间的跨域业务,通过在发送处理请求时设置处理时间条件:一方面,接收处理请求的一方在获取处理请求时,先根据处理时间条件检测处理请求是否有效,并根据处理请求是否有效获取处理结果;另一方面,发送处理请求的一方可以根据处理时间条件确定开始发送查询请求的查询起始时间,以免在处理请求仍有效的情况下向另一方进行跨域业务的结果查询,造成两方结果不一致。如此,可以规避跨域业务中可能出现的时序混乱现象,从而使第一***和第二***中,跨域业务的业务状态记录一致。进一步地,提高了跨域业务的有效性。
根据另一方面的实施例,还提供一种处理跨域业务请求的装置。跨域业务包括发生在第一***和第二***之间的业务。图6示出根据一个实施例的处理跨域业务请求的装置的示意性框图。该装置600可以适应于图1~图3所示的第一***中。
如图6所示,处理跨域业务请求的装置600包括:获取单元61,配置为在第一时刻,获取来自第二***的对跨域业务的处理请求,其中,处理请求中包含对处理请求进行处理的处理时间条件,处理时间条件用于确定处理请求的有效时限;检测单元62,配置为检测第一时刻是否满足处理时间条件;处理单元63,配置为根据检测结果,获取对跨域业务的处理结果,其中,在第一时刻满足处理时间条件的情况下,对跨域业务进行处理,得到处理结果;在第一时刻不满足处理时间条件的情况下,确定跨域业务处理失败。
根据一个实施方式,检测单元62进一步还可以配置为:根据处理时间条件确定允许处理跨域业务的最晚时间;将第一时刻与最晚时间进行对比;在第一时刻早于最晚时间的情况下,确定第一时刻满足处理时间条件;否则,确定第一时刻不满足所述处理时间条件。
根据一个可能的设计,装置600还包括查询单元(未示出)。该查询单元可以配置为:在第二时刻,接收到来自第二***针对跨域业务的查询请求,查询请求于第三时刻从第二***发出,第三时刻晚于通过处理时间条件限定的允许处理跨域业务的最晚时间;获取对跨域业务的查询结果,并向第二***反馈查询结果。
根据一种实现方式,在第二时刻早于第一时刻的情况下,查询单元获取的查询结果可以包括以下中的一项:未接收到相应的处理请求;处理失败;等待处理
根据另一种实现方式,在第二时刻晚于第一时刻的情况下,如果处理请求有效,并且处理单元63已经对跨域业务进行处理并获取了处理结果,该处理结果可能是处理成功或者处理失败。如果处理请求有效,但处理单元63仍正在处理该跨域业务,则第一***可以返回诸如处理中之类的查询结果。如果处理请求无效,则查询单元还可能得到处理单元63确定的处理失败之类的处理结果作为查询结果。
值得说明的是,图6所示的装置600是与图4示出的方法实施例相对应的装置实施例,图4示出的方法实施例中的相应描述同样适用于装置600,在此不再赘述。
根据又一方面的实施例,本说明书还提供一种对跨域业务的查询装置。跨域业务包括发生在第一***和第二***之间的业务。图7示出根据一个实施例的对跨域业务的查询装置的示意性框图。该装置700可以适应于图1~图3所示的第二***中。
如图7所示,对跨域业务的查询装置700包括:发送单元71,配置为向第一***发送跨域业务的处理请求,处理请求包含对跨域业务进行处理的处理时间条件;确定单元72,配置为基于上述处理时间条件,确定对跨域业务的查询起始时间,其中,查询起始时间不早于通过处理时间条件确定的、允许第一***处理跨域业务的最晚时间;发送单元71,还配置为根据查询起始时间,向第一***发送查询请求,以获取第一***对跨域业务的查询结果。
在一个实施例中,上述查询结果可以包括第一***按照处理时间条件获取的对跨域业务的处理结果。
在另一个实施例中,上述查询结果可以包括第一***未接收到跨域业务的处理请求的结果。
根据一种可能的设计,发送单元71还可以配置为:从查询起始时间开始,向第一***循环发送查询请求,直至接收到对跨域业务的预定查询结果。
值得说明的是,图7所示的装置700是与图5示出的方法实施例相对应的装置实施例,图5示出的方法实施例中的相应描述同样适用于装置700,在此不再赘述。
通过以上装置600和700,分别设于图1~图3示出的两个***中,基于处理时间条件的设置,为跨域业务限定处理时限。从而,使得跨域业务不会在处理时限之外被处理,对跨域业务的查询不会在处理时限之内发出。从而对业务时限进行有序管理,使发生跨域业务的两个***保持一致,提高跨域业务处理的有效性。
根据另一方面的实施例,还提供一种计算机可读存储介质,其上存储有计算机程序,当所述计算机程序在计算机中执行时,令计算机执行结合图4或图5所描述的方法。
根据再一方面的实施例,还提供一种计算设备,包括存储器和处理器,所述存储器中存储有可执行代码,所述处理器执行所述可执行代码时,实现结合图4或图5所述的方法。
本领域技术人员应该可以意识到,在上述一个或多个示例中,本发明所描述的功能可以用硬件、软件、固件或它们的任意组合来实现。当使用软件实现时,可以将这些功能存储在计算机可读介质中或者作为计算机可读介质上的一个或多个指令或代码进行传输。
以上所述的具体实施方式,对本发明的目的、技术方案和有益效果进行了进一步详细说明,所应理解的是,以上所述仅为本发明的具体实施方式而已,并不用于限定本发明的保护范围,凡在本发明的技术方案的基础之上,所做的任何修改、等同替换、改进等,均应包括在本发明的保护范围之内。

Claims (18)

1.一种处理跨域业务请求的方法,所述跨域业务包括发生在第一***和第二***之间的业务,所述方法通过所述第一***执行,包括:
在第一时刻,获取来自所述第二***的对跨域业务的处理请求,其中,所述处理请求中包含对所述跨域业务进行处理的处理时间条件;
检测所述第一时刻是否满足所述处理时间条件;
在所述第一时刻满足所述处理时间条件的情况下,对所述跨域业务进行处理,得到处理结果;
在所述第一时刻不满足所述处理时间条件的情况下,确定对所述跨域业务的处理结果包括处理失败;
使得,对于所述第二***针对所述跨域业务于第三时刻发出的查询请求,在所述第三时刻晚于通过所述处理时间条件限定的允许处理所述跨域业务的最晚时间的情况下,保持针对所述跨域业务的查询结果与所述跨域业务的处理结果一致。
2.根据权利要求1所述的方法,其中,所述检测所述第一时刻是否满足所述处理时间条件包括:
根据所述处理时间条件确定允许处理所述跨域业务的最晚时间;
将所述第一时刻与所述最晚时间进行对比;
在所述第一时刻早于所述最晚时间的情况下,确定所述第一时刻满足所述处理时间条件;
否则,确定所述第一时刻不满足所述处理时间条件。
3.根据权利要求1所述的方法,其中,所述方法还包括:
在第二时刻,接收到来自所述第二***针对所述跨域业务的查询请求;
获取对所述跨域业务的查询结果,并向所述第二***反馈所述查询结果。
4.根据权利要求3所述的方法,其中,在所述第二时刻早于所述第一时刻的情况下,所述查询结果包括以下中的一项:
未接收到相应的处理请求;
处理失败;
等待处理。
5.根据权利要求3所述的方法,其中,在所述第二时刻晚于所述第一时刻的情况下,所述查询结果包括对所述跨域业务进行处理得到的处理结果。
6.一种对跨域业务的请求方法,所述跨域业务包括发生在第一***和第二***之间的业务,所述方法通过所述第二***执行,所述方法包括:
向所述第一***发送所述跨域业务的处理请求,所述处理请求包含对所述跨域业务进行处理的处理时间条件,以供所述第一***根据接收到所述处理请求的时刻是否满足所述处理时间条件,确定是否处理所述跨域业务;
基于所述处理时间条件,确定对所述跨域业务的查询起始时间,其中,所述查询起始时间不早于通过所述处理时间条件确定的、允许所述第一***处理所述跨域业务的最晚时间;
根据所述查询起始时间,向所述第一***发送查询请求,以获取所述第一***对所述跨域业务处理情况的查询结果。
7.根据权利要求6所述的方法,其中,所述查询结果包括以下中的一项:
所述第一***按照所述处理时间条件获取的对所述跨域业务的处理结果;
所述第一***未接收到所述处理请求。
8.根据权利要求7所述的方法,其中,所述根据所述查询起始时间,向所述第一***发送查询请求包括:
从所述查询起始时间开始,向所述第一***循环发送查询请求,直至接收到对所述跨域业务的预定查询结果。
9.一种处理跨域业务请求的装置,所述跨域业务包括发生在第一***和第二***之间的业务,所述装置设于所述第一***,所述装置包括:
获取单元,配置为在第一时刻,获取来自所述第二***的对跨域业务的处理请求,其中,所述处理请求中包含对所述跨域业务进行处理的处理时间条件;
检测单元,配置为检测所述第一时刻是否满足所述处理时间条件;
处理单元,配置为:在所述第一时刻满足所述处理时间条件的情况下,对所述跨域业务进行处理,得到处理结果;在所述第一时刻不满足所述处理时间条件的情况下,确定所述跨域业务处理失败;
从而,使得所述第一***对于所述第二***针对所述跨域业务于第三时刻发出的查询请求,在所述第三时刻晚于通过所述处理时间条件限定的允许处理所述跨域业务的最晚时间的情况下,保持针对所述跨域业务的查询结果与所述跨域业务的处理结果一致。
10.根据权利要求9所述的装置,其中,所述检测单元还配置为:
根据所述处理时间条件确定允许处理所述跨域业务的最晚时间;
将所述第一时刻与所述最晚时间进行对比;
在所述第一时刻早于所述最晚时间的情况下,确定所述第一时刻满足所述处理时间条件;
否则,确定所述第一时刻不满足所述处理时间条件。
11.根据权利要求9所述的装置,其中,所述装置还包括查询单元,配置为:
在第二时刻,接收到来自所述第二***针对所述跨域业务的查询请求;
获取对所述跨域业务的查询结果,并向所述第二***反馈所述查询结果。
12.根据权利要求11所述的装置,其中,在所述第二时刻早于所述第一时刻的情况下,所述查询结果包括以下中的一项:
未接收到相应的处理请求;
处理失败;
等待处理。
13.根据权利要求11所述的装置,其中,在所述第二时刻晚于所述第一时刻的情况下,所述查询结果包括对所述处理请求进行处理得到的处理结果。
14.一种对跨域业务的请求装置,所述跨域业务包括发生在第一***和第二***之间的业务,所述装置设于所述第二***,所述装置包括:
发送单元,配置为向所述第一***发送所述跨域业务的处理请求,所述处理请求包含对所述跨域业务进行处理的处理时间条件,以供所述第一***根据接收到所述处理请求的时刻是否满足所述处理时间条件,确定是否处理所述跨域业务;
确定单元,配置为基于所述处理时间条件,确定对所述跨域业务的查询起始时间,其中,所述查询起始时间不早于通过所述处理时间条件确定的、允许所述第一***处理所述跨域业务的最晚时间;
所述发送单元,还配置为根据所述查询起始时间,向所述第一***发送查询请求,以获取所述第一***对所述跨域业务处理情况的查询结果。
15.根据权利要求14所述的装置,其中,所述查询结果包括以下至少一项:
所述第一***按照所述处理时间条件获取的对所述跨域业务的处理结果;
所述第一***未接收到所述处理请求。
16.根据权利要求14所述的装置,其中,所述发送单元还配置为:
从所述查询起始时间开始,向所述第一***循环发送查询请求,直至接收到对所述跨域业务的预定查询结果。
17.一种计算机可读存储介质,其上存储有计算机程序,当所述计算机程序在计算机中执行时,令计算机执行权利要求1-5或6-8中任一项的所述的方法。
18.一种计算设备,包括存储器和处理器,其特征在于,所述存储器中存储有可执行代码,所述处理器执行所述可执行代码时,实现权利要求1-5或6-8中任一项所述的方法。
CN201811174611.2A 2018-10-09 2018-10-09 处理跨域业务请求及对跨域业务的请求方法和装置 Active CN109347940B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811174611.2A CN109347940B (zh) 2018-10-09 2018-10-09 处理跨域业务请求及对跨域业务的请求方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811174611.2A CN109347940B (zh) 2018-10-09 2018-10-09 处理跨域业务请求及对跨域业务的请求方法和装置

Publications (2)

Publication Number Publication Date
CN109347940A CN109347940A (zh) 2019-02-15
CN109347940B true CN109347940B (zh) 2021-03-02

Family

ID=65308821

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811174611.2A Active CN109347940B (zh) 2018-10-09 2018-10-09 处理跨域业务请求及对跨域业务的请求方法和装置

Country Status (1)

Country Link
CN (1) CN109347940B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111078728B (zh) * 2019-12-19 2023-06-23 山大地纬软件股份有限公司 一种数据库归档模式下跨库查询方法和装置

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103347020A (zh) * 2013-07-02 2013-10-09 中国工商银行股份有限公司 一种跨应用认证访问的***及方法
CN104166912A (zh) * 2014-04-30 2014-11-26 深圳光启创新技术有限公司 光子支付方法及支付***
CN105099989A (zh) * 2014-04-24 2015-11-25 阿里巴巴集团控股有限公司 用于处理业务请求及获取业务处理结果的方法、装置和***
WO2017101715A1 (zh) * 2015-12-17 2017-06-22 阿里巴巴集团控股有限公司 跨***的业务操作执行方法、业务平台以及目标***
CN107920120A (zh) * 2017-11-22 2018-04-17 北京小米移动软件有限公司 业务处理方法、装置及计算机可读存储介质
CN108133367A (zh) * 2014-05-29 2018-06-08 苹果公司 用于支付的用户接口

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
TWI313138B (en) * 2005-12-08 2009-08-01 Method, system and computer readable medium therefor adapted for wireless communication system
US9460436B2 (en) * 2012-03-16 2016-10-04 Visa International Service Association Systems and methods to apply the benefit of offers via a transaction handler
US10956888B2 (en) * 2015-07-21 2021-03-23 Early Warning Services, Llc Secure real-time transactions

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103347020A (zh) * 2013-07-02 2013-10-09 中国工商银行股份有限公司 一种跨应用认证访问的***及方法
CN105099989A (zh) * 2014-04-24 2015-11-25 阿里巴巴集团控股有限公司 用于处理业务请求及获取业务处理结果的方法、装置和***
CN104166912A (zh) * 2014-04-30 2014-11-26 深圳光启创新技术有限公司 光子支付方法及支付***
CN108133367A (zh) * 2014-05-29 2018-06-08 苹果公司 用于支付的用户接口
WO2017101715A1 (zh) * 2015-12-17 2017-06-22 阿里巴巴集团控股有限公司 跨***的业务操作执行方法、业务平台以及目标***
CN106899539A (zh) * 2015-12-17 2017-06-27 阿里巴巴集团控股有限公司 跨***的业务操作执行方法、业务平台以及目标***
CN107920120A (zh) * 2017-11-22 2018-04-17 北京小米移动软件有限公司 业务处理方法、装置及计算机可读存储介质

Also Published As

Publication number Publication date
CN109347940A (zh) 2019-02-15

Similar Documents

Publication Publication Date Title
CN108848119B (zh) 跨区块链的交互方法及装置、***、电子设备
CN109491765B (zh) 对跨域业务请求的处理方法及装置
US7694178B2 (en) Method, apparatus and computer program product for transaction recovery
CN111277639B (zh) 一种保持数据一致性的方法和装置
KR102167613B1 (ko) 메시지 푸시 방법 및 장치
CN108681777B (zh) 一种基于分布式***的机器学习程序运行的方法和装置
CN110602214B (zh) 司法链的证据存证和处理方法、装置、设备和介质
CN107436799B (zh) 分布式事务一致性实现方法及装置
CN110851290A (zh) 一种数据同步方法、装置、电子设备及存储介质
CN108647105B (zh) ***切换过程中的幂等控制方法、装置及***
CN112446786A (zh) 一种异常交易处理方法、装置、电子设备和可读存储介质
KR20150001146A (ko) 스토리지 시스템 및 그의 동작 방법
CN107645476B (zh) 请求处理方法和装置
CN110598058A (zh) 司法链的证据存证和处理方法、装置、设备和介质
CN109347940B (zh) 处理跨域业务请求及对跨域业务的请求方法和装置
CN113112344B (zh) 业务处理方法、设备、存储介质及计算机程序产品
CN110941622A (zh) 一种数据处理方法及装置
US8756320B2 (en) Web service grid architecture
CN111367694B (zh) 事件处理方法、服务器及计算机存储介质
CN115643271A (zh) 一种云上多应用数据同步方法、装置、服务器及介质
CN116414628A (zh) 一种新旧***切换过程中交易请求的处理方法和装置
JP5979719B2 (ja) Atmシステム及び方法
CN111695901B (zh) 账务凭证处理方法、装置、设备及存储介质
CN109034768B (zh) 财务调拨方法、装置、计算机设备和存储介质
CN113590715A (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
TA01 Transfer of patent application right

Effective date of registration: 20201010

Address after: Cayman Enterprise Centre, 27 Hospital Road, George Town, Grand Cayman Islands

Applicant after: Innovative advanced technology Co.,Ltd.

Address before: Cayman Enterprise Centre, 27 Hospital Road, George Town, Grand Cayman Islands

Applicant before: Advanced innovation technology Co.,Ltd.

Effective date of registration: 20201010

Address after: Cayman Enterprise Centre, 27 Hospital Road, George Town, Grand Cayman Islands

Applicant after: Advanced innovation technology Co.,Ltd.

Address before: A four-storey 847 mailbox in Grand Cayman Capital Building, British Cayman Islands

Applicant before: Alibaba Group Holding Ltd.

TA01 Transfer of patent application right
GR01 Patent grant
GR01 Patent grant