Apple Pay运行环境:iPhone6以上设备,操作系统最低iOS9.0以上,部分信息设置需要iOS9.2以上。目前还不支持企业证书添加。
环境搭建好后可以在模拟器上面运行,xcode7.2.1+iPhone6SP9.2系统下,系统会绑定几种虚拟的银行卡,和几个联系人,方便调试,支付也不会发生真实的付款,真的很方便。
准备工作
在接入Apple Pay之前,首先要申请MerchantID及对应证书。
工程设置
- bundleID设置
Capability中启用Apple Pay权限,并选择merchantID。
之后项目会多一个Applepay的配置文件ApplePayYasin.entitlements
- 需要引用的库
Xcode7.0以上不需要再手动添加需要引用的库了,只需要导入头文件就可以了
1 2 3 |
|
- 设备Applepay权限检测
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
创建支付请求PKPaymentRequest
- 初始化PKPaymentRequest
这里需要注意RMB的币种代码是CNY
1 2 3 4 5 6 7 |
|
- 设置发票配送信息和货物配送地址信息,用户设置后可以通过代理回调代理获取信息的更新
1 2 3 4 5 |
|
送货信息页面展示
设置货物的配送方式,不需要不配置
1 2 3 4 5 6 7 8 9 10 |
|
- 账单信息的设置
每条账单的设置
账单列表使用PKPaymentSummaryItem添加描述和价格,价格使用NSDecimalNumber。
PKPaymentSummaryItem初始化:
label为商品名字或者是描述,amount为商品价格,折扣为负数,type为该条账单为最终价格还是估算价格(比如出租车价格预估)
1 2 |
|
NSDecimalNumber初始化:
NSDecimalNumber可以使用数字初始化,也可以使用字符串。
使用方法请移步我写的NSDecimalNumber--十进制数
添加账单列表:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
|
显示购物信息并进行支付
1 2 3 4 |
|
PKPaymentAuthorizationViewControllerDelegate代理
- 这里还有两个类要介绍
PKPayment 支付成功信息
1 2 3 4 5 |
|
PKContact 联系人信息
1 2 3 4 5 |
|
- 代理说明
送货地址回调
1 2 3 4 5 6 7 |
|
送货方式回调
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
支付卡选择回调
1 2 3 4 |
|
送货地址回调,已弃用
1 2 3 |
|
付款成功苹果服务器返回信息回调,做服务器验证
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
支付完成回调
1 2 3 |
#import "ViewController.h" #import <PassKit/PassKit.h> @interface ViewController ()<PKPaymentAuthorizationViewControllerDelegate> @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; //1、判断当前设备是否支持苹果支付 // 2、判断是否添加银行卡 if (![PKPaymentAuthorizationViewController class]) { //PKPaymentAuthorizationViewController需iOS8.0以上支持 NSLog(@"操作系统不支持ApplePay,请升级至9.0以上版本,且iPhone6以上设备才支持"); return; } else if (![PKPaymentAuthorizationViewController canMakePayments]) { NSLog(@"当前设备不支持applepay"); } //PKPaymentNetworkChinaUnionPay 银联卡 。PKPaymentNetworkVisa vsa 卡 //检查用户是否可进行某种卡的支付,是否支持Amex、MasterCard、Visa与银联四种卡,,根据自己项目的需要进行检测 else if (![PKPaymentAuthorizationViewController canMakePaymentsUsingNetworks:@[PKPaymentNetworkChinaUnionPay,PKPaymentNetworkVisa]]) { // 如果没有添加银行卡,创建一个跳转按钮,跳转到添加银行卡的界面 PKPaymentButton *button=[PKPaymentButton buttonWithType:PKPaymentButtonTypeSetUp style:PKPaymentButtonStyleWhiteOutline]; button.center=self.view.center; [self.view addSubview:button]; [button addTarget:self action:@selector(jumpAddBank) forControlEvents:UIControlEventTouchUpInside]; } else { // 创建一个够买按钮,当用户点击按钮时,购买一个商品 PKPaymentButton *button=[PKPaymentButton buttonWithType:PKPaymentButtonTypeBuy style:PKPaymentButtonStyleBlack]; button.center=self.view.center; [self.view addSubview:button]; [button addTarget:self action:@selector(clickBuy) forControlEvents:UIControlEventTouchUpInside]; } } #pragma mark - 点击去购买 -(void)clickBuy { // 1、创建一个支付请求 PKPaymentRequest *request=[[PKPaymentRequest alloc]init]; // 配置支付请求 //1.1 配置商家ID [email protected]"merchant.com.cym.weiliaopay"; //1.2 配置国家代码,以及货币代码 [email protected]"CN"; [email protected]"CNY"; // 1.3 支付的银行卡 [email protected][PKPaymentNetworkChinaUnionPay,PKPaymentNetworkVisa]; // 1.4配置商户的处理方式//设置支持的交易处理协议,3DS必须支持,EMV为可选,目前国内的话还是使用两者吧 request.merchantCapabilities=PKMerchantCapability3DS|PKMerchantCapabilityEMV; // 1.5 配置购买的商品列表 NSDecimalNumber *price=[NSDecimalNumber decimalNumberWithString:@"0.01"]; PKPaymentSummaryItem *item=[PKPaymentSummaryItem summaryItemWithLabel:@"汽车保养" amount:price]; [email protected][item]; //配置请求的附加项 //1、是否显示发票收货地址 。显示哪些选项 // request.requiredBillingAddressFields=PKAddressFieldAll; // // 2、是否显示快递地址,显示哪些选项 // request.requiredShippingAddressFields=PKAddressFieldAll; //2、 验证用户的支付授权 PKPaymentAuthorizationViewController *PayVC=[[PKPaymentAuthorizationViewController alloc]initWithPaymentRequest:request]; PayVC.delegate=self; [self presentViewController:PayVC animated:YES completion:nil]; } #pragma mark -代理方法 //如果当用户授权成功,就会调用这个方法 /* 参数一:授权控制器 参数二:支付对象 参数三:系统给定的一个回调代码块,我们需要执行这个代码块,来告诉系统当前的的支付状态是否成功 */ - (void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller didAuthorizePayment:(PKPayment *)payment completion:(void (^)(PKPaymentAuthorizationStatus status))completion { NSLog(@"token=%@",payment.token); // 一般在此外,拿到支付信息,发送给服务器处理,处理完毕之后,服务器返回一个状态,告诉客户端,是否支付成功,然后由客户端进行处理 BOOL isSuccess=YES; if (isSuccess) { completion(PKPaymentAuthorizationStatusSuccess); } else { completion(PKPaymentAuthorizationStatusFailure); } } #pragma mari 当用户授权成功,或者取消授权时调用 - (void)paymentAuthorizationViewControllerDidFinish:(PKPaymentAuthorizationViewController *)controller { [self dismissViewControllerAnimated:YES completion:nil]; } #pragma mark - 添加银行卡界面 -(void)jumpAddBank { // 跳转到添加银行卡界面 PKPassLibrary *pl=[[PKPassLibrary alloc]init]; [pl openPaymentSetup]; } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } |