iOS开发 Apple Pay

一、什么是Apple Pay?

  1. 概念

    Apple Pay,简单来说, 就是一种移动支付方式。通过Touch ID/ Passcode,用户可使用存储在iPhone 6, 6p等设备上的信用卡和借记卡支付证书来授权支付; 它是苹果公司在2014苹果秋季新品发布会上发布的一种基于NFC的手机支付功能,于2014年10月20日在美国正式上线,2016年2月18日凌晨5:00, Apple Pay 业务在中国上线。

  2. 使用前提

    (1). 支持设备

Apple Pay支持的硬件设备 (表1)
线上 线下 线上&线下

iPad Pro

Apple Watch

iPhone 6

iPad Air 2

 

iPhone 6 Plus

iPad mini 3

 

iPhone 6s

iPad mini 4

 
iPhone 6s Plus

    (2). 系统支持(iOS8.0+版本, 注意:iOS9.2才真正的支持“银联支付”, 意味着iOS9.2以后才可以在中国市场使用)

    (3). 银行支持

        需要将被支持银行的银行卡, 添加到手机wallet应用当中

        

二、 应用场景?

  1. 线下支付

    > 除下使用前提之外, 还要求      

    > 商家支持(要求必须有支持NFC的刷卡机)

      如果发现以下标识,就代表该商家支持Apple Pay

      

      苹果公开的Apple Pay商家有:

        

  2. 线上支付

    > 除下使用前提之外, 还要求

    > App 支持

      目前支持Apple Pay支付方式的App并不多。很多公司也在集成当中,这也是写这篇博客的目的。

唯品会   大众点评  

       目前, 苹果公开的支持Apple Pay的APP列表

        

 三、 与微信支付以及支付宝等第三方支付平台的区别?

  1. 硬件方面

    Apple Pay:必须是iOS设备, 而且是按照线上支付和线下支付区分不同的真机设备(具体参考表1)

    微信、支付宝: 基本跟硬件设备无关, 支持大多数的只能手机

  2. 网络环境要求

    Apple Pay:线上支付需要联网, 线下支付无需联网就可以支付

    微信、支付宝: 无论是线上还是线下支付, 都需要联网使用

  3. 使用技术

    Apple Pay:线下支付使用的是 基于NFC的近场通讯技术

    微信、支付宝: 线下支付使用的是 扫码支付(条形码、二维码)

  4. 主要功能

    Apple Pay:线上支付、线下支付、部分升级后的ATM机可以取款

    微信、支付宝: 线上支付、线下支付、转账、理财等

  5. 安全性能

    Apple Pay:不保留银行卡信息,并且不会暴漏给外界、不分流银行存款(不需要从银行卡转钱到另外一个平台)、不能充值  安全性较高

    微信、支付宝: 密码保护,身份验证等手段保护账户  安全性相对稍差

  6. 支付时长

    Apple Pay:无论是线上支付,还是线下支付, 只需要验证指纹即可支付。非常迅速

    微信、支付宝: 需要扫码支付, 流程相对繁琐,所以时长较长

  7. 各自弊端

    Apple Pay:只适用于苹果设备, 支付场景单一,无转账理财等业务

    微信、支付宝: 安全性较差, 必须联网操作,需要充值到对应平台

 四、线上支付集成步骤

 1. 配置支付环境

  • 使用XCode创建一个工程, 并设置好对应的BundleID
  • 注册并配置一个商业标示符
    • 添加一个App ID
    • 配置Merchant ID
    • 为Merchant ID 配置证书, 并下载证书安装到钥匙串
    • 检查安装到钥匙串中的证书是否有效
    • 绑定Merchant ID 到 APP ID

 2. 配置Xcode 项目

    • 调整系统最低部署版本(iOS8.0)
    • 开启Apple Pay功能

 3. 代码实现

  • 判断当前设备是否可以支付
  • 判断"Wallet有没有添加该支付网络的储蓄卡/信用卡"
  • 创建一个支付请求, 并配置各项信息
  • 弹出授权控制器,让用户给支付授权
  • 处理支付凭证

 4. 服务器处理

