最近苹果推出了一种新的支付方式–ApplePay支付,虽然毁誉参半,可是不得不认可国内不少的公司还有商家已经开通了ApplePay,可能最早锋的莫过于肯德基和招商银行了。抛开优劣与否不说,做为一个开发者天然要第一时间把ApplePay搞懂搞通,用不用再另说。html
ApplePay的支付流程
在具体去进行每一步操做的时候必定要先了解一下ApplePay的具体的操做流程。这里是官方给出的开发者文档。全部的流程步骤还有逻辑流程均可以在这里找到答案。
开发者传送门
使用ApplePay开发一样的须要一个商户ID,开通权限,而后根据需求拼接支付请求。Apple Pay会对支付信息进行加密处理,以防止未获受权的第三方获取用户的支付信息。剩下的就是在本身的服务器上进行支付流程和处理了。ios
ApplePay的开发流程
1 获取证书
详细的官方指导能够参考这里苹果证书帮助习惯了苹果开发的人必定会料到,新的苹果支付必定是须要一个新的证书的,没错,须要建立一个新的商业证书。json
选择右侧的[Merchant IDs],点击右上角的添加。服务器
点击continueapp
点击registeride
如今新添加的Merchant ID已经显示出来了,能够添加到列表里了。post
将刚刚添加的MerchantID选中,选择编辑。ui
将选项改成Yes,点Continue。再继续Continue。而后会须要上传一个证书。这个时候来到本地打开钥匙串,生成本地证书,我这里直接贴每一步的截图了。编码
将生成的证书放到桌面上。加密
选择刚才建立的证书进行上传,而且点击生成。
选择描述文件选项,建立一个描述文件,而后点开他的详细信息,点击编辑。
确认ApplePay的两个选项都是enable。若是不是,点击edit将其勾选上。
生成对应的描述文件,在本地运行添加到钥匙串中。
2 工程配置
建立一个新工程,须要注意两点:1 在BuildIdentifier中设置的必须和描述文件同样。
2 在Capability标签中把ApplePay选项打开,而且将MerchantIDs选中,以下图
3 代码编写
1导入头文件并遵循代理
#import <PassKit/PassKit.h> #import <AddressBook/AddressBook.h> @interface ViewController ()<PKPaymentAuthorizationViewControllerDelegate>
2 处理支付页面
支付界面都是采用的PKPaymentAuthorizationViewController,每一条支付信息能够采用PKPaymentSummaryItem来进行编辑,最后调用苹果支付的时候就是调用的这个页面。
//点击支付的相应事件 - (IBAction)payAction:(UIButton *)sender { // 订单请求对象 PKPaymentRequest *request = [[PKPaymentRequest alloc]init]; //商品订单信息对象 PKPaymentSummaryItem *item1 = [PKPaymentSummaryItem summaryItemWithLabel:@"宝马车一辆" amount:[NSDecimalNumber decimalNumberWithString:@"100"]]; PKPaymentSummaryItem *item2 = [PKPaymentSummaryItem summaryItemWithLabel:@"真皮座椅一个" amount:[NSDecimalNumber decimalNumberWithString:@"200"]]; PKPaymentSummaryItem *item3 = [PKPaymentSummaryItem summaryItemWithLabel:@"自动雨刷两只" amount:[NSDecimalNumber decimalNumberWithString:@"50"]]; request.paymentSummaryItems = @[item1,item2,item3]; //指定国家地区编码 request.countryCode = @"CN"; //指定国家货币种类--人民币 request.currencyCode = @"CNY"; //指定支持的网上银行支付方式 request.supportedNetworks = @[PKPaymentNetworkVisa,PKPaymentNetworkChinaUnionPay,PKPaymentNetworkMasterCard]; //指定APP须要的商业ID request.merchantIdentifier = @"merchant.com.coderqi.pay.test"; //指定支付的范围限制 request.merchantCapabilities = PKMerchantCapabilityEMV; //指定订单接受的地址是哪里 request.requiredBillingAddressFields = PKAddressFieldEmail | PKAddressFieldPostalAddress; //支付界面显示对象 PKPaymentAuthorizationViewController *pvc = [[PKPaymentAuthorizationViewController alloc]initWithPaymentRequest:request]; pvc.delegate = self; if (!pvc) { NSLog(@"出问题了,请注意检查"); @throw [NSException exceptionWithName:@"CQ_Error" reason:@"建立支付显示界面不成功" userInfo:nil]; }else{ [self presentViewController:pvc animated:YES completion:nil]; } }
3 编写代理回调
接下来就是代理回调的处理,服务器接收到了咱们的请求以后收到返回信息会调用对应的方法。
//在支付的过程当中进行调用,这个方法直接影响支付结果在界面上的显示 //payment 是表明的支付对象,支付相关的全部信息都存在于这个对象,1 token 2 address //comletion 是一个回调Block块,block块传递的参数直接影响界面结果的显示。 -(void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller didAuthorizePayment:(PKPayment *)payment completion:(void (^)(PKPaymentAuthorizationStatus))completion{ /* NSError *error; ABMultiValueRef addressMultiValue = ABRecordCopyValue(payment.billingAddress ,kABPersonAddressProperty); NSDictionary *addressDictionary = (__bridge_transfer NSDictionary *) ABMultiValueCopyValueAtIndex(addressMultiValue, 0); //这里模拟取出地址里的每个信息。 NSLog(@"%@",addressDictionary[@"State"]); NSData *json = [NSJSONSerialization dataWithJSONObject:addressDictionary options:NSJSONWritingPrettyPrinted error: &error]; // 这里须要将Token和地址信息发送到本身的服务器上,进行订单处理,处理以后,根据本身的服务器返回的结果调用completion()代码块,根据传进去的参数界面的显示结果会不一样 PKPaymentAuthorizationStatus status; // From your server completion(status); */ //拿到token, PKPaymentToken *token = payment.token; //拿到订单地址 NSString *city = payment.billingContact.postalAddress.city; NSLog(@"city:%@",city); ///在这里将token和地址发送到本身的服务器,有本身的服务器与银行和商家进行接口调用和支付将结果返回到这里 //咱们根据结果生成对应的状态对象,根据状态对象显示不一样的支付结构 //状态对象 PKPaymentAuthorizationStatus status = PKPaymentAuthorizationStatusFailure; completion(status); } //当支付过程完成的时候进行调用 -(void)paymentAuthorizationViewControllerDidFinish:(PKPaymentAuthorizationViewController *)controller{ [controller dismissViewControllerAnimated:YES completion:nil]; }
到此就结束了,这只是一个初步的研究,并无深刻,好比指纹付啊,还有不少功能能够添加.
文/Ashoka_APP(简书做者) 原文连接:http://www.jianshu.com/p/cc38d1a6bd1d 著做权归做者全部,转载请联系做者得到受权,并标注“简书做者”。