Alipay, China's leading third-party online payment solutionAlipay, China's leading third-party online payment solution

如何正确使用支付推进链接

在调用 支付(收银台)接口后,根据支付过程中所使用的支付方式,接口响应中会返回不同类型的支付推进链接。本文为您提供针对不同客户端类型的支付推进链接的最佳实践。有关每种支付方式返回的支付推进链接 的详细信息,请参阅支付方式返回链接

支付推进链接的类型

对于不同类型的商户客户端(Web、WAP、App),不同的支付方式在 支付(收银台)接口的响应中返回以下三种类型的支付推进链接之一或全部,以继续支付流程。

类型

描述

normalUrl

一个 HTTPS 地址的链接,用于在同个浏览器页面上重定向到支付方式的网站页面。

示例:https://msp.boost-my.com/onlinepayment/authorise?source=alipay-connect&codeValue=https%3A%2F%2Fglobal.alipay.com%2F2810020400931LFH2t2mq1jjJ8zSetyv31VU

applinkUrl

在支付过程中用于重定向的 Android App Link 或 iOS Universal Link。

示例https://myboost.app.link/IvWm7QZkfjb?%24fallback_url=https%3A%2F%2Fmsp.boost-my.com%2Fonlinepayment%2Fauthorise&source=alipay-connect&codeValue=https%3A%2F%2Fglobal.alipay.com%2F2810020400931LFH2t2mq1jjJ8zSetyv31VU

schemeUrl

用于打开支付方式应用的 URL scheme。

示例boostapp://inAppDeeplink?deeplink_path=deeplink/onetimepayment&source=alipay-connect&codeValue=https%3A%2F%2Fglobal.alipay.com%2F2810020400931LFH2t2mq1jjJ8zSetyv31VU

注意

  • 使用上述链接发起支付时,如果买家未安装支付方式应用,重定向过程中可能会出现异常。如有异常,请妥善处理。
  • 某些支付方式返回的链接不能多次使用。如果使用链接未能成功调起支付页面,建议使用新的 paymentRequestId 值获取链接并重新调起支付页面。
  • 除了链接重定向方法,支付(收银台)接口响应中可能包含 orderCodeForm 字段,对于某些支付方式,该字段值包含二维码或支付码信息,可用于在您的网站上显示支付码,从而在您的网站内实现无缝支付流程。有关此解决方案的更多信息,请参阅前置方案

Web

本节提供了关于如何在 WEB 类型的终端中进行支付推进链接操作的信息。对于电脑网站上的支付,支付(收银台)接口的响应中包含标识为 normalUrl 的支付推进链接。

打开链接

获取到 normalUrl 值后,您需要使用支付推进链接将买家重定向到支付页面。建议您在新标签页中打开链接,引导买家完成支付。打开新页面的代码如下:

copy
if (serverResponse.normalUrl != null) {
    window.open(serverResponse.normalUrl, '_blank');
}

用户体验

使用 normalUrl 渲染的支付页面可能是二维码扫描页或登录页。以下图表展示了这两种情况下的支付流程:

二维码扫描页面

image.png

登录页面

image.png

WAP

本节提供了在WAP终端类型下如何处理支付推进链接的信息。对于移动网站上的支付,支付(收银台)接口的响应可能包含以下一个或多个支付推进链接:

  • normalUrl
  • applinkUrl
  • schemeUrl

选择链接

如果 支付(收银台)接口的响应中只包含三个链接之一,直接将接收到的链接用作跳转链接。如果收到多个链接,建议根据以下指导选择链接:

  • iOS 系统:优先使用 applinkUrl ,然后是 schemeUrl ,最后是 normalUrl
  • Android 系统:优先使用 schemeUrl ,然后是 applinkUrl ,最后是 normalUrl

打开链接

要使用 JavaScript 的重定向方法打开链接,可以使用以下代码:

copy
window.location.href = URL;

用户体验

类型

支付体验

normalUrl

买家从您的移动网页页面被重定向到支付方式的移动网页页面。在支付方式的移动网页上显示的内容取决于支付方式,可以分为以下两类:

  • 登录页面:后续的支付流程在支付方式的移动网页页面内完成。

1.png

  • 引导买家点击按钮启动支付方式应用。后续的支付流程在支付方式应用内完成。

2.png

  • 显示支付码。买家复制支付码并在支付方式应用中付款。

3.png

  • 显示二维码。买家扫描二维码并在支付方式应用中付款。

