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
5if(![PKPaymentAuthorizationViewController canMakePayments])
{
NSLog(@"不能支付");
return;
}
(2)判断"Wallet有没有添加该支付网络的储蓄卡/信用卡"
1
12if(![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. 创建一个支付请求
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 = [NSDecimalNumberdecimalNumberWithString:@"2"];
PKPaymentSummaryItem *item1 = [PKPaymentSummaryItem summaryItemWithLabel:@"手榴弹"amount:price1];
NSDecimalNumber*price2 = [NSDecimalNumberdecimalNumberWithString:@"6"];
PKPaymentSummaryItem *item2 = [PKPaymentSummaryItem summaryItemWithLabel:@"炸弹"amount:price2 type:PKPaymentSummaryItemTypePending];
NSDecimalNumber*totalAmount = [NSDecimalNumberzero];
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 = [NSDecimalNumberdecimalNumberWithString:@"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)弹出授权控制器,让用户给支付授权
// 3. 开始支付
8// 3. 开始支付
PKPaymentAuthorizationViewController *paymentPane = [[PKPaymentAuthorizationViewController alloc] initWithPaymentRequest:request];
if(paymentPane ==nil) {
NSLog(@"授权控制器创建失败");
return;
}
paymentPane.delegate =self;
[selfpresentViewController:paymentPane animated:YEScompletion:nil];
(5)处理支付凭证(token)
/**
* 当授权成功之后会调用这个代理方法
*/
- (void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller
didAuthorizePayment:(PKPayment *)payment
completion:(void(^)(PKPaymentAuthorizationStatus status))completion;
{
// PKPayment *temp = payment;
NSLog(@"验证授权---%@", payment.token);
NSLog(@"验证通过后, 需要开发者继续完成交易");
// 它需要你连接服务器并上传支付令牌和 其他信息,以完成整个支付流程。
BOOLisSuccess =YES;
if(isSuccess) {
completion(PKPaymentAuthorizationStatusSuccess);
}else
{
completion(PKPaymentAuthorizationStatusFailure);
}
}
(6)关闭授权控制器
/**
* 当授权成功之后或者取消授权之后会调用这个代理方法
*/
- (void)paymentAuthorizationViewControllerDidFinish:(PKPaymentAuthorizationViewController *)controller
{
NSLog(@"取消或者交易完成");
[selfdismissViewControllerAnimated:YEScompletion:nil];
}
* 支付授权的流程:
框架发送支付请求给安全模块,只有安全模块可以访问存储在设备上的标记化的卡信息。
安全模块把特定的卡和商家等支付数据加密,以保证只有苹果可以读取,然后发送给框架。框架会将这些数据发送给苹果。
苹果服务器再次加密这些支付数据,以保证只有商家可以读取。然后服务器对它进行签名,生成支付token,然后发送给设备。
框架调用相应的代理方法并传入这个token,然后你的代理方法传送token给你的服务器。
4. 服务器接收到token后的一般处理流程
验证支付数据的哈希表和签名
为加密过的支付数据解码
向支付处理系统提交支付数据
向订单追踪系统提交订单
处理支付请求时,你有两个选择;你既可以利用支付平台处理支付请求,也可以自己实现支付请求处理流程。一个常用的支付平台可以完成上述大部分操作。
关于支持Apple Pay支付平台的更多信息,请参考developer.apple.com/apple-pay/