Apple Pay入门详细指南

Apple Pay入门

概述

利用apple,用户可以在您的app中轻松地购买实物商品和服务。客户更喜欢使用 Apple Pay,因为他们在购物时无需输入账单、送货和联系人详细信息。而且,Apple Pay 具有更高的安全性,能让客户和开发者安心使用。Apple 不会存储或共享客户的实际信用卡和借记卡卡号,因此商家和 App 开发者无需负责管理和保护实际的信用卡和借记卡卡号。

由于具备这些优点,在按照推荐方式实施了 Apple Pay 之后,开发者的结账转换率提高为原来的 2 倍,结账时间也大幅缩短;而且,在整合了 Apple Pay 之后,客户的忠诚度和购买频率也都提高了。

在您的 App 中,用户可以使用 Touch ID 为付款授权,以释放安全地存储在 iPhone 和 iPad 上的令牌化信用卡和借记卡付款凭证。此外,用户还可将其账单、送货和联系人信息存储在 Wallet 这一 App 中。这样一来,当客户在您的 App 中使用 Touch ID 为购买项目授权时,系统就会随付款凭证一道提供这些信息。

目前,Apple Pay 可在澳大利亚、加拿大、中国、英国和美国使用。

先决条件

除了使用PassKit 框架实施 Apple Pay 之外,您还必须:

  • 通过付款处理机构或网关设置一个帐户。
  • 通过“证书、标识符和描述文件”(“Certificates, Identifiers & Profiles”)注册一个商家 ID。
  • 生成一个 Apple Pay 证书,用于加密和解密付款令牌
  • 在您的 App 中包括一个 Apple Pay 授权
  • 遵循“应用审核准则”的第 29 节中列出的要求
  • 遵循《App 审核准则》(“App Review Guidelines”)第 29 节中列出的要求。

在App中设置Apple Pay

Apple Pay入门详细指南_第1张图片
Apple Pay

       第一步先修改target为iOS 8.1,然后在项目Capabilities里将Apple Pay设置为on,这将自动导入需要的库文件,然后添加一个权限文件并设置,最后修改或创建你的App ID。

Apple Pay入门详细指南_第2张图片
设置Apple Pay为on

       如果没有有效merchant ID,我们需要创建一个,访问苹果iOS 开发者中心的位于Identifiers > Merchant ID的页面。
       跟随创建流程创建完成后,我们需要给Merchant ID添加一个证书签名请求(Certificate Signing Request),以便加密支付令牌来保证其安全性。为达到这个目的,导航至你的Merchant ID,并点击Edit按钮来修改它。跟随流程添加证书签名请求
       编辑完成后回到Xcode,刷新Merchant ID区块。选中merchant ID 然后进入代码编写

编写代码

  • 在适当的文件中导入passkit框架
    #import
  • 遵循代理协议
    @interface ViewController ()
  • 创建支付请求
    首先确认设备是否支持Apple Pay支付
    if([PKPaymentAuthorizationViewController canMakePayments])
    接下来开始创建Apple Pay支付请求
    PKPaymentRequest *request = [[PKPaymentRequest alloc] init];
    request.countryCode = @"CN";
    request.currencyCode = @"CNY";
    request.supportedNetworks = @[PKPaymentNetworkAmex, PKPaymentNetworkMasterCard, PKPaymentNetworkVisa];
    request.merchantCapabilities = PKMerchantCapability3DS | PKMerchantCapabilityEMV;
    request.merchantIdentifier = @"merchant.com.UNIBOX.UNIBOX";
    request.requiredBillingAddressFields = PKAddressFieldEmail | PKAddressFieldPostalAddress;
    request.requiredShippingAddressFields = PKAddressFieldPostalAddress;
    currencyCode列表查询
    countryCode列表查询
    supportedNetworks 支持的支付方式

通过在supportedNetworks属性中填入字符串常量数组来指定你支持的支付网络。通过指定merchantCapabilities属性来指定你支持的支付处理标准,3DS支付方式是必须支持的,EMV方式是可选的。

通过填充 requiredBillingAddressFields和 requiredShippingAddressFields属性来指定所需账单信息和配送地址信息

