apple pay 集成

苹果在本周一发布了iOS 8.1版本,并正式开放了Apple Pay支付系统。Apple Pay是一个基于NFC的支付系统,不久将被数以万计的线下零售商店予以支持。即使这项科技并非完全的突破性进展,但它足以推进许多公司和零售商来支持这种支付方式,并成为苹果又一项成功的投资。ios

Apple Pay还给开发者带来了处理支付的新渠道,用户将指望在应用中使用它,由于它将验证和交易极端简化,仅需手指轻轻一触便可完成,若是应用里面有涉及到交易,开发者颇有必要集成Apple Pay。那么如何将Apple Pay功能集成到你的应用里呢?git

在App里设置Apple Paygithub

 

Screen-Shot-2014-10-21-at-1.31.40-PM.png

Xcode 6.1提供了很是方便的界面来设置Apple Pay。第一步先修改target为iOS 8.1,而后在项目Capabilities里将Apple Pay设置为on,这将自动导入须要的库文件,而后添加一个权限文件并设置,最后修改或建立你的App ID。数组

screen1.png

你可能会注意到上面没有有效的Merchant ID,咱们须要建立一个,访问苹果iOS 开发者中心的位于Identifiers > Merchant ID的页面安全

而后随着流程指引,建立一个Merchant ID并注册它。服务器

screen2.png

如今,咱们须要给Merchant ID添加一个证书签名请求(Certificate Signing Request),以便加密支付令牌来保证其安全性。为达到这个目的,导航至你的Merchant ID,并点击Edit按钮来修改它。app

screen3.png

如今,你须要建立一个证书。点击下面的Create Certificate按钮,并跟随苹果的流程指引完成建立。框架

screen4.png

如今Merchant ID设置好了,你能够回到Xcode并刷新Merchant ID区块,若是一切正常,你应当看到刚建立的ID出如今列表上。将它选中,而后能够进入下一部分。ide

screen5.png

编写代码优化

咱们在Github上提供了一个集成Apple Pay的示例项目:cjbeauchamp/ApplePayDemo ,权限文件和App设置文件已经剥离出去了,能够放心将它添加到你本身的项目里。下面咱们将讨论一些开发中的要点。

设置项目

Apple Pay使用了PassKit框架,因此你须要在适当的文件里导入头文件:

#import <PASSKIT PassKit.h>

 

你还须要接收Apple Pay处理信息的回调,因此确保将委托添加到接收类上:

@interface ViewController : UIViewController 
<PKPAYMENTAUTHORIZATIONVIEWCONTROLLERDELEGATE>

 

建立支付请求

首先你须要确认设备是否支持Apple Pay支付,确认的代码是:

if([PKPaymentAuthorizationViewController canMakePayments]) {  
    ...  
}

 

在上面的代码块里,你能使用PKPayment类来建立支付请求。下面是相应的代码,你须要将其中一些信息修改为本身的,好比merchantIdentifier须要与你以前建立的Merchant ID相匹配。

PKPaymentRequest *request = [[PKPaymentRequest alloc] init]; 
request.countryCode = @"US"; 
request.currencyCode = @"USD"; 
request.supportedNetworks = @[PKPaymentNetworkAmex, PKPaymentNetworkMasterCard, PKPaymentNetworkVisa]; 
request.merchantCapabilities = PKMerchantCapabilityEMV; 
request.merchantIdentifier = @"merchant.com.myMerchantID";

 

添加物品到支付页

你可使用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:@"Grand Total" amount:[NSDecimalNumber decimalNumberWithString:@"1.99"]]; 
  
request.paymentSummaryItems = @[widget1, widget2, total];

 

显示认证视图

最后,显示由PassKit框架提供的view controller,接下来它将自动处理认证。

PKPaymentAuthorizationViewController *paymentPane = [[PKPaymentAuthorizationViewController alloc] initWithPaymentRequest:request]; 
paymentPane.delegate = self; 
[self presentViewController:paymentPane animated:TRUE completion:nil];

 

实现委托方法

被请求的委托方法是被认证成功和认证完成两个事件调用的。是否解除view controller,以及让用户知道认证是否成功都取决于你。方法的签名以下:

- (void)paymentAuthorizationViewController:didAuthorizePayment:completion: 
- (void)paymentAuthorizationViewControllerDidFinish:

 

支付验证

在Apple Pay验证了支付以后,仍然须要开发者来完成交易,这能够用didAuthorizePayment委托方法来完成,它须要你链接服务器并上传支付令牌和其余信息,以完成整个支付流程。在服务器呼叫结束后,你须要调用completion方法,摒弃提供success或failure标记的参数。你能够在示例代码里找到具体实现。

监控并优化交易

Apple Pay是现有的结帐流程很是棒的解决方案,在应用里使用它无疑会让用户们高兴。尽管Apple Pay让支付流程极端简化,仍然有许多变更地方,他们的表现将直接与app的营收挂钩。

交易监控

Crittercism公司的新Transaction Management是一种很棒的方法,用来监控各类交易确保它们工做正常。若是一个API端末或服务执行缓慢,或者若是用户决定取消交易,或者你的应用崩溃了,你须要知道这些信息才能更好的优化它们。你能够到Crittercism官方网站了解更多信息。

总结

但愿这个入门教程让你更好的理解和使用Apple Pay。别忘了阅读苹果的指南和文档来了解如何与供应商集成,以及用户界面的指导规范。你能够在苹果Apple Pay的官网上找到它们。

相关文章
相关标签/搜索