五、 具体步骤实现

   1. 配置支付环境

    • 使用XCode创建一个工程, 并设置好对应的BundleID

       

    • 注册并配置一个商业标示符

      (1)添加一个App ID, 并勾选Apple Pay功能

           

        

      (2)配置Merchant ID

        

        

      (3)为Merchant ID 配置证书, 并下载证书安装到钥匙串

        

        

        

        

      (4)检查安装到钥匙串中的证书是否有效

        问题描述: 有可能会出现提示

        问题原因: 系统根证书/中级证书颁发机构过期

        解决方案:   重新下载证书, 并安装,具体下载列表看下图

          

     

      (5)绑定Merchant ID 到 APP ID

        

          

         

         

         

 2. 配置Xcode 项目

  • 调整系统最低部署版本(iOS8.0)

      

  • 开启Apple Pay功能

      

    注意: 以上步骤截图, 只是关键处截图, 如果在具体细节处遇到问题, 欢迎关注公众号(王顺子),共同探讨。或者参照具体视频教程, 链接地址, 后续附上。

  

  3. 代码实现    

    (1)判断当前设备是否可以支付

      


1

2

3

4

5

if(![PKPaymentAuthorizationViewController canMakePayments])

{

    NSLog(@"不能支付");

    return;

}

    (2)判断"Wallet有没有添加该支付网络的储蓄卡/信用卡"

       


1

2

3

4

5

6

7

8

9

10

11

12

    if (![PKPaymentAuthorizationViewController canMakePaymentsUsingNetworks:@[PKPaymentNetworkAmex, PKPaymentNetworkMasterCard, PKPaymentNetworkVisa, PKPaymentNetworkChinaUnionPay]]) {

        NSLog(@"Wallet没有添加该支付网络的储蓄卡/信用卡");

        // 创建一个设置按钮

//        PKPaymentButton *button = [PKPaymentButton buttonWithType:PKPaymentButtonTypeSetUp style:PKPaymentButtonStyleWhiteOutline];

//        [button addTarget:self action:@selector(jump) forControlEvents:UIControlEventTouchUpInside];

//        button.center = self.view.center;

//        [self.view addSubview:button];

        return;

    }

    (3)创建一个支付请求, 并配置各项信息

      


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

// 1. 创建一个支付请求

    PKPaymentRequest *request = [[PKPaymentRequest alloc] init];

    // 2. 参数配置

    // 2.1 商店标识

    request.merchantIdentifier = @"merchant.520it.com";

    // 2.2 货币代码

    request.currencyCode = @"CNY";

    // 2.3 国家编码

    request.countryCode = @"CN";

    // 2.4 支持的支付网络(PKPaymentNetworkChinaUnionPay iOS9.2开始支持)

    request.supportedNetworks = @[PKPaymentNetworkAmex, PKPaymentNetworkMasterCard, PKPaymentNetworkVisa, PKPaymentNetworkChinaUnionPay];

    // 2.5 支付请求包含一个支付摘要项目的列表

    NSDecimalNumber *price1 = [NSDecimalNumber decimalNumberWithString:@"2"];

    PKPaymentSummaryItem *item1 = [PKPaymentSummaryItem summaryItemWithLabel:@"手榴弹" amount:price1];

    NSDecimalNumber *price2 = [NSDecimalNumber decimalNumberWithString:@"6"];

    PKPaymentSummaryItem *item2 = [PKPaymentSummaryItem summaryItemWithLabel:@"炸弹" amount:price2 type:PKPaymentSummaryItemTypePending];

    NSDecimalNumber *totalAmount = [NSDecimalNumber zero];

    totalAmount = [totalAmount decimalNumberByAdding:price1];

    totalAmount = [totalAmount decimalNumberByAdding:price2];

    PKPaymentSummaryItem *total = [PKPaymentSummaryItem summaryItemWithLabel:@"小码哥财务中心" amount:totalAmount type:PKPaymentSummaryItemTypePending];

    // 注意: 数组最后一个是总价格

    request.paymentSummaryItems = @[item1, item2, total];

    // 2.6 运输方式

    NSDecimalNumber *shippingPrice = [NSDecimalNumber decimalNumberWithString:@"18.0"];

    PKShippingMethod *method = [PKShippingMethod summaryItemWithLabel:@"顺丰快递" amount:shippingPrice];

    method.detail = @"24小时送到!";

    method.identifier = @"shunfeng";

    request.shippingMethods = @[method];

    request.shippingType = PKShippingTypeServicePickup;

    // 2.7 通过指定merchantCapabilities属性来指定你支持的支付处理标准,3DS支付方式是必须支持的,EMV方式是可选的,

    request.merchantCapabilities = PKMerchantCapability3DS | PKMerchantCapabilityEMV | PKMerchantCapabilityCredit | PKMerchantCapabilityDebit;

    

    // 2.8 需要的配送信息和账单信息

    request.requiredBillingAddressFields = PKAddressFieldAll;

    request.requiredShippingAddressFields = PKAddressFieldAll;

    // 2.9 存储额外信息

    // 使用applicationData属性来存储一些在你的应用中关于这次支付请求的唯一标识信息,比如一个购物车的标识符。在用户授权支付之后,这个属性的哈希值会出现在这次支付的token中。

    request.applicationData = [@"购物车ID: 123456" dataUsingEncoding:NSUTF8StringEncoding];

    (4)弹出授权控制器,让用户给支付授权

      


