iOS-APP集成Apple Pay指南

版权声明:本文为作者原创文章, 如果有相同的或者相似的,那将是我的荣幸。

Apple Pay是什么?

Apple Pay目前在国内上线已有一段时间,这意味着消费者可通过 苹果手机、苹果手表等智能设备来进行支付,它的功能类似一个“卡包”,讲实体银行卡虚拟到手机里,用户可以绑定储蓄卡或信用卡实现刷卡支付。


为什么使用Apple Pay

从理论上看:微信支付也好、支付宝也好,均属于“结算平台”,他们会透过银联,从你的银行里提出现金代为托管;直至你把金钱放回银行之前,都只能在微信/支付宝上使用。但 Apple Pay 只是一张电子信用卡,你的钱仍然在银行里,付款时直接从银联向银行提取。而从技上术上,微信支付也好、支付宝也好,在付款时都要透过相机或条码机,读取一次性的二维码;而 Apple Pay 则透过近场通信 (NFC) 的方式,读取 iPhone 上的 Token 令牌。

从实际上看:目前微信支付及支付宝的优势在于低入场门槛:商店只要有台智能手机,就毋须为移动支付购入/租用新设备,而消费者也不需要很高端的旗舰级设备。而 Apple Pay 优势是良好的用户体验,使用 Apple Pay 付费,既安全、又快捷、隐私度也比较高。


设备支持有哪些要求?

Apple Pay需要支持NFC功能,目前只限于iPhone 6s、iPhone 6s Plus、iPhone 6、iPhone 6 Plus和Apple Watch这几款设备使用。同时,用户需讲手机操作系统版本升级到iOS 9.2以上,Apple Watch则需要Watch OS 2.1版本以上。


Apple Pay如何使用?

iPhone上,先打开系统自带的Wallet应用,后点右上角的符号,这时你有两个选择,可以用摄像头拍卡就能识别,也可以手动输入,或者通过iTunes绑定,至于Apple Watch怎么使用,应该操作差不多,具体情况本人未去实践,还望谅解。


Apple Pay环境配置

  • 配置Bundle ID


    iOS-APP集成Apple Pay指南_第1张图片
    14671699608022.jpg
  • 添加商户的ID


    iOS-APP集成Apple Pay指南_第2张图片
    14671702234549.jpg
  • 把工程中对应的Bundle ID添加进去


    iOS-APP集成Apple Pay指南_第3张图片
    14671703281837.jpg
  • 点击创建好的商户ID


    iOS-APP集成Apple Pay指南_第4张图片
    14671705166905.jpg
  • 编辑商户ID


    iOS-APP集成Apple Pay指南_第5张图片
    14671711439975.jpg
  • 添加CSR文件


    iOS-APP集成Apple Pay指南_第6张图片
    14671714784874.jpg
  • 下载配置好的商户ID


    iOS-APP集成Apple Pay指南_第7张图片
    14671715087391.jpg

    14671715713657.jpg
  • 创建对应的App IDs


    iOS-APP集成Apple Pay指南_第8张图片
    14671716587260.jpg
  • 勾选Apple Pay


    iOS-APP集成Apple Pay指南_第9张图片
    14671717034194.jpg
  • 配置支付环境


    iOS-APP集成Apple Pay指南_第10张图片
    14671720852032.jpg
  • Clean一下工程,如果工程自动添加此文件则以上步骤正确


    iOS-APP集成Apple Pay指南_第11张图片
    14671720005926.jpg

App项目内部集成方式

Apple Pay使用了PassKit框架,所以需要导入相应头文件

#import 

接收Apple Pay处理信息的回调,需要遵守协议,实现相应的代理方法

@interface ViewController ()
@end

为了方便测试,触发支付操作时间写在touchBegan:方法中

- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event {
    // code...
}

具体代码实现如下:

  • 判断设备是否支持Apple Pay快捷支付功能
