CN114638608A - 支付方法、终端设备、服务器、系统及介质 - Google Patents
支付方法、终端设备、服务器、系统及介质 Download PDFInfo
- Publication number
- CN114638608A CN114638608A CN202210238575.1A CN202210238575A CN114638608A CN 114638608 A CN114638608 A CN 114638608A CN 202210238575 A CN202210238575 A CN 202210238575A CN 114638608 A CN114638608 A CN 114638608A
- Authority
- CN
- China
- Prior art keywords
- sdk
- payment
- user
- server
- verification
- 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.)
- Pending
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/386—Payment protocols; Details thereof using messaging services or messaging apps
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
- G06F21/57—Certifying or maintaining trusted computer platforms, e.g. secure boots or power-downs, version controls, system software checks, secure updates or assessing vulnerabilities
- G06F21/572—Secure firmware programming, e.g. of basic input output system [BIOS]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/40—Authorisation, e.g. identification of payer or payee, verification of customer or shop credentials; Review and approval of payers, e.g. check credit lines or negative lists
- G06Q20/401—Transaction verification
- G06Q20/4014—Identity check for transactions
Abstract
本申请公开了一种支付方法、终端设备、服务器、系统及介质,属于数据处理领域。该方法包括:响应于接收的支付请求消息,向安全控制系统发送安全验证请求消息,安全验证请求消息用于指示安全控制系统根据安全验证信息进行安全验证;接收安全控制系统发送的安全验证结果信息;在安全验证结果信息表征安全验证通过的情况下,向SDK发送第一通知消息,第一通知消息指示SDK通知宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息,第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息;在用户验证结果信息表征用户验证通过的情况下发起付款请求,以完成支付。根据本申请实施例能够提高支付的安全性。
Description
技术领域
本申请属于数据处理领域,尤其涉及一种支付方法、终端设备、服务器、系统及介质。
背景技术
随着支付技术的发展,电子支付的应用越来越广泛。用户可通过终端设备实现支付。终端设备中安装有应用程序和软件开发工具包(Software Development Kit,SDK),SDK可集成在应用程序中,共同实现支付。
支付过程在终端设备中涉及应用程序和SDK两个主体,支付过程涉及的主体增多,支付存在的安全风险也随之增大。因此,亟需一种能够提高安全性的支付方法。
发明内容
本申请实施例提供一种支付方法、终端设备、服务器、系统及介质,能够提高支付的安全性。
第一方面,本申请实施例提供一种支付方法,应用于软件开发工具包SDK服务器,方法包括:响应于接收的支付请求消息,向安全控制系统发送安全验证请求消息,安全验证请求消息包括安全验证信息,用于指示安全控制系统根据安全验证信息对支付请求消息对应的支付进行安全验证;接收安全控制系统发送的安全验证结果信息;在安全验证结果信息表征安全验证通过的情况下,向终端设备中的SDK发送第一通知消息,终端设备具有SDK和宿主程序,第一通知消息用于指示SDK通知宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息,第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息;在用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
第二方面,本申请实施例提供一种支付方法,应用于终端设备,终端设备具有软件开发工具包SDK和宿主程序,方法包括:通过SDK获取SDK服务器发送的第一通知消息,第一通知消息是SDK服务器基于表征安全验证通过的安全验证结果信息发送的,安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应的支付进行安全验证得到的,安全验证请求消息由SDK服务器响应于接收的支付请求消息发送;响应于第一通知消息,通过SDK通知宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息;通过宿主程序向宿主程序服务器反馈第一用户验证输入信息,第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息;通过SDK向SDK服务器发送通过宿主程序从宿主程序服务器获取的用户验证结果信息,使SDK服务器在用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
第三方面,本申请实施例提供一种支付方法,应用于宿主程序服务器,方法包括:接收终端设备通过宿主程序反馈的第一用户验证输入信息,终端设备具有软件开发工具包SDK和宿主程序,第一用户验证输入信息在SDK响应于第一通知消息通知宿主程序展示用户验证页面后得到,第一通知消息是SDK服务器基于表征安全验证通过的安全验证结果信息发送的,安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应支付进行安全验证得到的,安全验证请求消息由SDK服务器响应于接收的支付请求消息发送;根据第一用户验证输入信息进行用户验证,得到用户验证结果信息;向终端设备中的宿主程序发送用户验证结果信息,通过宿主程序将用户验证结果信息传输给SDK,以使SDK向SDK服务器发送用户验证结果信息,在用户验证结果信息表征用户验证通过的情况下,使SDK服务器发起付款请求,以完成支付。
第四方面,本申请实施例提供一种SDK服务器,包括:发送模块,用于响应于接收的支付请求消息,向安全控制系统发送安全验证请求消息,安全验证请求消息包括安全验证信息,用于指示安全控制系统根据安全验证信息对支付请求消息对应的支付进行安全验证;接收模块,用于接收安全控制系统发送的安全验证结果信息;发送模块还用于在安全验证结果信息表征安全验证通过的情况下,向终端设备中的SDK发送第一通知消息,终端设备具有SDK和宿主程序,第一通知消息用于指示SDK通知宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息,第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息;发送模块还用于在用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
第五方面,本申请实施例提供一种终端设备,终端设备具有软件开发工具包SDK和宿主程序,终端设备包括:接收模块,用于通过SDK获取SDK服务器发送的第一通知消息,第一通知消息是SDK服务器基于表征安全验证通过的安全验证结果信息发送的,安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应的支付进行安全验证得到的,安全验证请求消息由SDK服务器响应于接收的支付请求消息发送;显示模块,用于响应于第一通知消息,通过SDK通知宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息;发送模块,用于通过宿主程序向宿主程序服务器反馈第一用户验证输入信息,第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息;发送模块还用于通过SDK向SDK服务器发送通过宿主程序从宿主程序服务器获取的用户验证结果信息,使SDK服务器在用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
第六方面,本申请实施例提供一种宿主程序服务器,包括:接收模块,用于接收终端设备通过宿主程序反馈的第一用户验证输入信息,终端设备具有软件开发工具包SDK和宿主程序,第一用户验证输入信息在SDK响应于第一通知消息通知宿主程序展示用户验证页面后得到,第一通知消息是SDK服务器基于表征安全验证通过的安全验证结果信息发送的,安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应支付进行安全验证得到的,安全验证请求消息由SDK服务器响应于接收的支付请求消息发送;验证模块,用于根据第一用户验证输入信息进行用户验证,得到用户验证结果信息;发送模块,用于向终端设备中的宿主程序发送用户验证结果信息,通过宿主程序将用户验证结果信息传输给SDK,以使SDK向SDK服务器发送用户验证结果信息,在用户验证结果信息表征用户验证通过的情况下,使SDK服务器发起付款请求,以完成支付。
第七方面,本申请实施例提供一种SDK服务器,包括:处理器以及存储有计算机程序指令的存储器;处理器执行计算机程序指令时实现第一方面的支付方法。
第八方面,本申请实施例提供一种终端设备,包括:处理器以及存储有计算机程序指令的存储器;处理器执行计算机程序指令时实现第二方面的支付方法。
第九方面,本申请实施例提供一种宿主程序服务器,包括:处理器以及存储有计算机程序指令的存储器;处理器执行计算机程序指令时实现第一方面的支付方法。
第十方面,本申请实施例提供一种支付系统,包括第七方面的SDK服务器、第八方面的终端设备和第九方面的宿主程序服务器。
第十一方面,本申请实施例提供一种计算机可读存储介质,计算机可读存储介质上存储有计算机程序指令,计算机程序指令被处理器执行时实现第一方面的支付方法、第二方面的支付方法、第三方面的支付方法。
申请实施例提供一种支付方法、终端设备、服务器、系统及介质,SDK服务器响应于支付请求消息,向安全控制系统发送安全验证请求消息,以请求安全控制系统对本次支付进行安全验证,以完成SDK所属方所需的安全性方面的验证。在安全验证通过的情况下,SDK服务器向终端设备的SDK发送用于指示SDK通知宿主程序展示用户验证页面的消息,以使SDK能够触发宿主程序主动发起用户验证,以完成宿主程序所属方所需的用户身份安全性方面的验证。在支付过程中实现了SDK所属方和宿主程序所属方两个主体的双向验证,提高了支付的安全性。
附图说明
为了更清楚地说明本申请实施例的技术方案,下面将对本申请实施例中所需要使用的附图作简单的介绍,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本申请实施例提供的支付方法的应用场景的一示例的示意图;
图2为本申请第一方面提供的支付方法的一实施例的流程图;
图3为本申请第一方面提供的支付方法的另一实施例的流程图;
图4为本申请第一方面提供的支付方法的又一实施例的流程图;
图5为本申请第一方面提供的支付方法的又另一实施例的流程图;
图6为本申请第一方面提供的支付方法的再一实施例的流程图;
图7为本申请第二方面提供的支付方法的一实施例的流程图;
图8为本申请第二方面提供的支付方法的另一实施例的流程图;
图9为本申请第二方面提供的支付方法的又一实施例的流程图;
图10为本申请第二方面提供的支付方法的又另一实施例的流程图;
图11为本申请第二方面提供的支付方法的再一实施例的流程图;
图12为本申请第三方面提供的支付方法的一实施例的流程图;
图13为本申请第三方面提供的支付方法的另一实施例的流程图;
图14为本申请实施例提供的支付流程的一示例的流程图;
图15为本申请实施例提供的支付流程的另一示例的流程图;
图16为本申请实施例提供的支付流程的又一示例的流程图;
图17为本申请第四方面提供的SDK服务器的一实施例的结构示意图;
图18为第五方面提供的终端设备的一实施例的结构示意图;
图19为第六方面提供的宿主程序服务器的一实施例的结构示意图;
图20为本申请第七方面提供的SDK服务器的一实施例的结构示意图。
具体实施方式
下面将详细描述本申请的各个方面的特征和示例性实施例,为了使本申请的目的、技术方案及优点更加清楚明白,以下结合附图及具体实施例,对本申请进行进一步详细描述。应理解,此处所描述的具体实施例仅意在解释本申请,而不是限定本申请。对于本领域技术人员来说,本申请可以在不需要这些具体细节中的一些细节的情况下实施。下面对实施例的描述仅仅是为了通过示出本申请的示例来提供对本申请更好的理解。
随着支付技术的发展,电子支付的应用越来越广泛。用户可通过终端设备实现支付。终端设备中安装有用于支付的应用程序,但应用程序的功能有限,为了使得支付功能更加完善,终端设备中还可设置SDK,SDK可集成在应用程序中,和应用程序共同实现支付。在这种情况下,支付过程在终端设备中会涉及应用程序和SDK两个主体,支付过程涉及的主体增多,支付存在的安全风险也随之增大。因此,亟需一种能够提高安全性的支付方法。
本申请实施例提供一种支付方法、终端设备、服务器、系统及介质,能够分别以SDK和宿主程序为主体,进行双重验证,在SDK为主体的验证和宿主程序为主体的验证均通过的情况下,完成支付。通过SDK和宿主程序两方面的验证来保证SDK相关交互和宿主程序相关交互的安全性,从而提高整个支付过程的安全性。
本申请提供的支付方法应用于支付场景中,主要可涉及终端设备、SDK后台系统、宿主程序后台系统和安全控制系统。图1为本申请实施例提供的支付方法的应用场景的一示例的示意图。如图1所示,终端设备11可分别与SDK后台系统12、宿主程序后台系统13进行通信交互,SDK后台系统12还可分别与宿主程序后台系统13、安全控制系统14进行通信交互。
终端设备11具有宿主程序和SDK。终端设备11的支付功能需要宿主程序调用SDK共同实现。终端设备11中的SDK与宿主程序之间可交互。终端设备11中的SDK可与SDK后台系统12通信交互,终端设备11中的宿主程序可与宿主程序后台系统13通信交互。终端设备11为用户用于进行支付的设备,具体可包括手机、平板电脑、电子计算机、只能穿戴设备等,在此并不限定。
SDK后台系统12为SDK的后台系统,可包括一台以上的SDK服务器,在此并不限定SDK后台系统12中SDK服务器的种类和数量。终端设备11在支付过程中,会通过SDK将支付相关的信息发送给SDK后台系统。SDK后台系统也可预先存储支付的用户的账户信息及个人信息等。
在一些实施例中,SDK后台系统12可包括SDK后台子系统和支付码子系统,SDK后台子系统与支付码子系统之间可通信交互,SDK后台子系统还可与终端设备11中的SDK通信交互,支付码子系统可与宿主程序后台系统通信交互。支付码子系统存储有支付码的相关信息,可对支付码进行管理和验证。支付码可包括收款码、付款码等,支付码具体可为二维码或其他形式的图形码,在此并不限定。
宿主程序后台系统13为宿主程序的后台系统,可包括一台以上的宿主程序服务器,在此并不限定宿主程序后台系统13中宿主程序服务器的种类和数量。终端设备11在支付过程中,会通过宿主程序与宿主程序后台系统13交互。宿主程序后台系统13还可与SDK后台系统12通信交互。
安全控制系统14可用于对支付进行安全验证,可包括一台以上的电子设备,在此并不限定安全控制系统14中电子设备的种类和数量。安全控制系统14可与SDK后台系统12通信交互。在SDK后台系统12包括SDK后台子系统和支付码子系统的情况下,安全控制系统14可与其中的SDK后台子系统通信交互。
在一些实施例中,终端设备11中SDK和宿主程序之间的信息传输为加密传输,即终端设备11中SDK和宿主程序之间交互的信息为加密信息。SDK和宿主程序中各自存储有加、解密所需的加、解密算法,SDK和宿主程序中的加、解密算法可根据应用环境、需求等设定,例如,SDK和宿主程序中的加、解密算法可包括SM2算法、SM4算法、数据加密标准(DataEncryption Standard,DES)、RSA算法等,在此并不限定。SDK中加、解密算法所需的密钥可由SDK后台系统12存储和管理,即SDK中加、解密的密钥可存储于SDK后台系统12中的SDK服务器,SDK可通过与SDK后台系统12进行交互以实现加、解密。宿主程序中加、解密算法所需的密钥可由宿主程序后台系统13存储和管理,即宿主程序中加、解密的密钥存储于宿主程序后台系统13中的宿主程序服务器,宿主程序可通过与宿主程序后台系统13进行交互以实现加、解密。通过SDK与宿主程序之间的密文传输,SDK与宿主程序之间传输的信息不容易被窃取,可保证SDK与宿主程序之间的通信安全。
在一些实施例中,终端设备11中SDK可具有安全域,SDK中的信息可存储于安全域。安全域可为加密的数据存储空间,具体可通过硬件和/或软件实现,如通过安全元件(Secure Element,SE)和/或可信执行环境(Trusted Execution Environment,TEE)等实现。SDK可对安全域的权限进行管理,如划分不可开放读取的数据和仅有宿主程序有权限读取的数据等。
下面对本申请中的支付方法、终端设备、服务器、系统及介质依次进行说明。
本申请第一方面提供一种支付方法,该支付方法应用于SDK服务器,即该支付方法可由SDK服务器执行。图2为本申请第一方面提供的支付方法的一实施例的流程图。如图2所示,该支付方法可包括步骤S201至步骤S204。
在步骤S201中,响应于接收的支付请求消息,向安全控制系统发送安全验证请求消息。
支付请求消息用于发起支付。支付请求消息可由终端设备中的SDK向SDK服务器发送,或者,支付请求消息可由支付受理设备向SDK服务器发送。在SDK后台系统包括SDK后台子系统和支付码子系统的情况下,可由支付受理设备向支付码子系统中的SDK服务器发起支付,支付码子系统中的SDK服务器再向SDK后台子系统中的SDK服务器发送支付请求消息。支付请求消息可包括订单信息、终端设备信息、支付信息等。订单信息可包括订单标识、订单发起方、订单明细、订单金额、订单时间等与订单关联的信息,在此并不限定。终端设备信息可包括对进行本次支付的终端设备的地理位置、设备标识等与终端设备关联的信息,在此并不限定。支付信息可包括支付付款方信息、支付收款方信息、支付金额、支付时间等与支付相关的信息,在此并不限定。支付收款方信息可包括商户名称、商户账户等信息,支付付款方信息可包括支付方账户、支付方支付卡信息、支付方标识等信息,在此并不限定。
安全验证请求消息包括安全验证信息。安全验证请求消息用于指示安全控制系统根据安全验证信息对支付请求消息对应的支付进行安全验证。安全验证信息可包括终端设备中SDK向SDK服务器发送的至少部分信息,安全验证信息还可包括SDK服务器中预存的与支付请求消息指示的支付付款方信息等,在此并不限定。例如,安全验证信息可包括支付卡卡号、支付方登录账号、支付方登录账号关联的手机号、支付卡关联的手机号、终端设备标识、终端设备的地理位置、支付金额、支付时间、支付卡的历史支付信息等信息中的一项或两项以上,安全验证信息还可包括其他能够进行安全性方面验证的信息,在此并不限定。
在一些示例中,在安全验证请求消息包括支付卡卡号的情况下,该支付卡卡号可以为终端设备中SDK提供的默认支付卡卡号,若用户在终端设备切换默认支付卡即默认支付卡卡号发生变化的情况下,SDK会向SDK服务器发送包括新的默认支付卡卡号的消息,SDK服务器会被触发向安全控制系统再次发送包括新的默认支付卡卡号的安全验证请求消息。也就是说,若用户在终端设备显示的付款详情页切换默认支付卡,对应地,SDK服务器会重新向安全控制系统发送包括切换后的默认支付卡卡号的安全验证请求消息。
安全控制系统接收到安全验证请求消息,根据安全验证请求消息中的安全验证信息进行安全验证。安全验证可对支付的合法性以及支付的终端设备的登录状态的安全性进行验证,具体可通过安全验证信息是否满足预定的安全判定条件,来确定安全验证是否通过。安全判定条件可根据具体场景、需求等设定,在此并不限定。例如,安全验证信息包括本次支付的终端设备标识和支付卡的历史支付信息,支付卡的历史支付信息包括支付卡的历史支付中的终端设备标识,若本次支付的终端设备标识和支付卡的历史支付中的终端设备标识一致,则安全验证通过;反之,安全验证未通过。又例如,安全验证信息包括本次支付的终端设备的地理位置、支付时间和支付卡的历史支付信息,支付卡的历史支付信息包括支付卡最近一次支付的终端设备的地理位置和支付时间,若支付卡最近一吃支付的支付时间与本次支付的支付时间之间的时长小于预设时长,且支付卡最近一次支付的终端设备的地理位置与本次支付的终端设备的地理位置之间的距离大于预设距离,则安全验证未通过;反之,安全验证通过。还例如,安全验证信息包括支付方登录账号关联的手机号和支付卡关联的手机号,若支付方登录账号关联的手机号与支付卡关联的手机号一致,则安全验证通过;反之,则安全验证未通过。
在一些示例中,在安全风险度非常高的情况下,如账户余额不足、支付为非法支付等情况,才判定安全验证未通过。在安全风险度中、低,能够通过后续的用户验证来判断支付的安全的情况下,可判定安全验证通过。例如,安全验证信息包括本次支付的终端设备标识和支付卡的历史支付信息,支付卡的历史支付信息包括支付卡的历史支付中的终端设备标识,由于用户存在更换终端设备的可能性,若本次支付的终端设备标识和支付卡的历史支付中的终端设备标识不一致,也可视为安全验证通过,在后续过程中可通过用户验证判断是否为用户本人使用更换的终端设备进行支付。又例如,安全验证信息包括本次支付的支付金额和支付方账户余额,若本次支付的支付金额小于等于支付方账户余额,则安全验证通过;反之,安全验证未通过。
在一些示例中,SDK在接收到支付请求消息的情况下,若检测到当前登录的用户账号并未关联支付卡,可发出绑卡提示信息,以提示用户进入绑卡流程以绑定支付卡。在绑定支付卡后,SDK再向安全控制系统发送安全验证请求消息。
在步骤S202中,接收安全控制系统发送的安全验证结果信息。
安全控制系统根据安全验证信息进行安全验证,可得到对于本次支付即支付请求消息指示的支付的安全验证结果信息。安全验证结果信息用于表征安全验证是否通过。若安全验证结果信息表征安全验证未通过,SDK服务器可向终端设备中的SDK发送指示消息,以使SDK发出中止支付的弹窗信息。
在一些示例中,在SDK服务器接收到表征安全验证通过的安全验证结果信息后,终端设备中的SDK可调用预设的查询接口,将本次支付的如付款方信息等支付信息、订单号等订单信息等传输至SDK服务器,SDK服务器可进一步补充本次支付的如商户号等其他订单信息以及与付款相关的其他支付信息等,将支付信息、订单信息同步至宿主程序服务器,以实现SDK服务器与宿主程序服务器关于本次支付的信息的同步。
在一些示例中,在SDK后台系统包括SDK后台子系统和支付码子系统的情况下,在SDK后台子系统中的SDK服务器接收到表征安全验证通过的安全验证结果信息后,SDK后台子系统中的SDK服务器可可调用预设的查询接口,将本次支付的如付款方信息等支付信息、订单号等订单信息等传输至支付码子系统的SDK服务器,支付码子系统的SDK服务器可进一步补充本次支付的如商户号等其他订单信息以及与付款相关的其他支付信息等,将支付信息、订单信息同步至宿主程序服务器,以实现SDK后台系统中的SDK服务器与宿主程序服务器关于本次支付的信息的同步。
在步骤S203中,在安全验证结果信息表征安全验证通过的情况下,向终端设备中的SDK发送第一通知消息。
安全验证结果信息表征安全验证通过,则可再进行宿主程序的所属方的用户验证流程。第一通知消息用于指示SDK通知宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息。第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息。
终端设备中的SDK响应于第一通知消息,可向宿主程序发送用于指示宿主程序展示用户验证页面的消息。宿主程序响应于该消息,宿主程序使终端设备显示用户验证页面。用户验证页面可包括密码填写区、验证码填写区、生物特征采集区等,在此并不限定用户验证的方式。用户向用户验证页面输入的信息即为第一用户验证输入信息。宿主程序可向宿主程序服务器发送第一用户验证输入信息。宿主程序服务器可根据接收到的第一用户验证输入信息进行用户验证,并得到用户验证结果信息。用户验证用于验证用户的身份。用户验证通过表示进行支付操作的用户是合法的用户本人。例如,第一用户验证输入信息为密码,宿主程序服务器验证第一用户验证输入信息与宿主程序服务器中用户注册的密码是否一致,若一致,则用户验证通过;反之,则用户验证未通过。又例如,第一用户验证输入信息为人脸图像,宿主程序服务器验证第一用户验证输入信息与宿主程序服务器中用户预留的人脸图像是否属于同一用户,若属于同一用户,则用户验证通过;反之,则用户验证未通过。
用户验证结果信息用于表征用户验证是否通过。宿主程序服务器可将用户验证结果信息分别向宿主程序和SDK服务器反馈,宿主程序还会将用户验证结果传输给SDK,以使SDK的所属方和宿主程序的所属方均可得知用户验证是否通过。
在一些示例中,在宿主程序展示用户验证页面时,SDK可添加与展示用户验证页面这一动作关联的埋点信息,以便后续对宿主程序展示用户验证页面这一过程的执行情况的分析和排查。
在步骤S204中,在用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
用户验证结果信息表征用户验证通过,表示用户身份安全性较高,可向支付方账户管理系统发起付款请求,正常进行支付。用户验证结果信息表征用户验证未通过,可中止该支付。
在一些实施例中,由于用户验证结果信息在传输过程中可能被窃取或篡改,为了进一步保证支付安全,可通过一致性验证条件来对用户验证结果信息在传输过程中的安全性进行验证。在用户验证结果信息满足一致性验证条件的情况下,发起所述付款请求。一致性验证条件用于判断用户验证结果信息在传输过程中是否安全、有效。用户验证结果信息满足一致性验证条件,表示用户验证结果信息在传输过程中是安全、有效的,可向支付方账户管理系统发起付款请求,正常进行支付,或者,由SDK服务器通过宿主程序服务器向支付方账户管理系统发起付款请求,正常进行支付;用户验证结果信息不满足一致性验证条件,表示用户验证结果信息在传输过程中并不安全、有效,可中止该支付。
在一些示例中,一致性验证条件可包括第一用户验证结果信息和第二用户验证结果信息一致。其中,第一用户验证结果信息为由宿主程序服务器通过宿主程序传输给SDK的用户验证结果信息。第二用户验证结果信息为从宿主程序服务器获取的用户验证结果信息。第一用户验证结果信息和第二用户验证结果信息一致,表示用户验证结果信息在传输过程中是安全、有效的;第一用户验证结果信息和第二用户验证结果信息不一致,表示用户验证结果信息在传输过程中并不安全、有效。
支付成功后,SDK服务器可获取付款结果信息,付款结果信息表征付款是否成功。SDK服务器可将付款结果信息传输给SDK、商户系统等,以将付款是否成功的结果展示给用户、商户等。
在上述支付过程中,用户验证通过后,由于用户验证结果信息的传输、付款、以及付款结果信息的传输都需要一定时间,终端设备不会立即显示支付完成页面,在这种情况下,SDK可控制终端设备显示付款中标识,如包含“loading”字样的图像,在终端设备显示支付完成页面时,停止显示付款中标识。
在本申请实施例中,SDK服务器响应于支付请求消息,向安全控制系统发送安全验证请求消息,以请求安全控制系统对本次支付进行安全验证,以完成SDK所属方所需的安全性方面的验证。在安全验证通过的情况下,SDK服务器向终端设备的SDK发送用于指示SDK通知宿主程序展示用户验证页面的消息,以使SDK能够触发宿主程序主动发起用户验证,以完成宿主程序所属方所需的用户身份安全性方面的验证。在支付过程中实现了SDK所属方和宿主程序所属方两个主体的双向验证,提高了支付的安全性,也满足了SDK所属方和宿主程序所属方两个主体对安全性管控的需求。
在一些示例中,在SDK服务器通过宿主程序服务器向支付方账户管理系统发起付款请求的情况下,SDK服务器可提供SDK所属方的第一支付策略信息,第一支付策略信息可包括SDK所属方的优惠信息、支付活动信息等,可用于参与支付请求消息指示的支付的金额计算。宿主程序服务器可提供宿主程序所属方的第二支付策略信息,第二支付策略信息可包括宿主程序所属方的优惠信息、支付活动信息等,可用于参与支付请求消息指示的支付的金额计算。
在一些实施例中,SDK服务器也可在接收支付请求消息后,直接向宿主程序服务器或通过支付策略系统向宿主程序服务器查询优惠信息、支付活动信息等支付策略信息。
在上述实施例中,SDK与宿主程序之间交互的信息为加密信息,SDK需要对信息进行加、解密。对应地,SDK服务器存储有用于对SDK与宿主程序之间交互的信息进行加、解密的密钥。
在一些实施例中,SDK服务器可向宿主程序服务器请求用户验证方式,并将宿主程序服务器的反馈传输给SDK,以使SDK做出对应的操作。图3为本申请第一方面提供的支付方法的另一实施例的流程图。图3与图2的不同之处在于,图3所示的支付方法还可包括步骤S205至步骤S208,图2中的步骤S203可具体细化为图3中的步骤S2031。
在步骤S205中,在安全验证结果信息表征安全验证通过的情况下,向宿主程序服务器发送用户验证方式请求消息。
用户验证方式请求消息用于向宿主程序服务器请求用户验证方式,可包括支付请求消息指示的支付对应的订单信息、终端设备信息、支付信息中的一项或两项以上。订单信息、终端设备信息和支付信息的具体内容可参见上述实施中的相关说明,在此不再赘述。
宿主程序服务器可根据用户验证方式请求消息中的信息,确定验证操作信息,验证操作信息用于指示是否进行用户验证以及用户验证的方式。宿主程序服务器可存储有用于确定是否进行用户验证以及用户验证的方式的判断条件,可通过用户验证方式请求消息中的信息是否满足参考条件来判断是否进行用户验证以及用户验证的方式。判断条件可根据支付场景、需求等设置,在此并不限定。例如,用户验证方式请求消息可包括支付信息,支付信息包括支付金额,判断条件可包括支付金额范围与是否进行用户验证以及用户验证的方式的对应关系,如判断条件包括:支付金额小于100元,不需进行用户验证;支付金额在100元至500元的范围内,需进行用户验证,且用户验证的方式为密码验证;支付金额在500元至1000元的范围内,需进行用户验证,且用户验证的方式为验证码验证;支付金额大于1000元,需进行用户验证,且用户验证的方式为生物特征验证。又例如,用户验证方式请求消息可包括订单信息和支付信息,订单信息包括订单标识和下订单用户账号,支付信息包括付款方登录账号,判断条件可包括:下订单用户账号与付款方登录账号不一致,需进行用户验证,且用户验证方式为生物特征验证;下订单用户账号与付款方登录账号一致,需进行用户验证,且用户验证方式为密码验证。
宿主程序服务器确定验证操作信息后,可向SDK服务器发送用户验证方式反馈消息。用户验证方式反馈消息包括验证操作信息。
在步骤S206中,接收宿主程序服务器发送的用户验证方式反馈消息。
在步骤S207中,在验证操作信息包括拒绝支付标识的情况下,向SDK发送第二通知消息。
拒绝支付标识表示不需进行用户验证且停止支付。响应于用户验证方式反馈信息,SDK服务器向终端设备中SDK发送第二通知信息。第二通知消息用于指示SDK发出拒绝支付提示信息。SDK响应于第二通知消息,可发出提示信息,以提示用户存在支付风险。例如,提示信息使终端设备显示“宿主程序风险受限”等文字。在一些示例中,用户验证方式反馈消息还可包括拒绝支付原因,对应地,第二通知信息也可包括该拒绝支付原因,SDK响应于第二通知信息发出的提示信息可包括该拒绝支付原因,终端设备可显示该决绝支付原因,以告知用户。拒绝支付原因可包括SDK异常、宿主程序服务器异常等导致用户验证方式标识失败的原因。
在步骤S208中,在验证操作信息包括免密支付标识的情况下,向SDK发送第三通知消息。
免密支付标识表示不需进行用户验证且可继续支付流程。响应于用户验证方式反馈信息,SDK服务器向终端设备中SDK发送第三通知信息。第三通知消息用于指示SDK发出免密支付提示信息。免密支付提示信息可提示用户该支付为免密方式的支付。
在步骤S2031中,在验证操作信息包括用户验证方式标识且安全验证结果信息表征安全验证通过的情况下,向SDK发送第一通知消息。
第一通知消息包括用户验证方式标识。用户验证方式标识用于指示用户验证的方式。第一通知消息用于指示SDK通知宿主程序展示与用户验证方式标识匹配的用户验证页面,以提示用户输入与用户验证方式标识匹配的第一用户验证输入信息。即SDK响应于第一通知消息,可向宿主程序发送包括用户验证方式标识的指示消息,宿主程序根据用户验证方式标识,展现与用户验证方式标识指示的用户验证的方式对应的用户验证页面,对应地,用户输入的第一用户验证输入信息也与用户验证方式标识指示的用户验证的方式对应。
例如,用户验证方式标识为01,用户验证的方式为密码验证,宿主程序展示的用户验证页面为密码验证页面,用户需输入的第一用户验证输入信息为密码;用户验证方式标识为10,用户验证的方式为验证码验证,宿主程序展示的用户验证页面为验证码验证页面,用户需输入的第一用户验证输入信息为验证码;用户验证方式标识为11,用户验证的方式为生物特征验证,宿主程序展示的用户验证页面为生物特征验证页面,用户需输入的第一用户验证输入信息为生物特征。
在一些实施例中,支付请求消息、安全验证请求消息和安全验证结果信息可包括目标宿主程序标识。目标宿主程序标识包括支付请求消息对应的支付的宿主程序标识,即目标宿主程序标识可表征支付请求消息对应的支付关联的宿主程序。
SDK服务器预设有第一对应关系。第一对应关系包括宿主程序标识与用户验证调起方的关系。宿主程序标识用于标识宿主程序。用户验证调起方用于指示展示用户验证页面的主体,用户验证调起方包括终端设备中的SDK或宿主程序。在接收安全验证结果信息后,SDK服务器可根据目标宿主程序标识和第一对应关系,确定与目标宿主程序标识对应的目标用户验证调起方。目标用户验证调起方为在第一对应关系中与目标宿主程序标识对应的用户验证调起方。
在目标用户验证调起方为宿主程序的情况下,SDK服务器向SDK发送第一通知消息。在目标用户验证调起方为SDK的情况下,SDK服务器向SDK发送第四通知消息。第四通知消息用于指示SDK展示用户验证页面,以提示用户输入第二用户验证输入信息。第二用户验证输入信息用于SDK服务器进行用户验证以得到用户验证结果信息。终端设备中的SDK响应于第四通知消息,可由SDK直接展示用户验证页面,对应地,用户验证由SDK服务器执行。终端设备中的SDK可向SDK服务器发送第二用户验证输入信息。SDK服务器根据第二用户验证输入信息进行用户验证,得到用户验证结果信息,用户验证的具体内容可参见上述实施例中宿主程序服务器进行的用户验证的相关说明,在此不再赘述。
通过第一对应关系的设置,可使终端设备中用户验证的主体设置更加灵活,具有更多选择性。
在一些实施例中,支付由商户系统或通过终端设备中安装的商户程序发起,在SDK服务器接收到支付请求消息前,商户系统与SDK之间、SDK与SDK服务器之间还需就订单的相关信息进行交互。图4为本申请第一方面提供的支付方法的又一实施例的流程图。图4与图2的不同之处在于,图4所示的支付方法还可包括步骤S209至步骤S211。
在步骤S209中,响应于商户系统发送的订单请求消息,生成订单标识。
在用户下单生成订单后,商户系统可向SDK服务器发送订单请求消息,以向SDK服务器请求能够标识该笔订单的标识即订单标识。SDK服务器生成的订单标识具体可为订单流水号。
在步骤S210中,向商户系统发送订单反馈消息,以使商户系统向SDK发送SDK调用请求消息。
SDK服务器可生成订单反馈消息,订单反馈消息包括订单标识。SDK服务器向商户系统发送该订单反馈消息,订单反馈消息包括订单标识。商户系统接收到订单反馈消息后,可向终端设备的SDK发送SDK调用请求消息,SDK调用请求包括订单标识。SDK调用请求消息用于请求调用终端设备中的SDK。终端设备中的SDK在初始化的过程中,可采集终端设备的地理位置、终端设备标识等信息。
在步骤S211中,响应于SDK发送的第一订单查询消息,向SDK发送第一查询反馈消息。
SDK可向SDK服务器发送第一订单查询消息,以在SDK服务器通过订单标识查询订单标识对应的订单信息。第一订单查询消息包括订单标识。SDK服务器查找到与订单标识对应的订单消息后,通过第一查询反馈消息将与订单标识对应的订单消息反馈给SDK。第一查询反馈消息包括与订单标识对应的订单信息。SDK接收到第一查询反馈消息后,可向SDK服务器发送支付请求消息。
在一些实施例中,商户可指定特定的付款方付款,订单请求消息包括指定付款方身份信息,即通过订单请求消息制定特定的付款方。SDK向SDK服务器发送的支付请求消息包括如用户登录账号等支付的付款方身份信息,SDK服务器可在指定付款方身份信息与支付请求消息指示的支付的付款方身份信息不一致的情况下,向SDK发送支付中止通知消息,以使SDK发出支付提示信息。支付提示信息可提示用户切换用户登录账号重新支付,支付提示信息也可提示用户支付中止的原因,如支付提示信息为终端设备显示的“登录账号信息与商户指定信息不符,暂无法支付”等字样。
在一些实施例中,支付可为用户利用终端设备扫描他人的收款码发起的支付。在SDK服务器接收到支付请求消息前,SDK与SDK服务器之间还需就订单的相关信息进行交互。图5为本申请第一方面提供的支付方法的又另一实施例的流程图。图5与图2的不同之处在于,图5所示的支付方法还可包括步骤S212和步骤S213。
在步骤S212中,接收终端设备的SDK发送的第二订单查询消息。
终端设备扫描收款码,可得到第一码信息。第一码信息为从收款码中读取得到的码信息。终端设备的SDK可向SDK服务器发送第二订单查询消息。第二订单查询消息用于向SDK服务器请求查询与第一码信息对应的订单消息。第二订单查询消息包括终端设备扫描收款码得到的第一码信息。
在步骤S213中,向SDK发送第二查询反馈消息。
SDK服务器根据第一码信息,查找与第一码信息对应的订单信息。在查找到与第一码信息对应的订单信息后,SDK服务器可生产第二查询反馈消息,并向SDK发送第二查询反馈消息。第二查询反馈消息包括与第一码信息对应的订单信息。
SDK接收到第二查询反馈消息后,可根据用户的输入确定支付金额,生成支付请求消息,向SDK服务器发送支付请求消息。SDK服务器在接收到支付请求消息后,可判断支付请求消息指示的支付的付款卡是否可用,在付款卡可用的情况下,向安全控制系统发送安全验证请求消息。
在一些实施例中,支付可为用户利用终端设备显示付款码,由他人利用支付受理终端扫描付款码发起的支付。在SDK服务器接收到支付请求消息前,SDK可向SDK服务器申请付款码。图6为本申请第一方面提供的支付方法的再一实施例的流程图。图6与图2的不同之处在于,图6所示的支付方法还可包括步骤S214。
在步骤S214中,响应于接收的付款码申请消息,向SDK发送付款码反馈消息。
付款码申请消息由SDK发送。即终端设备中的SDK可向SDK服务器发送付款码申请消息,付款码申请消息用于向SDK服务器申请付款码。SDK服务器为付款码申请消息分配付款码,并通过付款码反馈消息将付款码反馈给SDK。付款码反馈消息包括付款码。
在一些示例中,SDK后台系统包括SDK后台子系统和支付码子系统。SDK可向SDK后台子系统中的SDK服务器发送付款码申请消息,SDK后台子系统中的SDK服务器向支付码子系统中的SDK服务器转发付款码申请消息,支付码子系统中的SDK服务器为付款码申请消息分配付款码,并向SDK后台子系统中的SDK服务器发送付款码反馈消息,SDK后台子系统中的SDK服务器向SDK转发付款码反馈消息。
支付请求消息由支付受理设备基于扫描的付款码生成。SDK收到付款码反馈消息后,可在支付时显示付款码。支付受理设备扫描付款码,得到第二码信息,第二码信息为从付款码中读取得到的码信息。支付受理设备可基于第二码信息生成支付请求消息,并向SDK服务器发送支付请求消息。
本申请第二方面提供一种支付方法,该支付方法应用于终端设备,即该支付方法可由终端设备执行。终端设备具有SDK和宿主程序。图7为本申请第二方面提供的支付方法的一实施例的流程图。如图7所示,该支付方法可包括步骤S301至步骤S304。
在步骤S301中,通过SDK获取SDK服务器发送的第一通知消息。
第一通知消息是SDK服务器基于表征安全验证通过的安全验证结果信息发送的。安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应的支付进行安全验证得到的。安全验证请求消息由SDK服务器响应于接收的支付请求消息发送。
在步骤S302中,响应于第一通知消息,通过SDK通知宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息。
在步骤S303中,通过宿主程序向宿主程序服务器反馈第一用户验证输入信息。
第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息。
在步骤S304中,通过SDK向SDK服务器发送通过宿主程序从宿主程序服务器获取的用户验证结果信息,使SDK服务器在用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
在一些实施例中,用户验证结果信息还用于使SDK服务器在用户验证结果信息满足一致性验证条件的情况下,发起付款请求。
在一些示例中,一致性验证条件包括:第一用户验证结果信息和第二用户验证结果信息一致,第一用户验证结果信息为由宿主程序服务器通过宿主程序传输给SDK的用户验证结果信息,第二用户验证结果信息为从宿主程序服务器获取的用户验证结果信息。
上述步骤S301至步骤S304的具体内容可参见上述实施例中的相关说明,在此不再赘述。
在本申请实施例中,SDK服务器响应于支付请求消息,向安全控制系统发送安全验证请求消息,以请求安全控制系统对本次支付进行安全验证,以完成SDK所属方所需的安全性方面的验证。在安全验证通过的情况下,终端设备中的SDK接收到SDK服务器发送的用于指示SDK通知宿主程序展示用户验证页面的消息,SDK响应于该消息,触发宿主程序主动发起用户验证,以完成宿主程序所属方所需的用户身份安全性方面的验证。在支付过程中实现了SDK所属方和宿主程序所属方两个主体的双向验证,提高了支付的安全性,也满足了SDK所属方和宿主程序所属方两个主体对安全性管控的需求。
在一些实施例中,SDK服务器可向宿主程序服务器请求用户验证方式,SDK可通过SDK服务器获取宿主程序服务器的反馈,并做出对应的操作。图8为本申请第二方面提供的支付方法的另一实施例的流程图。图8与图7的不同之处在于,图8所示的支付方法还可包括步骤S305和步骤S306。
在步骤S305中,响应于SDK接收的第二通知消息,通过SDK发出拒绝提示信息。
第二通知消息由SDK服务器在验证操作信息包括拒绝支付标识的情况下发送。
在步骤S306中,响应于SDK接收的第三通知消息,通过SDK发出免密支付提示信息。
第三通知消息由SDK服务器在验证操作信息包括免密支付标识的情况下发送。
用户验证方式反馈消息包括验证操作信息。用户验证方式反馈消息由宿主服务器响应于用户验证方式请求消息发送。用户验证方式请求消息由SDK服务器在安全验证结果信息表征安全验证通过的情况下向宿主程序服务器发送。用户验证方式请求消息包括支付请求消息指示的支付对应的订单信息、终端设备信息、支付信息中的一项或两项以上。
在一些实施例中,第一通知消息由SDK服务器在验证操作信息包括用户验证方式标识的情况下发送。第一通知消息包括用户验证方式标识,用于指示SDK通知宿主程序展示与用户验证方式标识匹配的用户验证页面,以提示用户输入与用户验证方式标识匹配的第一用户验证输入信息。
上述步骤S305和步骤S306的具体内容可参见上述实施例中的相关说明,在此不再赘述。
在一些实施例中,安全验证结果信息包括目标宿主程序标识。目标宿主程序标识包括支付请求消息对应的支付的宿主程序标识。第一通知消息由SDK服务器在目标用户验证调起方为宿主程序的情况下发送。目标用户验证调起方为第一对应关系中与目标宿主程序标识匹配的用户验证调起方,目标宿主程序标识包括支付请求消息对应的支付的宿主程序标识。第一对应关系包括宿主程序标识与用户验证调起方的关系。
在一些实施例中,在目标用户验证调起方为SDK的情况下,终端设备通过SDK获取SDK服务器发送的第四通知消息。第四通知消息由SDK服务器在目标用户验证调起方为SDK的情况下发送。终端设备响应于第四通知消息,调用SDK展示用户验证页面,以提示用户输入第二用户验证输入信息。终端设备通过SDK向SDK服务器反馈第二用户验证输入信息。第二用户验证输入信息用于SDK服务器进行用户验证以得到用户验证结果信息。
在一些实施例中,支付由商户系统或通过终端设备中安装的商户程序发起,在SDK服务器接收到支付请求消息前,商户系统与SDK之间、SDK与SDK服务器之间还需就订单的相关信息进行交互。图9为本申请第二方面提供的支付方法的又一实施例的流程图。图9与图7的不同之处在于,图9所示的支付方法还可包括步骤S307至步骤S309。
在步骤S307中,通过SDK接收SDK调用请求消息,SDK调用请求消息由商户系统响应于订单反馈消息生成。
订单反馈消息和SDK调用请求消息包括订单标识。订单标识由SDK服务器响应于商户系统发送的订单请求消息生成。
在步骤S308中,响应于SDK调用请求消息,通过SDK向SDK服务器发送第一订单查询消息。
在步骤S309中,通过SDK接收SDK服务器响应于第一订单查询消息发送的第一查询反馈消息。
第一查询反馈消息包括与订单标识对应的订单信息。
在一些实施例中,订单请求消息包括指定付款方身份信息。响应于通过SDK接收的支付中止通知消息,终端设备可通过SDK发出支付提示信息。支付中止通知消息由SDK服务器在指定付款方身份信息与支付请求消息指示的支付的付款方身份信息不一致的情况下发送。
上述步骤S307至步骤S309的具体内容可参见上述实施例中的相关说明,在此不再赘述。
在一些实施例中,支付可为用户利用终端设备扫描他人的收款码发起的支付。在SDK服务器接收到支付请求消息前,SDK与SDK服务器之间还需就订单的相关信息进行交互。图10为本申请第二方面提供的支付方法的又另一实施例的流程图。图10与图7的不同之处在于,图10所示的支付方法还可包括步骤S310至步骤S312。
在步骤310中,扫描付款码,得到第一码信息。
在步骤311中,通过SDK向SDK服务器发送第二订单查询消息。
第二订单查询消息包括第一码信息。
在步骤312中,通过SDK接收SDK服务器发送的第二查询反馈消息。
第二查询反馈消息包括与第一码信息对应的订单信息。
上述步骤S310至步骤S312的具体内容可参见上述实施例中的相关说明,在此不再赘述。
在一些实施例中,支付可为用户利用终端设备显示付款码,由他人利用支付受理终端扫描付款码发起的支付。在SDK服务器接收到支付请求消息前,SDK可向SDK服务器申请付款码。图11为本申请第二方面提供的支付方法的再一实施例的流程图。图11与图7的不同之处在于,图11所示的支付方法还可包括步骤S313至步骤S315。
在步骤S313中,通过SDK向SDK服务器发送付款码申请消息。
在步骤S314中,通过SDK接收SDK服务器发送的付款码反馈消息。
付款码反馈消息包括付款码。
在步骤S315中,显示付款码。
付款码用于被支付受理设备扫描以生成支付请求消息。
上述步骤S313至步骤S315的具体内容可参见上述实施例中的相关说明,在此不再赘述。
本申请第三方面提供一种支付方法,应用于宿主程序服务器,即该支付方法可由宿主程序服务器执行。图12为本申请第三方面提供的支付方法的一实施例的流程图。如图12所示,该支付方法可包括步骤S401至步骤S403。
在步骤S401中,接收终端设备通过宿主程序反馈的第一用户验证输入信息。
第一用户验证输入信息在SDK响应于第一通知消息通知宿主程序展示用户验证页面后得到。第一通知消息是SDK服务器基于表征安全验证通过的安全验证结果信息发送的。安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应支付进行安全验证得到的。安全验证请求消息由SDK服务器响应于接收的支付请求消息发送。
在步骤S402中,根据第一用户验证输入信息进行用户验证,得到用户验证结果信息。
在步骤S403中,向终端设备中的宿主程序发送用户验证结果信息,通过宿主程序将用户验证结果信息传输给SDK,以使SDK向SDK服务器发送用户验证结果信息,在用户验证结果信息表征用户验证通过的情况下,使SDK服务器发起付款请求,以完成支付。
在一些实施例中,在执行步骤S403之后,宿主程序服务器还可向SDK服务器发送用户验证结果信息,以使SDK服务器在用户验证结果信息表征用户验证通过且用户验证结果信息满足一致性验证条件的情况下,发起付款请求,以完成支付。
在一些示例中,一致性验证条件包括第一用户验证结果信息和第二用户验证结果信息一致。第一用户验证结果信息为由宿主程序服务器通过宿主程序传输给SDK的用户验证结果信息,第二用户验证结果信息为从宿主程序服务器获取的用户验证结果信息。
上述步骤S401至步骤S403的具体内容可参见上述实施例中的相关说明,在此不再赘述。
在本申请实施例中,SDK服务器响应于支付请求消息,向安全控制系统发送安全验证请求消息,以请求安全控制系统对本次支付进行安全验证,以完成SDK所属方所需的安全性方面的验证。在安全验证通过的情况下,SDK服务器向终端设备的SDK发送用于指示SDK通知宿主程序展示用户验证页面的消息,以使SDK能够触发宿主程序主动发起用户验证。终端设备可接收用户输入的第一用户验证输入信息,并将第一用户验证输入信息向宿主程序服务器发送,宿主程序服务器可完成宿主程序所属方所需的用户身份安全性方面的验证。在支付过程中实现了SDK所属方和宿主程序所属方两个主体的双向验证,提高了支付的安全性,也满足了SDK所属方和宿主程序所属方两个主体对安全性管控的需求。
在上述实施例中,宿主程序服务器存储有用于对宿主程序与SDK之间交互的信息进行加、解密的密钥,具体内容可参见上述实施例中的现关说明,在此不再赘述。
在一些实施例中,宿主程序服务器可接受SDK服务器的请求,向SDK服务器提供用户验证方式,SDK可通过SDK服务器获取宿主程序服务器的反馈,并做出对应的操作。图13为本申请第三方面提供的支付方法的另一实施例的流程图。图13与图12的不同之处在于,图13所示的支付方法还可包括步骤S404和步骤S405。
在步骤S404中,接收SDK服务器在安全验证结果信息表征安全验证通过的情况下发送的用户验证方式请求消息。
用户验证方式请求消息包括支付请求消息指示的支付对应的订单信息、终端设备信息、支付信息中的一项或两项以上。
在步骤S405中,根据用户验证方式请求消息,向SDK服务器发送用户验证方式反馈消息。
用户验证方式反馈消息包括验证操作信息。
在验证操作信息包括拒绝支付标识的情况下,SDK服务器向SDK发送第二通知消息,第二通知消息用于指示SDK发出拒绝支付提示信息。在验证操作信息包括免密支付标识的情况下,SDK服务器向SDK发送第三通知消息,第三通知消息用于指示SDK发出免密支付提示信息。
在一些实施例中,第一通知消息由SDK服务器在验证操作信息包括用户验证方式标识的情况下发送。第一通知消息包括用户验证方式标识,用于指示SDK通知宿主程序展示与用户验证方式标识匹配的用户验证页面,以提示用户输入与用户验证方式标识匹配的第一用户验证输入信息。
上述步骤S404和步骤S405的具体内容可参见上述实施例中的相关说明,在此不再赘述。
在一些示例中,安全验证结果信息包括目标宿主程序标识。目标宿主程序标识包括支付请求消息对应的支付的宿主程序标识。第一通知消息由SDK服务器在目标用户验证调起方为宿主程序的情况下发送。目标用户验证调起方为第一对应关系中与目标宿主程序标识匹配的用户验证调起方。目标宿主程序标识包括支付请求消息对应的支付的宿主程序标识。第一对应关系包括宿主程序标识与用户验证调起方的关系。
为了便于说明,下面分别以支付由商户系统或通过终端设备中安装的商户程序发起、支付由终端设备扫描他人的收款码发起、支付由支付受理终端扫描付款码发起三种场景为例,对终端设备、系统、服务器之间的支付流程的交互进行说明。
在该示例中,支付由商户系统或通过终端设备中安装的商户程序发起。图14为本申请实施例提供的支付流程的一示例的流程图。终端设备包括SDK和宿主程序。如图14所示,该支付流程包括步骤S501至步骤S522。
在步骤S501中,用户下单后,商户系统向SDK服务器发送订单请求消息。
在步骤S502中,SDK服务器响应于订单请求消息,向商户系统发送订单反馈消息。订单反馈消息可包括SDK服务器生成的订单标识。
在步骤S503中,商户系统向终端设备中SDK发送SDK调用请求消息。
在步骤S504中,SDK采集终端设备信息。
在步骤S505中,SDK向SDK服务器发送第一订单查询消息。
在步骤S506中,SDK服务器向SDK反馈第一查询反馈消息。
在步骤S507中,SDK向SDK服务器发送支付请求消息。
在步骤S508中,SDK服务器向安全控制系统发送安全验证请求消息。
在步骤S509中,安全控制系统对支付请求消息指示的支付进行安全验证。
在步骤S510中,安全控制系统向SDK服务器反馈安全验证结果信息。
在步骤S511中,在安全验证结果信息表征安全验证通过的情况下,SDK服务器向宿主程序服务器发送用户验证方式请求消息。
在步骤S512中,宿主程序服务器响应于用户验证方式请求消息,向SDK服务器发送用户验证方式反馈消息。用户验证方式反馈消息包括用户验证方式标识。
在步骤S513中,SDK服务器向SDK发送第一通知消息。第一通知消息包括用户验证方式标识。
在步骤S514中,SDK向宿主程序传输用户验证方式标识。
在步骤S515中,宿主程序被触发,展示与用户验证方式标识匹配的用户验证页面。
在步骤S516中,宿主程序接收用户输入的第一用户验证输入信息,向宿主程序服务器发送第一用户验证输入信息。
在步骤S517中,宿主程序服务器根据第一用户验证输入信息进行用户验证,得到用户验证结果信息。
在步骤S518中,SDK服务器从宿主程序服务器获取用户验证结果信息。为了便于说明,将SDK服务器直接从宿主服务器获取到的用户验证结果信息称为第二用户验证结果信息。
在步骤S519中,宿主程序服务器向宿主程序发送用户验证结果信息。
在步骤S520中,宿主程序将用户验证结果信息反馈给SDK。
在步骤S521中,SDK将用户验证结果信息反馈给SDK服务器。为了便于说明,将SDK服务器从SDK获取到的用户验证结果信息称为第一用户验证结果信息。
在步骤S522中,在第一用户验证结果信息和第二用户验证结果信息一致的情况下,SDK服务器发起付款请求,以完成支付。
上述步骤S501至步骤S522的具体内容可参见上述实施例中的相关说明,在此不再赘述。
在该示例中,支付由终端设备扫描他人的收款码发起。图15为本申请实施例提供的支付流程的另一示例的流程图。终端设备包括SDK和宿主程序。如图15所示,该支付流程可包括步骤S601至步骤S621。
在步骤S601中,终端设备扫描收款码,得到第一码信息,SDK向SDK服务器发送第二订单查询消息。第二订单查询消息包括第一码信息。
在步骤S602中,SDK服务器向SDK发送第二查询反馈消息。
在步骤S603中,SDK接收用户输入,确定支付金额。
在步骤S604中,SDK向SDK服务器发送支付请求消息。
在步骤S605中,SDK服务器判断是否有可用的付款卡。
在步骤S606中,在存在可用的付款卡的情况下,SDK服务器向安全控制系统发送安全验证请求消息。
在步骤S607中,安全控制系统对支付请求消息指示的支付进行安全验证。
在步骤S608中,安全控制系统向SDK服务器反馈安全验证结果信息。
在步骤S609中,在安全验证结果信息表征安全验证通过的情况下,SDK服务器向宿主程序服务器发送用户验证方式请求消息。
在步骤S610中,宿主程序服务器响应于用户验证方式请求消息,向SDK服务器发送用户验证方式反馈消息。用户验证方式反馈消息包括用户验证方式标识。
在步骤S611中,SDK服务器向SDK发送第一通知消息。第一通知消息包括用户验证方式标识。
在步骤S612中,SDK向宿主程序传输用户验证方式标识。
在步骤S613中,宿主程序被触发,展示与用户验证方式标识匹配的用户验证页面。
在步骤S614中,宿主程序接收用户输入的第一用户验证输入信息,向宿主程序服务器发送第一用户验证输入信息。
在步骤S615中,宿主程序服务器根据第一用户验证输入信息进行用户验证,得到用户验证结果信息。
在步骤S616中,SDK服务器从宿主程序服务器获取用户验证结果信息。为了便于说明,将SDK服务器直接从宿主服务器获取到的用户验证结果信息称为第二用户验证结果信息。
在步骤S617中,宿主程序服务器向宿主程序发送用户验证结果信息。
在步骤S618中,宿主程序将用户验证结果信息反馈给SDK。
在步骤S619中,SDK将用户验证结果信息反馈给SDK服务器。为了便于说明,将SDK服务器从SDK获取到的用户验证结果信息称为第一用户验证结果信息。
在步骤S620中,在第一用户验证结果信息和第二用户验证结果信息一致的情况下,SDK服务器向宿主程序服务器发起付款请求。
在步骤S621中,宿主程序服务器向付款方账户管理系统发起付款请求,以完成支付。
上述步骤S601至步骤S621的具体内容可参见上述实施例中的相关说明,在此不再赘述。
在该示例中,支付由支付受理终端扫描终端设备显示的付款码发起。终端设备包括SDK和宿主程序。这里以SDK后台系统包括SDK后台子系统和支付码子系统为例进行说明,为了便于说明,将SDK后台子系统中的SDK服务器称为第一SDK服务器,将支付码子系统中的SDK服务器称为第二SDK服务器。图16为本申请实施例提供的支付流程的又一示例的流程图。如图16所示,该支付流程可包括步骤S701至步骤S723。
在步骤S701中,终端设备中SDK通过第一SDK服务器向第二SDK服务器发送付款码申请消息。
在步骤S702中,第二SDK服务器分配付款码,并通过第一SDK服务器向SDK发送付款码反馈消息。付款码反馈消息包括付款码。
在步骤S703中,支付受理终端扫描终端设备显示的付款码,得到第二码信息,向第二SDK服务器发送支付请求消息。
在步骤S704中,第二SDK服务器可通过支付策略系统向宿主程序服务器发送支付策略查询消息。
在步骤S705中,宿主程序服务器通过支付策略系统向第二SDK服务器反馈支付策略信息。
在步骤S706中,第二SDK服务器向第一SDK服务器发送附加处理请求消息。附加处理请求消息包括支付策略信息。
在步骤S707中,第一SDK服务器向安全控制系统发送安全验证请求消息。
在步骤S708中,安全控制系统对支付请求消息指示的支付进行安全验证。
在步骤S709中,安全控制系统向第一SDK服务器反馈安全验证结果信息。
在步骤S710中,第一SDK服务器通过第二SDK服务器将支付信息、订单信息等信息同步至宿主程序服务器。
在步骤S711中,第一SDK服务器通过第二SDK服务器向宿主程序服务器发送用户验证方式请求消息。
在步骤S712中,宿主程序服务器通过第二SDK服务器向第一SDK服务器发送用户验证方式反馈消息。用户验证方式反馈消息包括用户验证方式标识。
在步骤S713中,第一SDK服务器向SDK发送第一通知消息。第一通知消息包括用户验证方式标识。
在步骤S714中,SDK向宿主程序传输用户验证方式标识。
在步骤S715中,宿主程序被触发,展示与用户验证方式标识匹配的用户验证页面。
在步骤S716中,宿主程序接收用户输入的第一用户验证输入信息,向宿主程序服务器发送第一用户验证输入信息。
在步骤S717中,宿主程序服务器根据第一用户验证输入信息进行用户验证,得到用户验证结果信息。
在步骤S718中,第一SDK服务器通过第二SDK服务器从宿主程序服务器获取用户验证结果信息。为了便于说明,将SDK服务器通过第二SDK服务器从宿主服务器获取到的用户验证结果信息称为第二用户验证结果信息。
在步骤S719中,宿主程序服务器向宿主程序发送用户验证结果信息。
在步骤S720中,宿主程序将用户验证结果信息反馈给SDK。
在步骤S721中,SDK将用户验证结果反馈给第一SDK服务器。为了便于说明,将第一SDK服务器从SDK获取到的用户验证结果信息称为第一用户验证结果信息。若宿主程序的所属方与付款卡所属方相同,跳转步骤S724;若宿主程序的所属方与付款卡所属方不同,跳转步骤S725
在步骤S722中,在第一用户验证结果信息和第二用户验证结果信息一致的情况下,第一SDK服务器通过第二SDK服务器和宿主程序服务器向付款方账户管理系统发起付款请求,以完成支付。
在步骤S723中,在第一用户验证结果信息和第二用户验证结果信息一致的情况下,第一SDK服务器通过第二SDK服务器向付款方账户管理系统发起付款请求,以完成支付。
在上述步骤S722和步骤S723之前,若支付使用了支付策略信息,第二SDK服务器还可与支付策略系统交互以承兑支付策略信息。
上述步骤S701至步骤S723的具体内容可参见上述实施例中的相关说明,在此不再赘述。
本申请第四方面提供一种SDK服务器。图17为本申请第四方面提供的SDK服务器的一实施例的结构示意图。如图17所示,该SDK服务器800可包括发送模块801和接收模块802。
发送模块801可用于响应于接收的支付请求消息,向安全控制系统发送安全验证请求消息。
安全验证请求消息包括安全验证信息,用于指示安全控制系统根据安全验证信息对支付请求消息对应的支付进行安全验证。
接收模块802可用于接收安全控制系统发送的安全验证结果信息。
发送模块801还可用于在安全验证结果信息表征安全验证通过的情况下,向终端设备中的SDK发送第一通知消息。
终端设备具有SDK和宿主程序。第一通知消息用于指示SDK通知宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息。第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息。
发送模块801还可用于在用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
在一些实施例中,发送模块801可用于在用户验证结果信息满足一致性验证条件的情况下,发起所述付款请求。
在一些示例中,一致性验证条件包括:第一用户验证结果信息和第二用户验证结果信息一致。
第一用户验证结果信息为由宿主程序服务器通过宿主程序传输给SDK的用户验证结果信息。第二用户验证结果信息为从宿主程序服务器获取的用户验证结果信息。
在本申请实施例中,SDK服务器响应于支付请求消息,向安全控制系统发送安全验证请求消息,以请求安全控制系统对本次支付进行安全验证,以完成SDK所属方所需的安全性方面的验证。在安全验证通过的情况下,SDK服务器向终端设备的SDK发送用于指示SDK通知宿主程序展示用户验证页面的消息,以使SDK能够触发宿主程序主动发起用户验证,以完成宿主程序所属方所需的用户身份安全性方面的验证。在支付过程中实现了SDK所属方和宿主程序所属方两个主体的双向验证,提高了支付的安全性,也满足了SDK所属方和宿主程序所属方两个主体对安全性管控的需求。
在一些示例中,SDK服务器存储有用于对SDK与宿主程序之间交互的信息进行加、解密的密钥。
在一些实施例中,发送模块801还可用于在安全验证结果信息表征安全验证通过的情况下,向宿主程序服务器发送用户验证方式请求消息。
用户验证方式请求消息包括支付请求消息指示的支付对应的订单信息、终端设备信息、支付信息中的一项或两项以上。
接收模块802还可用于接收宿主程序服务器发送的用户验证方式反馈消息。
用户验证方式反馈消息包括验证操作信息。
发送模块801还可用于在验证操作信息包括拒绝支付标识的情况下,向SDK发送第二通知消息。
第二通知消息用于指示SDK发出拒绝支付提示信息。
接收模块802还可用于在验证操作信息包括免密支付标识的情况下,向SDK发送第三通知消息。
第三通知消息用于指示SDK发出免密支付提示信息。
在一些实施例中,发送模块801可用于:在验证操作信息包括用户验证方式标识的情况下,向SDK发送第一通知消息。
第一通知消息包括用户验证方式标识,用于指示SDK通知宿主程序展示与用户验证方式标识匹配的用户验证页面,以提示用户输入与用户验证方式标识匹配的第一用户验证输入信息。
在一些实施例中,SDK服务器还可包括查询模块。
查询模块可用于根据目标宿主程序标识和预设的第一对应关系,确定与目标宿主程序标识对应的目标用户验证调起方。
第一对应关系包括宿主程序标识与用户验证调起方的关系。
发送模块801可用于在目标用户验证调起方为宿主程序的情况下,向SDK发送第一通知消息。
在一些实施例中,发送模块801还可用于在目标用户验证调起方为SDK的情况下,向SDK发送第四通知消息。
第四通知消息用于指示SDK展示用户验证页面,以提示用户输入第二用户验证输入信息。第二用户验证输入信息用于SDK服务器进行用户验证以得到用户验证结果信息。
在一些实施例中,SDK服务器800还可包括订单标识生成模块。
订单标识生成模块可用于响应于商户系统发送的订单请求消息,生成订单标识。
发送模块801还可用于向商户系统发送订单反馈消息,以使商户系统向SDK发送SDK调用请求消息。
订单反馈消息和SDK调用请求消息包括订单标识。
发送模块801还可用于响应于SDK发送的第一订单查询消息,向SDK发送第一查询反馈消息。
第一查询反馈消息包括与订单标识对应的订单信息。
在一些实施例中,订单请求消息包括指定付款方身份信息。
发送模块801还可用于在指定付款方身份信息与支付请求消息指示的支付的付款方身份信息不一致的情况下,向SDK发送支付中止通知消息,以使SDK发出支付提示信息。
在一些实施例中,接收模块802还可用于接收终端设备的SDK发送的第二订单查询消息。
第二订单查询消息包括终端设备扫描收款码得到的第一码信息。
发送模块801还可用于向SDK发送第二查询反馈消息。
第二查询反馈消息包括与第一码信息对应的订单信息。
在一些实施例中,发送模块801还可用于响应于接收的付款码申请消息,向SDK发送付款码反馈消息。
付款码申请消息由SDK发送。付款码反馈消息包括付款码。对应地,支付请求消息由支付受理设备基于扫描的付款码生成。
本申请第五方面提供一种终端设备。终端设备具有SDK和宿主程序。图18为第五方面提供的终端设备的一实施例的结构示意图。如图18所示,该终端设备900可包括接收模块901、显示模块902和发送模块903。
接收模块901可用于通过SDK获取SDK服务器发送的第一通知消息。
第一通知消息是SDK服务器基于表征安全验证通过的安全验证结果信息发送的。安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应的支付进行安全验证得到的。安全验证请求消息由SDK服务器响应于接收的支付请求消息发送。
显示模块902可用于响应于第一通知消息,通过SDK通知宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息。
发送模块903可用于通过宿主程序向宿主程序服务器反馈第一用户验证输入信息。
第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息。
发送模块903还可用于通过SDK向SDK服务器发送通过宿主程序从宿主程序服务器获取的用户验证结果信息,使SDK服务器在用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
在一些实施例中,所述用户验证结果信息还用于使所述SDK服务器在所述用户验证结果信息满足一致性验证条件的情况下,发起所述付款请求。
在一些示例中,一致性验证条件包括:第一用户验证结果信息和第二用户验证结果信息一致。第一用户验证结果信息为由宿主程序服务器通过宿主程序传输给SDK的用户验证结果信息,第二用户验证结果信息为从宿主程序服务器获取的用户验证结果信息。
在本申请实施例中,SDK服务器响应于支付请求消息,向安全控制系统发送安全验证请求消息,以请求安全控制系统对本次支付进行安全验证,以完成SDK所属方所需的安全性方面的验证。在安全验证通过的情况下,终端设备中的SDK接收到SDK服务器发送的用于指示SDK通知宿主程序展示用户验证页面的消息,SDK响应于该消息,触发宿主程序主动发起用户验证,以完成宿主程序所属方所需的用户身份安全性方面的验证。在支付过程中实现了SDK所属方和宿主程序所属方两个主体的双向验证,提高了支付的安全性,也满足了SDK所属方和宿主程序所属方两个主体对安全性管控的需求。
在一些示例中,SDK具有安全域,SDK中的信息存储于安全域。
SDK与宿主程序之间交互的信息为加密信息。SDK中加、解密的密钥存储于SDK服务器。宿主程序中加、解密的密钥存储于宿主程序服务器。
在一些实施例中,显示模块902还可用于响应于SDK接收的第二通知消息,通过SDK发出拒绝提示信息。
第二通知消息由SDK服务器在验证操作信息包括拒绝支付标识的情况下发送。
显示模块902还可用于响应于SDK接收的第三通知消息,通过SDK发出免密支付提示信息。
第三通知消息由SDK服务器在验证操作信息包括免密支付标识的情况下发送。
其中,用户验证方式反馈消息包括验证操作信息。用户验证方式反馈消息由宿主服务器响应于用户验证方式请求消息发送。用户验证方式请求消息由SDK服务器在安全验证结果信息表征安全验证通过的情况下向宿主程序服务器发送。用户验证方式请求消息包括支付请求消息指示的支付对应的订单信息、终端设备信息、支付信息中的一项或两项以上。
在一些实施例中,第一通知消息由SDK服务器在验证操作信息包括用户验证方式标识的情况下发送。第一通知消息包括用户验证方式标识,用于指示SDK通知宿主程序展示与用户验证方式标识匹配的用户验证页面,以提示用户输入与用户验证方式标识匹配的第一用户验证输入信息。
在一些实施例中,安全验证结果信息包括目标宿主程序标识。目标宿主程序标识包括支付请求消息对应的支付的宿主程序标识。第一通知消息由SDK服务器在目标用户验证调起方为宿主程序的情况下发送,目标用户验证调起方为第一对应关系中与目标宿主程序标识匹配的用户验证调起方,目标宿主程序标识包括支付请求消息对应的支付的宿主程序标识,第一对应关系包括宿主程序标识与用户验证调起方的关系。
在一些实施例中,接收模块901还可用于通过SDK获取SDK服务器发送的第四通知消息。第四通知消息由SDK服务器在目标用户验证调起方为SDK的情况下发送。
显示模块902还可用于响应于第四通知消息,调用SDK展示用户验证页面,以提示用户输入第二用户验证输入信息。
发送模块903还可用于通过SDK向SDK服务器反馈第二用户验证输入信息。
第二用户验证输入信息用于SDK服务器进行用户验证以得到用户验证结果信息。
在一些实施例中,接收模块901还可用于通过SDK接收SDK调用请求消息。
SDK调用请求消息由商户系统响应于订单反馈消息生成。订单反馈消息和SDK调用请求消息包括订单标识。订单标识由SDK服务器响应于商户系统发送的订单请求消息生成。
发送模块903还可用于响应于SDK调用请求消息,通过SDK向SDK服务器发送第一订单查询消息。
接收模块901还可用于通过SDK接收SDK服务器响应于第一订单查询消息发送的第一查询反馈消息。
第一查询反馈消息包括与订单标识对应的订单信息。
在一些实施例中,订单请求消息包括指定付款方身份信息。
显示模块902还可用于响应于通过SDK接收的支付中止通知消息,通过SDK发出支付提示信息。
支付中止通知消息由SDK服务器在指定付款方身份信息与支付请求消息指示的支付的付款方身份信息不一致的情况下发送。
在一些实施例中,终端设备900还可包括扫描模块。
扫描模块可用于扫描付款码,得到第一码信息;
发送模块903还可用于通过SDK向SDK服务器发送第二订单查询消息。
第二订单查询消息包括第一码信息。
接收模块901还可用于通过SDK接收SDK服务器发送的第二查询反馈消息。
第二查询反馈消息包括与第一码信息对应的订单信息。
在一些实施例中,发送模块903还可用于通过SDK向SDK服务器发送付款码申请消息。
接收模块901还可用于通过SDK接收SDK服务器发送的付款码反馈消息,付款码反馈消息包括付款码。
显示模块902还可用于显示付款码。
付款码用于被支付受理设备扫描以生成支付请求消息。
本申请第六方面提供一种宿主程序服务器。图19为第六方面提供的宿主程序服务器的一实施例的结构示意图。如图19所示,宿主程序服务器1000可包括接收模块1001、验证模块1002和发送模块1003。
接收模块1001可用于接收终端设备通过宿主程序反馈的第一用户验证输入信息。
终端设备具有软件开发工具包SDK和宿主程序。第一用户验证输入信息在SDK响应于第一通知消息通知宿主程序展示用户验证页面后得到。第一通知消息是SDK服务器基于表征安全验证通过的安全验证结果信息发送的。安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应支付进行安全验证得到的。安全验证请求消息由SDK服务器响应于接收的支付请求消息发送。
验证模块1002可用于根据第一用户验证输入信息进行用户验证,得到用户验证结果信息。
发送模块1003可用于向终端设备中的宿主程序发送用户验证结果信息,通过宿主程序将用户验证结果信息传输给SDK,以使SDK向SDK服务器发送用户验证结果信息,在用户验证结果信息表征用户验证通过的情况下,使SDK服务器发起付款请求,以完成支付。
在一些实施例中,发送模块1003还可用于向SDK服务器发送用户验证结果信息,以使SDK服务器在用户验证结果信息表征用户验证通过且用户验证结果信息满足一致性验证条件的情况下,发起付款请求,以完成支付。
在一些示例中,一致性验证条件包括第一用户验证结果信息和第二用户验证结果信息一致。
第一用户验证结果信息为由宿主程序服务器通过宿主程序传输给SDK的用户验证结果信息。第二用户验证结果信息为从宿主程序服务器获取的用户验证结果信息。
在本申请实施例中,SDK服务器响应于支付请求消息,向安全控制系统发送安全验证请求消息,以请求安全控制系统对本次支付进行安全验证,以完成SDK所属方所需的安全性方面的验证。在安全验证通过的情况下,SDK服务器向终端设备的SDK发送用于指示SDK通知宿主程序展示用户验证页面的消息,以使SDK能够触发宿主程序主动发起用户验证。终端设备可接收用户输入的第一用户验证输入信息,并将第一用户验证输入信息向宿主程序服务器发送,宿主程序服务器可完成宿主程序所属方所需的用户身份安全性方面的验证。在支付过程中实现了SDK所属方和宿主程序所属方两个主体的双向验证,提高了支付的安全性,也满足了SDK所属方和宿主程序所属方两个主体对安全性管控的需求。
在一些示例中,宿主程序服务器存储有用于对宿主程序与SDK之间交互的信息进行加、解密的密钥。
在一些实施例中,接收模块1001还可用于接收SDK服务器在安全验证结果信息表征安全验证通过的情况下发送的用户验证方式请求消息。
用户验证方式请求消息包括支付请求消息指示的支付对应的订单信息、终端设备信息、支付信息中的一项或两项以上。
发送模块1003还可用于根据用户验证方式请求消息,向SDK服务器发送用户验证方式反馈消息。
用户验证方式反馈消息包括验证操作信息。
其中,在验证操作信息包括拒绝支付标识的情况下,SDK服务器向SDK发送第二通知消息,第二通知消息用于指示SDK发出拒绝支付提示信息。在验证操作信息包括免密支付标识的情况下,SDK服务器向SDK发送第三通知消息,第三通知消息用于指示SDK发出免密支付提示信息。
在一些实施例中,第一通知消息由SDK服务器在验证操作信息包括用户验证方式标识的情况下发送。第一通知消息包括用户验证方式标识,用于指示SDK通知宿主程序展示与用户验证方式标识匹配的用户验证页面,以提示用户输入与用户验证方式标识匹配的第一用户验证输入信息。
在一些实施例中,安全验证结果信息包括目标宿主程序标识。目标宿主程序标识包括支付请求消息对应的支付的宿主程序标识。
第一通知消息由SDK服务器在目标用户验证调起方为宿主程序的情况下发送。目标用户验证调起方为第一对应关系中与目标宿主程序标识匹配的用户验证调起方。目标宿主程序标识包括支付请求消息对应的支付的宿主程序标识。第一对应关系包括宿主程序标识与用户验证调起方的关系。
本申请第七方面提供了一种SDK服务器。图20为本申请第七方面提供的SDK服务器的一实施例的结构示意图。如图20所示,SDK服务器1100包括存储器1101、处理器1102及存储在存储器1101上并可在处理器1102上运行的计算机程序。
在一个示例中,上述处理器1102可以包括中央处理器(CPU),或者特定集成电路(Application Specific Integrated Circuit,ASIC),或者可以被配置成实施本申请实施例的一个或多个集成电路。
存储器1101可包括只读存储器(Read-Only Memory,ROM),随机存取存储器(Random Access Memory,RAM),磁盘存储介质设备,光存储介质设备,闪存设备,电气、光学或其他物理/有形的存储器存储设备。因此,通常,存储器包括一个或多个编码有包括计算机可执行指令的软件的有形(非暂态)计算机可读存储介质(例如,存储器设备),并且当该软件被执行(例如,由一个或多个处理器)时,其可操作来执行参考根据本申请第一方面实施例中的支付方法所描述的操作。
处理器1102通过读取存储器1101中存储的可执行程序代码来运行与可执行程序代码对应的计算机程序,以用于实现上述第一方面的实施例中的支付方法。
在一些示例中,SDK服务器1100还可包括通信接口1103和总线1104。其中,如图20所示,存储器1101、处理器1102、通信接口1103通过总线1104连接并完成相互间的通信。
通信接口1103,主要用于实现本申请实施例中各模块、装置、单元和/或设备之间的通信。也可通过通信接口1103接入输入设备和/或输出设备。
总线1104包括硬件、软件或两者,将SDK服务器1100的部件彼此耦接在一起。举例来说而非限制,总线1104可包括加速图形端口(Accelerated Graphics Port,AGP)或其他图形总线、增强工业标准架构(Enhanced Industry Standard Architecture,EISA)总线、前端总线(Front Side Bus,FSB)、超传输(HyperTransport,HT)互连、工业标准架构(Industry Standard Architecture,ISA)总线、无限带宽互连、低引脚数(Low pin count,LPC)总线、存储器总线、微信道架构(MicroChannel Architecture,MCA)总线、外围组件互连(Peripheral Component Interconnect,PCI)总线、PCI-Express(PCI-E)总线、串行高级技术附件(Serial Advanced Technology Attachment,SATA)总线、视频电子标准协会局部(Video Electronics Standards Association Local Bus,VLB)总线或其他合适的总线或者两个或更多个以上这些的组合。在合适的情况下,总线1104可包括一个或多个总线。尽管本申请实施例描述和示出了特定的总线,但本申请考虑任何合适的总线或互连。
本申请第八方面提供了一种终端设备,终端设备可包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序。存储器和处理器的种类及关系可参见上述SDK服务器中存储器和处理器的相关说明。与上述SDK服务器的不同之处包括,当存储器中的软件被执行时,其可操作来执行参考根据本申请第二方面实施例中的支付方法所描述的操作;以及,处理器通过读取存储器中存储的可执行程序代码来运行与可执行程序代码对应的计算机程序,以用于实现上述第二方面的实施例中的支付方法。在一些示例中,终端设备还可包括通信接口和总线。存储器、处理器、通信接口可通过总线连接并完成相互间的通信,存储器、处理器、通信接口和总线之间的通信连接可参见图20所示的SDK服务器中的存储器、处理器、通信接口和总线之间的通信连接,在此不再赘述。
本申请第九方面提供了一种宿主程序服务器,宿主程序服务器可包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序。存储器和处理器的种类及关系可参见上述SDK服务器中存储器和处理器的相关说明。与上述SDK服务器的不同之处包括,当存储器中的软件被执行时,其可操作来执行参考根据本申请第三方面实施例中的支付方法所描述的操作;以及,处理器通过读取存储器中存储的可执行程序代码来运行与可执行程序代码对应的计算机程序,以用于实现上述第三方面的实施例中的支付方法。在一些示例中,宿主程序服务器还可包括通信接口和总线。存储器、处理器、通信接口可通过总线连接并完成相互间的通信,存储器、处理器、通信接口和总线之间的通信连接可参见图20所示的SDK服务器中的存储器、处理器、通信接口和总线之间的通信连接,在此不再赘述。
本申请第十方面提供一种支付系统,该支付系统可包括上述实施例中的SDK服务器、终端设备和宿主程序服务器,SDK服务器、终端设备和宿主程序服务器的具体内容可参见上述实施例中的相关说明,在此不再赘述。
本申请第十一方面还提供一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序指令,该计算机程序指令被处理器执行时可实现上述实施例中第一方面的支付方法、第二方面的支付方法和/或第三方面的支付方法,且能达到相同的技术效果,为避免重复,这里不再赘述。其中,上述计算机可读存储介质可包括非暂态计算机可读存储介质,如只读存储器(Read-Only Memory,简称ROM)、随机存取存储器(Random AccessMemory,简称RAM)、磁碟或者光盘等,在此并不限定。
本申请实施例还可提供一种计算机程序产品,该计算机程序产品中的指令可由SDK服务器、终端设备、宿主程序服务器的处理器执行时,使得SDK服务器、终端设备、宿主程序服务器执行上述第一方面的实施例中的支付方法、第二方面的实施例中的支付方法、第三方面的实施例中的支付方法。
需要明确的是,本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同或相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。对于SDK服务器实施例、终端设备实施例、宿主程序服务器实施例、系统实施例、计算机可读存储介质实施例和计算机程序产品实施例而言,相关之处可以参见方法实施例的说明部分。本申请并不局限于上文所描述并在图中示出的特定步骤和结构。本领域的技术人员可以在领会本申请的精神之后,作出各种改变、修改和添加,或者改变步骤之间的顺序。并且,为了简明起见,这里省略对已知方法技术的详细描述。
上面参考根据本申请的实施例的方法、装置(系统)和计算机程序产品的流程图和/或框图描述了本申请的各方面。应当理解,流程图和/或框图中的每个方框以及流程图和/或框图中各方框的组合可以由计算机程序指令实现。这些计算机程序指令可被提供给通用计算机、专用计算机、或其它可编程数据处理装置的处理器,以产生一种机器,使得经由计算机或其它可编程数据处理装置的处理器执行的这些指令使能对流程图和/或框图的一个或多个方框中指定的功能/动作的实现。这种处理器可以是但不限于是通用处理器、专用处理器、特殊应用处理器或者现场可编程逻辑电路。还可理解,框图和/或流程图中的每个方框以及框图和/或流程图中的方框的组合,也可以由执行指定的功能或动作的专用硬件来实现,或可由专用硬件和计算机指令的组合来实现。
本领域技术人员应能理解,上述实施例均是示例性而非限制性的。在不同实施例中出现的不同技术特征可以进行组合,以取得有益效果。本领域技术人员在研究附图、说明书及权利要求书的基础上,应能理解并实现所揭示的实施例的其他变化的实施例。在权利要求书中,术语“包括”并不排除其他装置或步骤;数量词“一个”不排除多个;术语“第一”、“第二”用于标示名称而非用于表示任何特定的顺序。权利要求中的任何附图标记均不应被理解为对保护范围的限制。权利要求中出现的多个部分的功能可以由一个单独的硬件或软件模块来实现。某些技术特征出现在不同的从属权利要求中并不意味着不能将这些技术特征进行组合以取得有益效果。
Claims (39)
1.一种支付方法,其特征在于,应用于软件开发工具包SDK服务器,所述方法包括:
响应于接收的支付请求消息,向安全控制系统发送安全验证请求消息,所述安全验证请求消息包括安全验证信息,用于指示所述安全控制系统根据所述安全验证信息对所述支付请求消息对应的支付进行安全验证;
接收所述安全控制系统发送的安全验证结果信息;
在所述安全验证结果信息表征安全验证通过的情况下,向终端设备中的SDK发送第一通知消息,所述终端设备具有SDK和宿主程序,所述第一通知消息用于指示所述SDK通知所述宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息,所述第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息;
在所述用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
2.根据权利要求1所述的方法,其特征在于,在所述接收所述安全控制系统发送的安全验证结果信息之后,还包括:
在所述安全验证结果信息表征安全验证通过的情况下,向所述宿主程序服务器发送用户验证方式请求消息,所述用户验证方式请求消息包括所述支付请求消息指示的支付对应的订单信息、终端设备信息、支付信息中的一项或两项以上;
接收所述宿主程序服务器发送的用户验证方式反馈消息,所述用户验证方式反馈消息包括验证操作信息;
在所述验证操作信息包括拒绝支付标识的情况下,向所述SDK发送第二通知消息,所述第二通知消息用于指示所述SDK发出拒绝支付提示信息;
在所述验证操作信息包括免密支付标识的情况下,向所述SDK发送第三通知消息,所述第三通知消息用于指示所述SDK发出免密支付提示信息。
3.根据权利要求2所述的方法,其特征在于,所述向终端设备中的SDK发送第一通知消息,包括:
在所述验证操作信息包括所述用户验证方式标识的情况下,向所述SDK发送所述第一通知消息,所述第一通知消息包括所述用户验证方式标识,用于指示所述SDK通知所述宿主程序展示与所述用户验证方式标识匹配的用户验证页面,以提示用户输入与所述用户验证方式标识匹配的所述第一用户验证输入信息。
4.根据权利要求1至3中任意一项所述的方法,其特征在于,所述安全验证结果信息包括目标宿主程序标识,所述目标宿主程序标识包括所述支付请求消息对应的支付的宿主程序标识,
在所述向终端设备中的SDK发送第一通知消息之前,还包括:
根据所述目标宿主程序标识和预设的第一对应关系,确定与所述目标宿主程序标识对应的目标用户验证调起方,所述第一对应关系包括宿主程序标识与用户验证调起方的关系;
所述向终端设备中的SDK发送第一通知消息,包括:
在所述目标用户验证调起方为所述宿主程序的情况下,向所述SDK发送所述第一通知消息。
5.根据权利要求4所述的方法,其特征在于,在所述根据所述目标宿主程序标识和预设的第一对应关系,确定与所述目标宿主程序标识对应的目标用户验证调起方之后,还包括:
在所述目标用户验证调起方为所述SDK的情况下,向所述SDK发送第四通知消息,所述第四通知消息用于指示所述SDK展示用户验证页面,以提示用户输入第二用户验证输入信息,所述第二用户验证输入信息用于所述SDK服务器进行用户验证以得到用户验证结果信息。
6.根据权利要求1所述的方法,其特征在于,所述发起付款请求,包括:
在所述用户验证结果信息满足一致性验证条件的情况下,发起所述付款请求。
7.根据权利要求1所述的方法,其特征在于,所述一致性验证条件包括:
第一用户验证结果信息和第二用户验证结果信息一致,所述第一用户验证结果信息为由所述宿主程序服务器通过所述宿主程序传输给所述SDK的所述用户验证结果信息,所述第二用户验证结果信息为从宿主程序服务器获取的所述用户验证结果信息。
8.根据权利要求1所述的方法,其特征在于,所述SDK服务器存储有用于对所述SDK与所述宿主程序之间交互的信息进行加、解密的密钥。
9.根据权利要求1所述的方法,其特征在于,在所述响应于接收的支付请求消息,向安全控制系统发送安全验证请求消息之前,还包括:
响应于商户系统发送的订单请求消息,生成订单标识;
向所述商户系统发送订单反馈消息,以使所述商户系统向所述SDK发送SDK调用请求消息,所述订单反馈消息和所述SDK调用请求消息包括所述订单标识;
响应于所述SDK发送的第一订单查询消息,向所述SDK发送第一查询反馈消息,所述第一查询反馈消息包括与所述订单标识对应的订单信息。
10.根据权利要求9所述的方法,其特征在于,所述订单请求消息包括指定付款方身份信息,
所述方法还包括:
在所述指定付款方身份信息与所述支付请求消息指示的支付的付款方身份信息不一致的情况下,向所述SDK发送支付中止通知消息,以使所述SDK发出支付提示信息。
11.根据权利要求1所述的方法,其特征在于,在所述响应于接收的支付请求消息,向安全控制系统发送安全验证请求消息之前,还包括:
接收所述终端设备的所述SDK发送的第二订单查询消息,所述第二订单查询消息包括所述终端设备扫描收款码得到的第一码信息;
向所述SDK发送第二查询反馈消息,所述第二查询反馈消息包括与所述第一码信息对应的订单信息。
12.根据权利要求1所述的方法,其特征在于,在所述响应于接收的支付请求消息,向安全控制系统发送安全验证请求消息之前,还包括:
响应于接收的付款码申请消息,向所述SDK发送付款码反馈消息,所述付款码申请消息由所述SDK发送,所述付款码反馈消息包括付款码;
所述支付请求消息由支付受理设备基于扫描的所述付款码生成。
13.一种支付方法,其特征在于,应用于终端设备,所述终端设备具有软件开发工具包SDK和宿主程序,所述方法包括:
通过所述SDK获取SDK服务器发送的第一通知消息,所述第一通知消息是所述SDK服务器基于表征安全验证通过的安全验证结果信息发送的,所述安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应的支付进行安全验证得到的,所述安全验证请求消息由所述SDK服务器响应于接收的所述支付请求消息发送;
响应于所述第一通知消息,通过所述SDK通知所述宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息;
通过所述宿主程序向宿主程序服务器反馈第一用户验证输入信息,所述第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息;
通过所述SDK向所述SDK服务器发送通过宿主程序从所述宿主程序服务器获取的所述用户验证结果信息,使所述SDK服务器在所述用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
14.根据权利要求13所述的方法,其特征在于,还包括:
响应于所述SDK接收的第二通知消息,通过所述SDK发出拒绝提示信息,所述第二通知消息由所述SDK服务器在所述验证操作信息包括拒绝支付标识的情况下发送;
或者,
响应于所述SDK接收的第三通知消息,通过所述SDK发出免密支付提示信息,所述第三通知消息由所述SDK服务器在所述验证操作信息包括免密支付标识的情况下发送;
其中,用户验证方式反馈消息包括所述验证操作信息,所述用户验证方式反馈消息由所述宿主服务器响应于用户验证方式请求消息发送,所述用户验证方式请求消息由SDK服务器在所述安全验证结果信息表征安全验证通过的情况下向所述宿主程序服务器发送,所述用户验证方式请求消息包括所述支付请求消息指示的支付对应的订单信息、终端设备信息、支付信息中的一项或两项以上。
15.根据权利要求14所述的方法,其特征在于,所述第一通知消息由所述SDK服务器在所述验证操作信息包括所述用户验证方式标识的情况下发送,所述第一通知消息包括所述用户验证方式标识,用于指示所述SDK通知所述宿主程序展示与所述用户验证方式标识匹配的用户验证页面,以提示用户输入与所述用户验证方式标识匹配的所述第一用户验证输入信息。
16.根据权利要求13至15中任意一项所述的方法,其特征在于,
所述安全验证结果信息包括目标宿主程序标识,所述目标宿主程序标识包括所述支付请求消息对应的支付的宿主程序标识,
所述第一通知消息由所述SDK服务器在目标用户验证调起方为所述宿主程序的情况下发送,所述目标用户验证调起方为第一对应关系中与目标宿主程序标识匹配的用户验证调起方,所述目标宿主程序标识包括所述支付请求消息对应的支付的宿主程序标识,所述第一对应关系包括宿主程序标识与用户验证调起方的关系。
17.根据权利要求16所述的方法,其特征在于,还包括:
通过所述SDK获取SDK服务器发送的第四通知消息,所述第四通知消息由所述SDK服务器在所述目标用户验证调起方为所述SDK的情况下发送;
响应于所述第四通知消息,调用所述SDK展示用户验证页面,以提示用户输入第二用户验证输入信息;
通过所述SDK向所述SDK服务器反馈所述第二用户验证输入信息,所述第二用户验证输入信息用于所述SDK服务器进行用户验证以得到用户验证结果信息。
18.根据权利要求13所述的方法,其特征在于,所述用户验证结果信息还用于使所述SDK服务器在所述用户验证结果信息满足一致性验证条件的情况下,发起所述付款请求。
19.根据权利要求18所述的方法,其特征在于,所述一致性验证条件包括:
所述第一用户验证结果信息和第二用户验证结果信息一致,所述第一用户验证结果信息为由所述宿主程序服务器通过所述宿主程序传输给所述SDK的所述用户验证结果信息,所述第二用户验证结果信息为从宿主程序服务器获取的所述用户验证结果信息。
20.根据权利要求13所述的方法,其特征在于,所述SDK具有安全域,所述SDK中的信息存储于所述安全域;
所述SDK与所述宿主程序之间交互的信息为加密信息,所述SDK中加、解密的密钥存储于所述SDK服务器,所述宿主程序中加、解密的密钥存储于所述宿主程序服务器。
21.根据权利要求13所述的方法,其特征在于,在所述通过所述SDK获取SDK服务器发送的第一通知消息之前,还包括:
通过所述SDK接收SDK调用请求消息,所述SDK调用请求消息由商户系统响应于订单反馈消息生成,所述订单反馈消息和所述SDK调用请求消息包括订单标识,所述订单标识由所述SDK服务器响应于所述商户系统发送的订单请求消息生成;
响应于所述SDK调用请求消息,通过所述SDK向所述SDK服务器发送第一订单查询消息;
通过所述SDK接收所述SDK服务器响应于所述第一订单查询消息发送的第一查询反馈消息,所述第一查询反馈消息包括与所述订单标识对应的订单信息。
22.根据权利要求21所述的方法,其特征在于,所述订单请求消息包括指定付款方身份信息,
所述方法还包括:
响应于通过所述SDK接收的支付中止通知消息,通过所述SDK发出支付提示信息,所述支付中止通知消息由所述SDK服务器在所述指定付款方身份信息与所述支付请求消息指示的支付的付款方身份信息不一致的情况下发送。
23.根据权利要求13所述的方法,其特征在于,在所述通过所述SDK获取SDK服务器发送的第一通知消息之前,还包括:
扫描付款码,得到第一码信息;
通过所述SDK向所述SDK服务器发送第二订单查询消息,所述第二订单查询消息包括所述第一码信息。
通过所述SDK接收所述SDK服务器发送的第二查询反馈消息,所述第二查询反馈消息包括与所述第一码信息对应的订单信息。
24.根据权利要求13所述的方法,其特征在于,在所述通过所述SDK获取SDK服务器发送的第一通知消息之前,还包括:
通过所述SDK向所述SDK服务器发送付款码申请消息;
通过所述SDK接收所述SDK服务器发送的付款码反馈消息,所述付款码反馈消息包括付款码;
显示所述付款码,所述付款码用于被支付受理设备扫描以生成所述支付请求消息。
25.一种支付方法,其特征在于,应用于宿主程序服务器,所述方法包括:
接收终端设备通过宿主程序反馈的第一用户验证输入信息,所述终端设备具有软件开发工具包SDK和所述宿主程序,所述第一用户验证输入信息在所述SDK响应于第一通知消息通知所述宿主程序展示用户验证页面后得到,所述第一通知消息是所述SDK服务器基于表征安全验证通过的安全验证结果信息发送的,所述安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应支付进行安全验证得到的,所述安全验证请求消息由所述SDK服务器响应于接收的所述支付请求消息发送;
根据所述第一用户验证输入信息进行用户验证,得到用户验证结果信息;
向所述终端设备中的所述宿主程序发送所述用户验证结果信息,通过所述宿主程序将所述用户验证结果信息传输给所述SDK,以使所述SDK向所述SDK服务器发送所述用户验证结果信息,在所述用户验证结果信息表征用户验证通过的情况下,使SDK服务器发起付款请求,以完成支付。
26.根据权利要求25所述的方法,其特征在于,在所述接收终端设备通过宿主程序反馈的第一用户验证输入信息之前,还包括:
接收所述SDK服务器在所述安全验证结果信息表征安全验证通过的情况下发送的用户验证方式请求消息,所述用户验证方式请求消息包括所述支付请求消息指示的支付对应的订单信息、终端设备信息、支付信息中的一项或两项以上;
根据所述用户验证方式请求消息,向所述SDK服务器发送用户验证方式反馈消息,所述用户验证方式反馈消息包括验证操作信息;
其中,在所述验证操作信息包括拒绝支付标识的情况下,所述SDK服务器向所述SDK发送第二通知消息,所述第二通知消息用于指示所述SDK发出拒绝支付提示信息;在所述验证操作信息包括免密支付标识的情况下,所述SDK服务器向所述SDK发送第三通知消息,所述第三通知消息用于指示所述SDK发出免密支付提示信息。
27.根据权利要求26所述的方法,其特征在于,所述第一通知消息由所述SDK服务器在所述验证操作信息包括所述用户验证方式标识的情况下发送,所述第一通知消息包括所述用户验证方式标识,用于指示所述SDK通知所述宿主程序展示与所述用户验证方式标识匹配的用户验证页面,以提示用户输入与所述用户验证方式标识匹配的所述第一用户验证输入信息。
28.根据权利要求25至27中任意一项所述的方法,其特征在于,
所述安全验证结果信息包括目标宿主程序标识,所述目标宿主程序标识包括所述支付请求消息对应的支付的宿主程序标识,
所述第一通知消息由所述SDK服务器在目标用户验证调起方为所述宿主程序的情况下发送,所述目标用户验证调起方为第一对应关系中与目标宿主程序标识匹配的用户验证调起方,所述目标宿主程序标识包括所述支付请求消息对应的支付的宿主程序标识,所述第一对应关系包括宿主程序标识与用户验证调起方的关系。
29.根据权利要求25所述的方法,其特征在于,还包括:
向所述SDK服务器发送所述用户验证结果信息,以使所述SDK服务器在所述用户验证结果信息表征用户验证通过且所述用户验证结果信息满足一致性验证条件的情况下,发起付款请求,以完成支付。
30.根据权利要求29所述的方法,其特征在于,所述一致性验证条件包括:
第一用户验证结果信息和第二用户验证结果信息一致,所述第一用户验证结果信息为由所述宿主程序服务器通过所述宿主程序传输给所述SDK的所述用户验证结果信息,所述第二用户验证结果信息为从宿主程序服务器获取的所述用户验证结果信息。
31.根据权利要求25所述的方法,其特征在于,所述宿主程序服务器存储有用于对所述宿主程序与所述SDK之间交互的信息进行加、解密的密钥。
32.一种软件开发工具包SDK服务器,其特征在于,包括:
发送模块,用于响应于接收的支付请求消息,向安全控制系统发送安全验证请求消息,所述安全验证请求消息包括安全验证信息,用于指示所述安全控制系统根据所述安全验证信息对所述支付请求消息对应的支付进行安全验证;
接收模块,用于接收所述安全控制系统发送的安全验证结果信息;
所述发送模块还用于在所述安全验证结果信息表征安全验证通过的情况下,向终端设备中的SDK发送第一通知消息,所述终端设备具有SDK和宿主程序,所述第一通知消息用于指示所述SDK通知所述宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息,所述第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息;
所述发送模块还用于在所述用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
33.一种终端设备,其特征在于,所述终端设备具有软件开发工具包SDK和宿主程序,所述终端设备包括:
接收模块,用于通过所述SDK获取SDK服务器发送的第一通知消息,所述第一通知消息是所述SDK服务器基于表征安全验证通过的安全验证结果信息发送的,所述安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应的支付进行安全验证得到的,所述安全验证请求消息由所述SDK服务器响应于接收的所述支付请求消息发送;
显示模块,用于响应于所述第一通知消息,通过所述SDK通知所述宿主程序展示用户验证页面,以提示用户输入第一用户验证输入信息;
发送模块,用于通过所述宿主程序向宿主程序服务器反馈第一用户验证输入信息,所述第一用户验证输入信息用于宿主程序服务器进行用户验证以得到用户验证结果信息;
所述发送模块还用于通过所述SDK向所述SDK服务器发送通过宿主程序从所述宿主程序服务器获取的所述用户验证结果信息,使所述SDK服务器在所述用户验证结果信息表征用户验证通过的情况下,发起付款请求,以完成支付。
34.一种宿主程序服务器,其特征在于,包括:
接收模块,用于接收终端设备通过宿主程序反馈的第一用户验证输入信息,所述终端设备具有软件开发工具包SDK和所述宿主程序,所述第一用户验证输入信息在所述SDK响应于第一通知消息通知所述宿主程序展示用户验证页面后得到,所述第一通知消息是所述SDK服务器基于表征安全验证通过的安全验证结果信息发送的,所述安全验证结果信息是安全控制系统基于安全验证请求消息中的安全验证信息对支付请求消息对应支付进行安全验证得到的,所述安全验证请求消息由所述SDK服务器响应于接收的所述支付请求消息发送;
验证模块,用于根据所述第一用户验证输入信息进行用户验证,得到用户验证结果信息;
发送模块,用于向所述终端设备中的所述宿主程序发送所述用户验证结果信息,通过所述宿主程序将所述用户验证结果信息传输给所述SDK,以使所述SDK向所述SDK服务器发送所述用户验证结果信息,在所述用户验证结果信息表征用户验证通过的情况下,使SDK服务器发起付款请求,以完成支付。
35.一种软件开发工具包SDK服务器,其特征在于,包括:处理器以及存储有计算机程序指令的存储器;
所述处理器执行所述计算机程序指令时实现如权利要求1至12中任意一项所述的支付方法。
36.一种终端设备,其特征在于,包括:处理器以及存储有计算机程序指令的存储器;
所述处理器执行所述计算机程序指令时实现如权利要求13至24中任意一项所述的支付方法。
37.一种宿主程序服务器,其特征在于,包括:处理器以及存储有计算机程序指令的存储器;
所述处理器执行所述计算机程序指令时实现如权利要求25至31中任意一项所述的支付方法。
38.一种支付系统,其特征在于,包括如权利要求35所述的软件开发工具包SDK服务器、如权利要求36所述的终端设备和如权利要求37所述的宿主程序服务器。
39.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序指令,所述计算机程序指令被处理器执行时实现如权利要求1至31中任意一项所述的支付方法。
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210238575.1A CN114638608A (zh) | 2022-03-10 | 2022-03-10 | 支付方法、终端设备、服务器、系统及介质 |
TW111137387A TW202336668A (zh) | 2022-03-10 | 2022-09-30 | 支付方法、終端設備、伺服器、系統及介質 |
PCT/CN2022/123922 WO2023168938A1 (zh) | 2022-03-10 | 2022-10-08 | 支付方法、终端设备、服务器、系统及介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210238575.1A CN114638608A (zh) | 2022-03-10 | 2022-03-10 | 支付方法、终端设备、服务器、系统及介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114638608A true CN114638608A (zh) | 2022-06-17 |
Family
ID=81947619
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210238575.1A Pending CN114638608A (zh) | 2022-03-10 | 2022-03-10 | 支付方法、终端设备、服务器、系统及介质 |
Country Status (3)
Country | Link |
---|---|
CN (1) | CN114638608A (zh) |
TW (1) | TW202336668A (zh) |
WO (1) | WO2023168938A1 (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2023168938A1 (zh) * | 2022-03-10 | 2023-09-14 | 中国银联股份有限公司 | 支付方法、终端设备、服务器、系统及介质 |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106304074B (zh) * | 2016-08-31 | 2019-08-16 | 尹子栋 | 面向移动用户的身份验证方法和系统 |
CN106600266A (zh) * | 2016-12-05 | 2017-04-26 | 深圳前海微众银行股份有限公司 | 基于sdk的移动支付方法及装置 |
CN206993151U (zh) * | 2017-07-06 | 2018-02-09 | 北京承启通科技有限公司 | 网络信令安全验证系统 |
WO2021007026A1 (en) * | 2019-07-08 | 2021-01-14 | Mastercard International Incorporated | Systems and methods for use in facilitating network interactions |
CN111538965B (zh) * | 2020-04-15 | 2021-10-12 | 支付宝(杭州)信息技术有限公司 | 一种应用程序的授权登录方法、装置及系统 |
CN113298523A (zh) * | 2021-05-31 | 2021-08-24 | 中国建设银行股份有限公司 | 运营平台支付方法及金融服务平台 |
CN114638608A (zh) * | 2022-03-10 | 2022-06-17 | 中国银联股份有限公司 | 支付方法、终端设备、服务器、系统及介质 |
-
2022
- 2022-03-10 CN CN202210238575.1A patent/CN114638608A/zh active Pending
- 2022-09-30 TW TW111137387A patent/TW202336668A/zh unknown
- 2022-10-08 WO PCT/CN2022/123922 patent/WO2023168938A1/zh unknown
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2023168938A1 (zh) * | 2022-03-10 | 2023-09-14 | 中国银联股份有限公司 | 支付方法、终端设备、服务器、系统及介质 |
Also Published As
Publication number | Publication date |
---|---|
TW202336668A (zh) | 2023-09-16 |
WO2023168938A1 (zh) | 2023-09-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
ES2687191T3 (es) | Método de autentificación de red para transacciones electrónicas seguras | |
CN110138744B (zh) | 更换通信号码的方法、装置、系统、计算机设备及存储介质 | |
US10282541B2 (en) | Method and system for verifying an access request | |
JP6284088B2 (ja) | 1回限りのランダムキーを用いた本人確認及び盗用防止システムならびに方法 | |
CN110662222B (zh) | 用于对等无线通信的系统和方法 | |
WO2020013928A1 (en) | Public-private key pair account login and key manager | |
CN112232805B (zh) | 卡管理方法、用户终端、服务器、系统及存储介质 | |
CN113836506A (zh) | 身份认证方法、装置、系统、电子设备、存储介质 | |
KR20210046357A (ko) | 블록체인 기반 시스템을 위한 키의 저장 및 복구 방법과 그 장치 | |
KR20200050813A (ko) | 생체 인증을 이용한 결제 방법 및 그 전자 장치 | |
JP2022171928A (ja) | 端末装置、認証サーバ、端末装置の制御方法、認証方法及びプログラム | |
CA2888612A1 (en) | Transaction system and method, electronic signature tool, and network bank server authentication method | |
CN114638608A (zh) | 支付方法、终端设备、服务器、系统及介质 | |
CN111917728A (zh) | 一种密码验证方法及装置 | |
CN113779532A (zh) | 生物特征认证方法、服务器、用户终端、系统及介质 | |
CN104978652B (zh) | 一种数据转移方法及相关设备、系统 | |
EP3579518B1 (en) | Payment method and device based on verification terminal | |
JP2017072897A (ja) | 認証システム、および、認証方法 | |
KR101257761B1 (ko) | 이미지 기반 인증시스템 및 방법 | |
KR20150018470A (ko) | 사용자 인증 방법 및 시스템 | |
CN114189362B (zh) | 账号登录方法、终端、服务器、系统及介质 | |
CN114158051B (zh) | 解锁方法、装置、电子设备及计算机可读存储介质 | |
JP6983347B1 (ja) | 情報処理装置及び情報処理方法 | |
CN113919007A (zh) | 数据签名方法、装置、电子设备及计算机可读存储介质 | |
CN117350715A (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 | ||
REG | Reference to a national code |
Ref country code: HK Ref legal event code: DE Ref document number: 40069218 Country of ref document: HK |