1

2

3

4

5

6

7

8

// 3. 开始支付

    PKPaymentAuthorizationViewController *paymentPane = [[PKPaymentAuthorizationViewController alloc] initWithPaymentRequest:request];

    if (paymentPane == nil) {

        NSLog(@"授权控制器创建失败");

        return;

    }

    paymentPane.delegate = self;

    [self presentViewController:paymentPane animated:YES completion:nil];

    (5)处理支付凭证(token)

      


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

/**

 *  当授权成功之后会调用这个代理方法

 */

- (void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller

                       didAuthorizePayment:(PKPayment *)payment

                                completion:(void (^)(PKPaymentAuthorizationStatus status))completion;

{

//    PKPayment *temp = payment;

    NSLog(@"验证授权---%@", payment.token);

    NSLog(@"验证通过后, 需要开发者继续完成交易");

    // 它需要你连接服务器并上传支付令牌和 其他信息,以完成整个支付流程。

    BOOL isSuccess = YES;

    if (isSuccess) {

        completion(PKPaymentAuthorizationStatusSuccess);

    }else

    {

        completion(PKPaymentAuthorizationStatusFailure);

    }

    

}

    

    (6)关闭授权控制器


1

2

3

4

5

6

7

8

/**

 *  当授权成功之后或者取消授权之后会调用这个代理方法

 */

- (void)paymentAuthorizationViewControllerDidFinish:(PKPaymentAuthorizationViewController *)controller

{

    NSLog(@"取消或者交易完成");

    [self dismissViewControllerAnimated:YES completion:nil];

}

     * 支付授权的流程:

    • 框架发送支付请求给安全模块,只有安全模块可以访问存储在设备上的标记化的卡信息。
    • 安全模块把特定的卡和商家等支付数据加密,以保证只有苹果可以读取,然后发送给框架。框架会将这些数据发送给苹果。
    • 苹果服务器再次加密这些支付数据,以保证只有商家可以读取。然后服务器对它进行签名,生成支付token,然后发送给设备。
    • 框架调用相应的代理方法并传入这个token,然后你的代理方法传送token给你的服务器。

    

  

  4. 服务器接收到token后的一般处理流程

    • 验证支付数据的哈希表和签名
    • 为加密过的支付数据解码  
    • 向支付处理系统提交支付数据
    • 向订单追踪系统提交订单

   处理支付请求时,你有两个选择;你既可以利用支付平台处理支付请求,也可以自己实现支付请求处理流程。一个常用的支付平台可以完成上述大部分操作。

   关于支持Apple Pay支付平台的更多信息,请参考developer.apple.com/apple-pay/

六、资料附件

  源码地址: https://github.com/wangshunzi/ApplePayDemo.git

  视频教程:http://pan.baidu.com/s/1mhzzqic 提取码:gghg

 

时间: 2024-08-05 09:50:31

iOS开发 Apple Pay的相关文章

开发apple pay碰到的问题总结

本来想简单总结一下Apple Pay 开发过程中的几个问题, 结果被下面这篇文章全碰上了, 干脆全文转载, 作者对相关资源整理得比较详细, 比较有参考价值 总的来说, 我们做过 APNs 推送的话, 申请 商户ID 并关联到 apple id, 申请证书, 生成provisioning profile等步骤都差不多 然后我真机调试有两个地方没通过, 下文也总结了, 我拎出来单独说一下: 1, Payment request is invalid: check your entitlements.

iOS开发-Apple Pay-苹果支付

转自:http://www.open-open.com/lib/view/open1471952847228.html Apple Pay,是苹果公司在2014年苹果秋季新品发布会上发布的一种基于NFC(近场通讯)的手机支付功能,2016年2月18日凌晨5点,Apple Pay业务在中国上线. 它的支付方式是通过 Touch ID/Passcode 验证方式,用户可使用事先已经储存在IPhone 6 ,6p或者更新设备上的银行卡支付证书来授权支付,当然最新的5e,同样支持Apple Pay支付.

iOS开发笔记(5)---- 应用内接入Apple Pay

自2014年苹果秋季发布会至今,Apple Pay推出已将近一年时间,我们对其便利性与安全性也早有耳闻,然而时至今日其使用范围仍然只限美国.英国两地区,对于在中国区的引入,我们只能报以期望. 总体来说,在应用内集成Apple Pay需要两个部分:交易授权与交易处理.交易授权在应用内进行,通过PassKit.framework所提供的接口向用户获取支付授权:而交易处理则需要授权后调用可受理交易的服务器接口,你可以选择某个支付平台来处理交易,或者也可以自己实现交易处理过程,苹果官方比较推荐前者. 准

iOS Apple Pay

iOS 苹果支付 需要证书支持支付功能 targets 打开支付功能按钮 //ApplePay#import <PassKit/PassKit.h>                                 //用户绑定的银行卡信息#import <PassKit/PKPaymentAuthorizationViewController.h>    //Apple Pay的展示控件#import <AddressBook/AddressBook.h>       

iOS App集成Apple Pay教程(附示例代码)

苹果在本周一发布了iOS 8.1版本,并正式开放了Apple Pay支付系统.Apple Pay是一个基于NFC的支付系统,不久将被数以万计的线下零售商店予以支持.即便这项科技并不是彻底的突破性进展,但它足以推动许多公司和零售商来支持这种支付方式,并成为苹果又一项成功的投资. Apple Pay还给开发者带来了处理支付的新渠道,用户将期望在应用中使用它,因为它将验证和交易极端简化,仅需手指轻轻一触即可完成,如果应用里面有涉及到交易,开发者很有必要集成Apple Pay.那么如何将Apple Pa

iOS App集成Apple Pay

Xcode 6.1提供了非常方便的界面来设置Apple Pay.第一步先修改target为iOS 8.1,然后在项目Capabilities里将Apple Pay设置为on,这将自动导入需要的库文件,然后添加一个权限文件并设置,最后修改或创建你的App ID. 你可能会注意到上面没有有效的Merchant ID,我们需要创建一个,访问苹果iOS 开发者中心的位于Identifiers > Merchant ID 然后随着流程指引,创建一个Merchant ID并注册它. 现在,我们需要给Merc

快速玩转Apple Pay开发

快速玩转Apple Pay开发 更新时间:2016年02月20日09时25分 来源:传智播客 Apple Pay 2016年2月18日上午,苹果公司宣布,与中国银联达成合作,正式在中国大陆上线Apple Pay服务. Apple Pay是一个基于NFC的支付系统,几乎所有的银行都支持.不知道大家还有没有印象,当初支付宝和位置的支付刚出来的时候,银行都恨不得想把他俩弄死.为啥Apple Pay一出来各大银行都支持.因为它和支付宝支付.微信支付是完全不同的概念.Apple Pay根本不是一个第三方支

ios apple pay 证书配置

一 环境配置 需要开发者账号 开发者中心https://developer.apple.com/membercenter/index.action 添加一个APP IDs 二.配置Merchant IDs商业ID   下面进行appids和商业id的绑定 之后在回到appids中查看id中的apple pay,发现已经变为可使用状态了 接下来是为商业id生成证书. 点击Merchant IDs 点击id.点击编辑. 这里会有一个提示信息.提示是否允许在美国以外的地区使用apple pay?当然要

iOS apple Pay 教程

Apple Pay运行环境:iPhone6以上设备,操作系统最低iOS9.0以上,部分信息设置需要iOS9.2以上.目前还不支持企业证书添加. 环境搭建好后可以在模拟器上面运行,xcode7.2.1+iPhone6SP9.2系统下,系统会绑定几种虚拟的银行卡,和几个联系人,方便调试,支付也不会发生真实的付款,真的很方便. 准备工作 在接入Apple Pay之前,首先要申请MerchantID及对应证书. 工程设置 bundleID设置 Capability中启用Apple Pay权限,并选择me