4.png

applinkUrl

根据买家是否安装了支付方式的应用,后续支付流程会自动确定:

  • 如果买家已安装支付方式的应用:将打开该应用,买家在应用内完成支付流程。

5.png

  • 如果买家未安装支付方式的应用:将打开移动网页页面,买家根据移动网页页面上的指示继续支付流程。此过程在默认浏览器中打开并渲染。

6.png

schemeUrl

支付体验取决于买家是否已安装支付方式的应用:

  • 如果买家已安装支付方式的应用:应用会被打开,买家在应用内完成支付流程。

image.png

  • 如果买家未安装支付方式的应用:无法通过此链接启动应用,买家可能停留在当前页面,无法继续支付流程。

image.png

APP

本节介绍了如何在 APP 类型的终端上处理支付推进链接。对于移动应用支付, 支付(收银台)接口的响应可能包含以下一个或多个支付推进链接:

  • normalUrl
  • applinkUrl
  • schemeUrl

注意:对于移动应用支付,除了上述提到的重定向链接参数外,支付(收银台)接口的响应还包含 appIdentifier 参数。此参数是对应支付方式应用的包名,用于判断是否已安装该应用以进行应用内支付。它也可以用于避免在 Android 上出现消歧对话框。

选择链接

如果 支付(收银台)接口响应中只包含三个链接中的一个,直接将接收到的链接用作跳转链接。如果您收到多个链接,建议根据以下指导选择链接:

  • iOS 系统:优先使用 applinkUrl,然后是 schemeUrl,最后是 normalUrl
  • Android 系统:优先使用 schemeUrl,然后是 applinkUrl,最后是 normalUrl

打开链接

对于 Android 和 iOS,使用以下重定向方法之一打开支付推进链接:

对于 iOS

使用以下方法之一打开支付推进链接:

  • 推荐 重定向到应用外部:调用 iOS 方法打开支付推进链接。
  • 在应用内重定向:在应用内打开支付推进链接。
  • 使用 WKWebView
  • 使用 WKWebView 和 JSBridge
  • 使用 SafariViewController
  • 取决于支付方式应用是否安装:在应用程序内部或外部打开支付推进链接。

重定向到应用外部

调用 iOS 方法来打开支付推进链接会导致重定向到应用外部。以下代码示例展示了如何使用 iOS 系统中的 iOS 方法,将买家从您的应用重定向到支付方式应用。

copy
if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 10.0) {
    [[UIApplication sharedApplication] openURL:[NSURL URLWithString:Url] options:@{} completionHandler:nil];
}else{ 
    [[UIApplication sharedApplication] openURL:[NSURL URLWithString:Url]];
}

应用内重定向

使用以下链接类型才可以在应用内打开支付推进链接:

  • normalUrl
  • applinkUrl

注意:某些支付方式不支持在移动网站上支付。打开 normalUrl 意味着通过重定向调用相应的支付方式应用,而 WKWebView 会拦截这个重定向。您需要使用 WKWebView 的 decidePolicyForNavigationAction方法,并调用 iOS 方法来打开支付推进链接,以实现从您的 WKWebView 到支付方式应用的重定向。

使用 WKWebView

以下示例代码展示了如何使用 WKWebView 在 iOS 应用内加载支付方式页面:

copy
// Initialize webview configuration
WKWebViewConfiguration *configuration = [[WKWebViewConfiguration alloc]init];
// Initialize webView 
WKWebView *webView = [[WKWebView alloc]initWithFrame:CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.height) configuration:configuration];
webView.navigationDelegate = self;
//Load the payment method URL
[webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:Url]]];
[self.view addSubview:self.webView];

以下示例代码展示了如何使用 WKWebView 的 decidePolicyForNavigationAction方法实现从您的 WKWebView 重定向至支付方式应用:

copy
- (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler{
    // WKWebView intercepts the redirection by default. Enable the redirection in the following ways. 
    // Operations such as opening Safari
    NSURL *url = navigationAction.request.URL;
    NSString *absoluteString = url.absoluteString;
    NSString *scheme = url.baseURL.scheme;

    DLog(@"navigationAction.request.URL.absoluteString=====> %@", absoluteString);
    if ([absoluteString isEqualToString:@"about:blank"]) {
        decisionHandler(WKNavigationActionPolicyCancel);
    }
    if (!([absoluteString containsString:@"https://"] || [absoluteString containsString:@"http://"])) {
        if ([absoluteString containsString:@"://"]) {
            NSString *urlHeader =  [absoluteString componentsSeparatedByString:@"://"][0];
            [MBProgressHUD showAutoMessage:[NSString stringWithFormat:@"Scheme\n%@://",urlHeader] toView:self.view];
            dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
                [self openAppWithUrlStr:navigationAction.request.URL];
                decisionHandler(WKNavigationActionPolicyAllow);
            });
        }
    } else {
        decisionHandler(WKNavigationActionPolicyAllow);
    }
}
使用 WKWebView 和 JSbridge

