ApplePay集成教程

Apple Pay运行环境:iPhone6以上设备,操作系统最低iOS9.0以上,部分信息设置需要iOS9.2以上。目前还不支持企业证书添加。

环境搭建好后可以在模拟器上面运行,xcode7.2.1+iPhone6SP9.2系统下,系统会绑定几种虚拟的银行卡,和几个联系人,方便调试,支付也不会发生真实的付款,真的很方便。

准备工作

在接入Apple Pay之前,首先要申请MerchantID及对应证书。


申请MerchantID


申请对应证书


工程设置

Capability中启用Apple Pay权限,并选择merchantID。


之后项目会多一个Applepay的配置文件ApplePayDemo.entitlements

如果Steps出现那三项就证明配置正确


[objc]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. #import "ViewController.h"  
  2. #import <PassKit/PassKit.h>  
  3. @interface ViewController ()<PKPaymentAuthorizationViewControllerDelegate>  
  4. {  
  5.     NSMutableArray *summaryItems;  
  6.     NSMutableArray *shippingMethods;  
  7. }  
  8. @end  
  9.   
  10. @implementation ViewController  
  11.   
  12. - (void)viewDidLoad {  
  13.     [super viewDidLoad];  
  14.   
  15.       
  16.     UIButton *btn=[[UIButton alloc]init];  
  17.     btn.backgroundColor=[UIColor colorWithRed:0.196 green:0.371 blue:0.248 alpha:1.000];  
  18.     [btn setTitle:@"开始支付" forState:UIControlStateNormal];  
  19.     [btn addTarget:self action:@selector(buyNow) forControlEvents:UIControlEventTouchUpInside];  
  20.     btn.frame=CGRectMake(10010010050);  
  21.     [self.view addSubview:btn];  
  22. }  
  23.   
  24.   
  25.   
  26.   
  27. - (void)buyNow {  
  28.     if (![PKPaymentAuthorizationViewController class]) {  
  29.         //PKPaymentAuthorizationViewController需iOS8.0以上支持  
  30.         NSLog(@"操作系统不支持ApplePay,请升级至9.0以上版本,且iPhone6以上设备才支持");  
  31.         return;  
  32.     }  
  33.     //检查当前设备是否可以支付  
  34.     if (![PKPaymentAuthorizationViewController canMakePayments]) {  
  35.         //支付需iOS9.0以上支持  
  36.         NSLog(@"设备不支持ApplePay,请升级至9.0以上版本,且iPhone6以上设备才支持");  
  37.         return;  
  38.     }  
  39.     //检查用户是否可进行某种卡的支付,是否支持Amex、MasterCard、Visa与银联四种卡,根据自己项目的需要进行检测  
  40.     NSArray *supportedNetworks = @[PKPaymentNetworkAmex, PKPaymentNetworkMasterCard,PKPaymentNetworkVisa,PKPaymentNetworkChinaUnionPay];  
  41.     if (![PKPaymentAuthorizationViewController canMakePaymentsUsingNetworks:supportedNetworks]) {  
  42.         NSLog(@"没有绑定支付卡");  
  43.         return;  
  44.     }  
  45.     NSLog(@"可以支付,开始建立支付请求");  
  46.     //设置币种、国家码及merchant标识符等基本信息  
  47.     PKPaymentRequest *payRequest = [[PKPaymentRequest alloc]init];  
  48.     payRequest.countryCode = @"CN";     //国家代码  
  49.     payRequest.currencyCode = @"CNY";       //RMB的币种代码  
  50.     payRequest.merchantIdentifier = @"merchant.com.kuaichengwuliu";  //申请的merchantID  
  51.     payRequest.supportedNetworks = supportedNetworks;   //用户可进行支付的银行卡  
  52.     payRequest.merchantCapabilities = PKMerchantCapability3DS|PKMerchantCapabilityEMV;      //设置支持的交易处理协议,3DS必须支持,EMV为可选,目前国内的话还是使用两者吧  
  53.       
  54.       
  55.     //如果需要邮寄账单可以选择进行设置,默认PKAddressFieldNone(不邮寄账单)  
  56.     //    payRequest.requiredBillingAddressFields = PKAddressFieldEmail;  
  57.       
  58.     //楼主感觉账单邮寄地址可以事先让用户选择是否需要,否则会增加客户的输入麻烦度,体验不好,  
  59.     //送货地址信息,这里设置需要地址和联系方式和姓名,如果需要进行设置,默认PKAddressFieldNone(没有送货地址)  
  60. //    payRequest.requiredShippingAddressFields = PKAddressFieldPostalAddress|PKAddressFieldPhone|PKAddressFieldName;  
  61.       
  62.       
  63.     //设置两种配送方式 用户可以手动选择  
  64.     PKShippingMethod *freeShipping = [PKShippingMethod summaryItemWithLabel:@"包邮" amount:[NSDecimalNumber zero]];  
  65.     freeShipping.identifier = @"freeshipping";  
  66.     freeShipping.detail = @"6-8 天 送达";  
  67.       
  68.     PKShippingMethod *expressShipping = [PKShippingMethod summaryItemWithLabel:@"极速送达" amount:[NSDecimalNumber decimalNumberWithString:@"10.00"]];  
  69.     expressShipping.identifier = @"expressshipping";  
  70.     expressShipping.detail = @"2-3 小时 送达";  
  71.     shippingMethods = [NSMutableArray arrayWithArray:@[freeShipping, expressShipping]];  
  72.     //shippingMethods为配送方式列表,类型是 NSMutableArray,这里设置成成员变量,在后续的代理回调中可以进行配送方式的调整。  
  73.     payRequest.shippingMethods = shippingMethods;  
  74.       
  75.       
  76.     //配置价格 优惠价格  
  77.     NSDecimalNumber *subtotalAmount = [NSDecimalNumber decimalNumberWithMantissa:1275 exponent:-2 isNegative:NO];   //12.75  
  78.     PKPaymentSummaryItem *subtotal = [PKPaymentSummaryItem summaryItemWithLabel:@"商品价格" amount:subtotalAmount];  
  79.       
  80.     NSDecimalNumber *discountAmount = [NSDecimalNumber decimalNumberWithString:@"-12.74"];      //-12.74  
  81.     PKPaymentSummaryItem *discount = [PKPaymentSummaryItem summaryItemWithLabel:@"优惠折扣" amount:discountAmount];  
  82.       
  83.     NSDecimalNumber *methodsAmount = [NSDecimalNumber zero];  
  84.     PKPaymentSummaryItem *methods = [PKPaymentSummaryItem summaryItemWithLabel:@"包邮" amount:methodsAmount];  
  85.       
  86.     NSDecimalNumber *totalAmount = [NSDecimalNumber zero];  
  87.     totalAmount = [totalAmount decimalNumberByAdding:subtotalAmount];  
  88.     totalAmount = [totalAmount decimalNumberByAdding:discountAmount];  
  89.     totalAmount = [totalAmount decimalNumberByAdding:methodsAmount];  
  90.       
  91.     PKPaymentSummaryItem *total = [PKPaymentSummaryItem summaryItemWithLabel:@"ls" amount:totalAmount];  //最后这个是支付给谁。哈哈,快支付给我  
  92.       
  93.     summaryItems = [NSMutableArray arrayWithArray:@[subtotal, discount, methods, total]];  
  94.     //summaryItems为账单列表,类型是 NSMutableArray,这里设置成成员变量,在后续的代理回调中可以进行支付金额的调整。  
  95.     payRequest.paymentSummaryItems = summaryItems;  
  96.       
  97.       
  98.     //ApplePay控件  
  99.     PKPaymentAuthorizationViewController *view = [[PKPaymentAuthorizationViewController alloc]initWithPaymentRequest:payRequest];  
  100.     view.delegate = self;  
  101.     [self presentViewController:view animated:YES completion:nil];  
  102.       
  103. }  
  104. #pragma mark - PKPaymentAuthorizationViewControllerDelegate  
  105. - (void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller  
  106.                   didSelectShippingContact:(PKContact *)contact  
  107.                                 completion:(void (^)(PKPaymentAuthorizationStatus, NSArray<PKShippingMethod *> * _Nonnull, NSArray<PKPaymentSummaryItem *> * _Nonnull))completion{  
  108.     //contact送货地址信息,PKContact类型  
  109.     NSPersonNameComponents *name = contact.name;                //联系人姓名  
  110.     CNPostalAddress *postalAddress = contact.postalAddress;     //联系人地址  
  111.     NSString *emailAddress = contact.emailAddress;              //联系人邮箱  
  112.     CNPhoneNumber *phoneNumber = contact.phoneNumber;           //联系人手机  
  113.     NSString *supplementarySubLocality = contact.supplementarySubLocality;  //补充信息,iOS9.2及以上才有  
  114.       
  115.     //送货信息选择回调,如果需要根据送货地址调整送货方式,比如普通地区包邮+极速配送,偏远地区只有付费普通配送,进行支付金额重新计算,可以实现该代理,返回给系统:shippingMethods配送方式,summaryItems账单列表,如果不支持该送货信息返回想要的PKPaymentAuthorizationStatus  
  116.     completion(PKPaymentAuthorizationStatusSuccess, shippingMethods, summaryItems);  
  117. }  
  118.   
  119. - (void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller  
  120.                    didSelectShippingMethod:(PKShippingMethod *)shippingMethod  
  121.                                 completion:(void (^)(PKPaymentAuthorizationStatus, NSArray<PKPaymentSummaryItem *> * _Nonnull))completion{  
  122.     //配送方式回调,如果需要根据不同的送货方式进行支付金额的调整,比如包邮和付费加速配送,可以实现该代理  
  123.     PKShippingMethod *oldShippingMethod = [summaryItems objectAtIndex:2];  
  124.     PKPaymentSummaryItem *total = [summaryItems lastObject];  
  125.     total.amount = [total.amount decimalNumberBySubtracting:oldShippingMethod.amount];  
  126.     total.amount = [total.amount decimalNumberByAdding:shippingMethod.amount];  
  127.       
  128.     [summaryItems replaceObjectAtIndex:2 withObject:shippingMethod];  
  129.     [summaryItems replaceObjectAtIndex:3 withObject:total];  
  130.       
  131.     completion(PKPaymentAuthorizationStatusSuccess, summaryItems);  
  132. }  
  133. -(void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller didSelectPaymentMethod:(PKPaymentMethod *)paymentMethod completion:(void (^)(NSArray<PKPaymentSummaryItem *> * _Nonnull))completion{  
  134.     //支付银行卡回调,如果需要根据不同的银行调整付费金额,可以实现该代理  
  135.     completion(summaryItems);   
  136. }  
  137. -(void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller didSelectShippingAddress:(ABRecordRef)address completion:(void (^)(PKPaymentAuthorizationStatus, NSArray<PKShippingMethod *> * _Nonnull, NSArray<PKPaymentSummaryItem *> * _Nonnull))completion{  
  138.     //送货地址回调,已弃用  
  139. }  
  140. - (void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller  
  141.                        didAuthorizePayment:(PKPayment *)payment  
  142.                                 completion:(void (^)(PKPaymentAuthorizationStatus status))completion {  
  143.       
  144.     PKPaymentToken *payToken = payment.token;  
  145.     //支付凭据,发给服务端进行验证支付是否真实有效  
  146.     PKContact *billingContact = payment.billingContact;     //账单信息  
  147.     PKContact *shippingContact = payment.shippingContact;   //送货信息  
  148.     PKContact *shippingMethod = payment.shippingMethod;     //送货方式  
  149.       
  150.     // 这里需要将Token和地址信息发送到自己的服务器上,进行订单处理,处理之后,根据自己的服务器返回的结果调用completion()代码块,根据传进去的参数界面的显示结果会不同  
  151.     //等待服务器返回结果后再进行系统block调用  
  152.     dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(33 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{  
  153.         //模拟服务器通信  
  154.         completion(PKPaymentAuthorizationStatusFailure);  
  155.     });  
  156.       
  157.       
  158. }  
  159. - (void)paymentAuthorizationViewControllerDidFinish:(PKPaymentAuthorizationViewController *)controller{  
  160.     [controller dismissViewControllerAnimated:YES completion:nil];  
  161. }  
  162.   
  163. @end  




demo下载地址 https://github.com/lsmakethebest/LSApplePayDemo

感谢作者原文地址:http://blog.csdn.net/itiapp_home/article/details/52448012

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值