iOS集成Apple Pay

Apple Pay是什么?

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


为什么使用Apple Pay

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

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


设备支持有哪些要求?

Apple Pay需要支持NFC功能,需要是iPhone6s以上设备,同时,用户需将手机操作系统版本升级到iOS 9.2以上,Apple Watch则需要Watch OS 2.1版本以上。


Apple Pay如何使用?

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


Apple Pay环境配置

  • 配置Bundle ID
    14671699608022.jpg

  • 添加商户的ID
    14671702234549.jpg

  • 把工程中对应的Bundle ID添加进去
    14671703281837.jpg

  • 点击创建好的商户ID
    14671705166905.jpg

  • 编辑商户ID
    14671711439975.jpg

  • 添加CSR文件
    14671714784874.jpg

  • 下载配置好的商户ID
    14671715087391.jpg
    14671715713657.jpg

  • 创建对应的App IDs
    14671716587260.jpg

  • 勾选Apple Pay
    14671717034194.jpg

  • 配置支付环境
    14671720852032.jpg

  • Clean一下工程,如果工程自动添加此文件则以上步骤正确
    14671720005926.jpg


App项目内部集成方式

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

#import <PassKit/PassKit.h>

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

@interface ViewController ()<PKPaymentAuthorizationViewControllerDelegate>
@end

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

- (void)touchesBegan:(NSSet<UITouch *> *)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 - <PKPaymentAuthorizationViewControllerDelegate>
- (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];
}

附上测试结果

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值