使用 WKWebView 和 JSBridge 可以优化买家的支付体验,但这需要强大的开发能力。通过 WKWebView 结合使用 JSBridge 打开URL对项目的维护和可扩展性有益,同时也能提升性能和安全性。利用 JSBridge 可以促进网页与原生应用之间的交互,使 WAP 页面能够直接调用应用的原生方法。下面的代码示例展示了如何在 WKWebView 中使用 JSBridge。

copy
[self.wkWebView evaluateJavaScript:bridge completionHandler:nil];
使用 SFSafariViewController

SFSafariViewController 支持打开和渲染 normalUrlapplinkUrl 以及 schemeUrl。与 WebView 相比,它具有更全面的功能和更简单的集成方式。关于如何使用 SFSafariViewController 来打开支付推进链接,请参阅 SFSafariViewController 用户指南。下面的代码示例展示了如何使用 SFSafariViewController。

copy
SFSafariViewController *safariVC = [[SFSafariViewController alloc] initWithURL:Url entersReaderIfAvailable:NO];
safariVC.delegate = self;
[self.navigationController presentViewController:safariVC animated:YES completion:nil];

取决于是否安装支付方式应用

您必须首先检查买家是否已安装了支付方式应用,然后决定支付推进链接的打开方式。如果买家已经安装了支付方式应用,您可以采用应用内重定向流程。否则,采用应用外重定向流程。 要检查买家是否已安装支付方式应用,请执行以下步骤:

  1. info.plist 中的配置里添加 LSApplicationQueriesSchemes。请注意,info.plist 中方案的数量是有限制的。
  2. 使用 canOpenURL 方法来确定支付方式应用是否已安装。参考以下代码:
copy
NSString *walletSchemeUrl = @"gcash://";

if ([[UIApplication sharedApplication] canOpenURL:[NSURL URLWithString:walletSchemeUrl]]){
    // The payment method app is installed. Open the app directly.
    [[UIApplication sharedApplication] openURL:[NSURL URLWithString:Url] options:@{} completionHandler:nil];
    
    return YES;
} else {
    // The payment method app is not installed. We recommend that you load the mobile website in WebView.
    SFSafariViewController *safariVC = [[SFSafariViewController alloc] initWithURL:Url entersReaderIfAvailable:NO];
    safariVC.delegate = self;
    [self.navigationController presentViewController:safariVC animated:YES completion:nil];
    
    return NO;
}

每种重定向方法的优缺点

每种重定向方法都有其优点和缺点。我们建议您根据操作系统和集成场景选择最适合的重定向方法。

重定向方法

描述

应用外重定向:调用 Android/iOS 方法打开支付推进链接。

Antom 推荐使用此方法。

  • 优点:集成成本低。一次性集成适用于所有支付方式。
  • 缺点:支付流程未完全保留在您的客户端中。

在应用内重定向

  • WKWebView
  • WebView

WKWebView/WebView 是内置控件,可以在应用中嵌入一个网络浏览器。您可以使用它来加载网站链接。

  • 优点:您可以为买家定制更好的支付体验。此外,通过在应用内重定向买家,可以实现无缝支付体验,这意味着买家不会离开您的应用,在您的应用内完成后续支付流程。
  • 缺点:需要更多的开发和测试工作。
  • WKWebView+JSBridge
  • WebView+JavascriptInterface

基于 WKWebView/WebView 的升级解决方案。使用 JSBridge/JavascriptInterface 后,可以直接在 WebView 中调用 Android/iOS 方法来打开 支付推进链接 。

  • 优点:相比 WKWebView/WebView,性能、可扩展性和安全性提升。为买家提供定制化的支付体验。
  • 缺点:需要更多的开发和测试工作。
  • SafariViewController
  • Custom Tabs