if (![PKPaymentAuthorizationViewController canMakePayments]) {
        // 提示用户该设备不支持Apple Pay快捷支付功能
        // code...
        return;
    }
  • 判断设备是否绑定过可支付的银行卡
    /**
     *  若没有可用银行卡,则跳转到设置银行卡界面
     *  PKPaymentNetworkVisa                Visa国际卡
     *  PKPaymentNetworkChinaUnionPay       中国银联
     *  PKPaymentNetworkDiscover            Discover(美国流行的信用卡)
     */
    if (![PKPaymentAuthorizationViewController canMakePaymentsUsingNetworks:@[PKPaymentNetworkVisa, PKPaymentNetworkChinaUnionPay, PKPaymentNetworkDiscover]]) {
        
        // 进入设置银行卡界面
        [[[PKPassLibrary alloc] init] openPaymentSetup];
        
    }

  • 设置商品参数
    // 创建商品
    NSDecimalNumber *firstAmount = [NSDecimalNumber decimalNumberWithString:@"1.11"];
    NSDecimalNumber *secondAmount = [NSDecimalNumber decimalNumberWithString:@"2.22"];
    NSDecimalNumber *thirdAmount = [NSDecimalNumber decimalNumberWithString:@"3.33"];
    
    NSDecimalNumber *amountSum = [NSDecimalNumber zero];
    amountSum = [amountSum decimalNumberByAdding:firstAmount];
    amountSum = [amountSum decimalNumberByAdding:secondAmount];
    amountSum = [amountSum decimalNumberByAdding:thirdAmount];
    
    /**
     *  @param label        商品名称(英文名称默认全部显示大写)
     *  @param amount       商品价格 - NSDecimalNumber类型
     */
    PKPaymentSummaryItem *firstItem = [PKPaymentSummaryItem summaryItemWithLabel:@"FirstItem" amount:firstAmount];
    PKPaymentSummaryItem *secondItem = [PKPaymentSummaryItem summaryItemWithLabel:@"SecondItem" amount:secondAmount];
    PKPaymentSummaryItem *thirdItem = [PKPaymentSummaryItem summaryItemWithLabel:@"ThirdtItem" amount:thirdAmount];
    
    PKPaymentSummaryItem *itemsSum = [PKPaymentSummaryItem summaryItemWithLabel:@"PJChao" amount:amountSum];
  • 创建支付请求(基本配置)
    PKPaymentRequest *request = [[PKPaymentRequest alloc] init];
    
    // 设置商户ID(merchant IDs)
    request.merchantIdentifier = @"merchant.com.zpj.ApplePayTest";
    
    // 设置国家代码(中国大陆)
    request.countryCode = @"CN";
    
    // 设置支付货币(人民币)
    request.currencyCode = @"CNY";
    
    // 设置商户的支付标准(3DS支付方式必须支持,其他方式可选)
    request.merchantCapabilities = PKMerchantCapability3DS;
    request.paymentSummaryItems = @[firstItem, secondItem, thirdItem, itemsSum];
    
    /**
     *  以上参数都是必须的
     *  以下参数不是必须的
     */
     
    // 设置收据内容
    request.requiredBillingAddressFields = PKAddressFieldAll;
    
    // 设置送货内容
    request.requiredShippingAddressFields = PKAddressFieldAll;
    
    // 设置送货方式
    PKShippingMethod *method = [PKShippingMethod summaryItemWithLabel:@"阿敏" amount:[NSDecimalNumber decimalNumberWithString:@"10.00"]];
    method.identifier = @"阿敏物流";
    method.detail = @"12小时到达";
    
    request.shippingMethods = @[method];
  • 显示支付界面
    PKPaymentAuthorizationViewController *paymentVC = [[PKPaymentAuthorizationViewController alloc] initWithPaymentRequest:request];
    paymentVC.delegate = self;
    
    if (paymentVC == nil) return;
    
    [self presentViewController:paymentVC animated:YES completion:nil];
  • 代理方法的实现
#pragma mark - 
- (void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller
                       didAuthorizePayment:(PKPayment *)payment
                                completion:(void (^)(PKPaymentAuthorizationStatus status))completion
{
    /**
     *  在这里支付信息应发送给服务器/第三方的SDK(银联SDK/易宝支付SDK/易智付SDK等)
     *  再根据服务器返回的支付成功与否进行不同处理
     *  这里直接返回支付成功
     */
    completion(PKPaymentAuthorizationStatusSuccess);
}

- (void)paymentAuthorizationViewControllerDidFinish:(PKPaymentAuthorizationViewController *)controller
{
    // 点击支付/取消按钮隐藏界面
    [controller dismissViewControllerAnimated:YES completion:nil];
}

附上测试结果

iOS-APP集成Apple Pay指南_第12张图片
14671851652964.jpg

iOS-APP集成Apple Pay指南_第13张图片
test.gif

iOS-APP集成Apple Pay指南_第14张图片
14671854207186.jpg

终于写完了,如果有什么问题,还望大神给予指点,Thank you。

你可能感兴趣的:(iOS-APP集成Apple Pay指南)