使用applicationData属性来存储一些在你的应用中关于这次支付请求的唯一标识信息,比如一个购物车的标识符。在用户授权支付之后,这个属性的哈希值会出现在这次支付的token中。

  • 添加物品到支付页
    使用PKPaymentSummaryItem来创建物品并显示,这个对象描述了一个物品和它的价格,数组最后的对象必须是总价格。
    PKPaymentSummaryItem *widget1 = [PKPaymentSummaryItem summaryItemWithLabel:@"Widget 1" amount:[NSDecimalNumber decimalNumberWithString:@"0.99"]];

    PKPaymentSummaryItem *widget2 = [PKPaymentSummaryItem summaryItemWithLabel:@"Widget 2" amount:[NSDecimalNumber decimalNumberWithString:@"1.00"]];
    
    PKPaymentSummaryItem *total = [PKPaymentSummaryItem summaryItemWithLabel:@"My Company Name" amount:[NSDecimalNumber decimalNumberWithString:@"1.99"]];
    
    request.paymentSummaryItems = @[widget1, widget2, total];
    
  • 配置配送方式
    PKShippingMethod *method1 = [PKShippingMethod summaryItemWithLabel:@"24小时内配送" amount:[NSDecimalNumber decimalNumberWithString:@"10。00"]];
    method1.detail = @"24小时内配送";
    method1.identifier = @"24hours";
    PKShippingMethod *method2 = [PKShippingMethod summaryItemWithLabel:@"两天内配送" amount:[NSDecimalNumber decimalNumberWithString:@"5.00"]];
    method2.detail = @"两天内配送";
    method2.identifier = @"2days";
    request.shippingMethods = @[method1,method2];

  • 显示认证视图
    PKPaymentAuthorizationViewController *paymentPane = [[PKPaymentAuthorizationViewController alloc] initWithPaymentRequest:request];
    paymentPane.delegate = self;
    [self presentViewController:paymentPane animated:YES completion:nil];

  • 代理说明
    送货地址回调
    -(void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller
    didSelectShippingContact:(PKContact *)contact
    completion:(void (^)(PKPaymentAuthorizationStatus, NSArray * _Nonnull, NSArray * _Nonnull))completion{
    //contact送货地址信息,PKContact类型
    //送货信息选择回调,如果需要根据送货地址调整送货方式,比如普通地区包邮+极速配送,偏远地区只有付费普通配送,进行支付金额重新计算,可以实现该代理,返回给系统:shippingMethods配送方式,summaryItems账单列表,如果不支持该送货信息返回想要的PKPaymentAuthorizationStatus
    completion(PKPaymentAuthorizationStatusSuccess, shippingMethods, summaryItems);
    }
    送货方式回调
    -(void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller
    didSelectShippingMethod:(PKShippingMethod *)shippingMethod
    completion:(void (^)(PKPaymentAuthorizationStatus, NSArray * _Nonnull))completion{
    //配送方式回调,如果需要根据不同的送货方式进行支付金额的调整,比如包邮和付费加速配送,可以实现该代理
    completion(PKPaymentAuthorizationStatusSuccess, summaryItems);
    }
    支付卡选择回调
    -(void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller didSelectPaymentMethod:(PKPaymentMethod *)paymentMethod completion:(void (^)(NSArray * _Nonnull))completion{
    //支付银行卡回调,如果需要根据不同的银行调整付费金额,可以实现该代理
    completion(summaryItems);
    }
    付款成功苹果服务器返回信息回调,做服务器验证
    -(void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller
    didAuthorizePayment:(PKPayment *)payment
    completion:(void (^)(PKPaymentAuthorizationStatus status))completion {
    PKPaymentToken *payToken = payment.token;
    //支付凭据,发给服务端进行验证支付是否真实有效
    PKContact *billingContact = payment.billingContact; //账单信息
    PKContact *shippingContact = payment.shippingContact; //送货信息
    PKContact *shippingMethod = payment.shippingMethod; //送货方式
    //等待服务器返回结果后再进行系统block调用
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
    //模拟服务器通信
    completion(PKPaymentAuthorizationStatusSuccess);
    });
    }
    支付完成回调
    -(void)paymentAuthorizationViewControllerDidFinish:(PKPaymentAuthorizationViewController *)controller{
    [controller dismissViewControllerAnimated:YES completion:nil];
    }

扩展阅读

Apple Pay入门
Apple Pay编程指南
Apple Pay标识指南

你可能感兴趣的:(Apple Pay入门详细指南)