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
第一步先修改target为iOS 8.1,然后在项目Capabilities里将Apple Pay设置为on,这将自动导入需要的库文件,然后添加一个权限文件并设置,最后修改或创建你的App ID。
如果没有有效merchant ID,我们需要创建一个,访问苹果iOS 开发者中心的位于Identifiers > Merchant ID的页面。
跟随创建流程创建完成后,我们需要给Merchant ID添加一个证书签名请求(Certificate Signing Request),以便加密支付令牌来保证其安全性。为达到这个目的,导航至你的Merchant ID,并点击Edit按钮来修改它。跟随流程添加证书签名请求
编辑完成后回到Xcode,刷新Merchant ID区块。选中merchant ID 然后进入代码编写
编写代码
- 在适当的文件中导入passkit框架
#import <PassKit/PassKit.h> - 遵循代理协议
@interface ViewController () <PKPaymentAuthorizationViewControllerDelegate> - 创建支付请求
首先确认设备是否支持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<pkshippingmethod *> * _Nonnull, NSArray<pkpaymentsummaryitem *> * _Nonnull))completion{
//contact送货地址信息,PKContact类型
//送货信息选择回调,如果需要根据送货地址调整送货方式,比如普通地区包邮+极速配送,偏远地区只有付费普通配送,进行支付金额重新计算,可以实现该代理,返回给系统:shippingMethods配送方式,summaryItems账单列表,如果不支持该送货信息返回想要的PKPaymentAuthorizationStatus
completion(PKPaymentAuthorizationStatusSuccess, shippingMethods, summaryItems);
}
送货方式回调
-(void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller
didSelectShippingMethod:(PKShippingMethod *)shippingMethod
completion:(void (^)(PKPaymentAuthorizationStatus, NSArray<pkpaymentsummaryitem *> * _Nonnull))completion{
//配送方式回调,如果需要根据不同的送货方式进行支付金额的调整,比如包邮和付费加速配送,可以实现该代理
completion(PKPaymentAuthorizationStatusSuccess, summaryItems);
}
支付卡选择回调
-(void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller didSelectPaymentMethod:(PKPaymentMethod *)paymentMethod completion:(void (^)(NSArray<pkpaymentsummaryitem *> * _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];
}