由 iOS/Android 提供,用于在应用内打开 支付推进链接 。相比 WebView,它具有更全面的功能 。

  • 优点:可以与系统浏览器集成,并与系统浏览器共享如 cookie 的能力。集成相对简单。
  • 缺点:不支持自定义支付体验。

根据支付方式应用是否已安装,在应用外打开支付推进链接,或在应用内打开支付推进链接。

根据支付方式应用的安装情况,提供不同的重定向方法。

  • 优点:提供用户友好的支付体验。
  • 缺点:需要更多的开发和测试工作。

每种重定向方法的用户体验

与支付推进链接不同开启方式相对应的支付流程如下:

重定向方法

支付流程

在应用外重定向:调用 Android/iOS 方法来打开支付推进链

在应用程序外部进行重定向。支付流程取决于买家是否已安装支付方式应用:

  • 已安装:从您的应用重定向到支付方式应用。买家选择支付方式后,支付方式应用通过 Antom 返回的 applinkUrlschemeUrl 发起支付,买家在支付方式应用中完成支付。

image.png

  • 未安装 :从您的应用重定向到默认浏览器。
    • 在默认浏览器中支付: 买家选择支付方式后,通过 Antom 提供的 normalUrlapplinkUrl 从您的应用重定向到默认浏览器中的支付页面,买家在此页面完成支付。

image.png

    • 通过支付方式应用支付:买家选择支付方式后,通过 Antom 提供的 normalUrlapplinkUrl 从您的应用重定向到默认浏览器中的支付页面。支付页面会打开支付方式应用,买家在支付方式应用中完成支付。

image.png

在应用程序内重定向

有两种支付体验:从您的应用中重定向和在您的应用内重定向。

  • 支付方式应用支付(从您的应用内重定向):买家选择支付方式后,通过 Antom 返回的 normalUrl applinkUrl 从您的应用重定向到 WebView 中的支付方式页面。支付页面会打开支付方式应用,买家在支付方式应用中完成支付。

image.png

  • WebView支付(从您的应用内重定向): 买家选择支付方式后,通过 Antom 返回的 normalUrl applinkUrl 从您的应用重定向到 WebView 中的支付方式页面,买家在此页面上完成支付。

image.png

配置重定向方法的最佳实践

建议您根据不同的支付方式固定配置支付推进链接,或者根据支付方式、设备环境和链接类型进行路由。以下是一个基于不同支付方式的固定配置示例:

image.png

对于每种支付方式,建议您根据以下逻辑确定支付推进链接的打开方式:

image.png

常见问题解答:什么是消歧对话框

Android App Link 在安装应用时向 Google 服务器请求验证。如果验证失败,Android App Link 将变得无效,当买家尝试通过此类链接打开应用时,会出现消歧对话框。买家需要手动选择如何打开链接。

此图显示了当买家点击 Android App Link 时出现的消歧对话框示例。买家需要手动选择如何打开链接:使用谷歌地图或谷歌浏览器。

1632448161329-0aef337a-b4eb-4700-a8d0-042ca36658e4.png

防止出现消歧对话框

当出现消歧对话框时,买家需要手动选择打开应用的方式,这可能影响支付成功率。因此,您需要通过以下方式(根据需要)防止消歧对话框的出现:

  • 如果买家已安装支付方式应用,指定支付方式的包名并打开支付方式的链接。
  • 如果买家未安装支付方式应用,使用以下示例代码来打开链接。
copy
Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(applinkUrl));
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 
//Specify the package name of the payment method
intent.setPackage(walletPackageName);
PackageManager packageManager = MainActivity.this.getPackageManager();
//Check whether there is an app that supports opening this link.
List<ResolveInfo> activities = packageManager.queryIntentActivities(intent, 0);
if (activities.size() <= 0) {
   //The payment method app is not installed. Initialize the Intent object. This link will be opened by the default Android method.
   intent = new Intent(Intent.ACTION_VIEW, Uri.parse(applinkUrl));
   intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
     startActivity(intent);
} else {
  //The payment method app is installed. Specify the package name of the payment method and open the payment method URL. The disambiguation dialog box will not appear.
     startActivity(intent);
}

注意:

某些支付方式的 packageName 值如下所示:

  • AlipayHK:hk.alipay.wallet
  • GCash:com.globe.gcash.android
  • TrueMoney:th.co.truemoney.wallet
  • KakaoPay:com.kakao.talk
  • Touch 'n Go:my.com.tngdigital.ewallet
  • Dana:id.dana