1、Apple Pay的介紹
-
1.1 Apple Pay概念
- Apple Pay,簡單來說, 就是一種移動支付方式。通過Touch ID/ Passcode,用戶可使用存儲在iPhone 6, 6p等之后的新設備上的信用卡和借記卡支付證書來授權支付; 它是蘋果公司在2014蘋果秋季新品發布會上發布的一種基於NFC的手機支付功能,於2014年10月20日在美國正式上線,2016年2月18日凌晨5:00, Apple Pay 業務在中國上線。
-
1.2 使用前提
- 設備支持
- iPhone
- 配備面容 ID 的 iPhone 機型
- 配備觸控 ID 的 iPhone 機型(iPhone 5s 除外)
- 識別您的 iPhone 機型
- iPad
- 配備觸控 ID 或面容 ID 的 iPad Pro、iPad Air、iPad 和 iPad mini 機型
- Apple Watch
- Apple Watch Series 1 和 2 及更新機型
- Apple Watch(第 1 代)7
- Mac
- 配備觸控 ID 功能的 Mac 機型
- 2012 年或之后推出的 Mac 機型,與支持 Apple Pay 的 iPhone 或 Apple Watch 搭配使用
- iPhone
- 系統支持
- iOS8.0以上版本, 注意:iOS9.2才真正的支持“銀聯支付”, 意味着iOS9.2以后才可以在中國市場使用。
- 銀行支持
- 想要使用Apple Pay,對應的銀行還要加入Apple Pay才行。
- 設備支持
-
1.3 應用場景?
-
1.4 與微信支付以及支付寶等第三方支付平台的區別?
- 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)硬件方面
2、線上支付集成步驟
-
2.1 配置支付環境
- 配置Merchant ID(商業ID)
- 配置Xcode 項目
-
2.2 代碼實現
- 框架導入
- 判斷當前設備是否可以支付
- 判斷"Wallet有沒有添加該支付網絡的儲蓄卡/信用卡"
- 創建一個支付請求, 並配置各項信息
- 彈出授權控制器,讓用戶給支付授權
- 處理支付憑證
-
2.3 服務器處理
3、線上支付集成具體實現過程
-
3.1 配置支付環境
- 配置Merchant ID(商業ID)
- 需要以merchant開頭的一個字符串
- 僅在中國使用
- 申請App ID,這里和Merchant ID填寫一樣的名字為了辨別
- 申請好后在權限對應的App ID里面打開ApplePay功能,並配置merchant證書
- 選擇Edit進行相應配置, 配置成功后你會看到
- 配置APP ID和Merchant ID關聯成功
- 需要以merchant開頭的一個字符串
- 配置Xcode 項目
- 調整系統最低部署版本(iOS8.0)
- 使用XCode創建一個工程, 並設置好對應的BundleID
- bundleID設置,對應手動生成的bundleID
- 開啟Apple Pay功能:Bundle Id設置 Capability中啟用Apple Pay權限,並選擇merchantID.
- bundleID設置,對應手動生成的bundleID
- 下載證書安裝到鑰匙串
- 檢查安裝到鑰匙串中的證書是否有效
- 調整系統最低部署版本(iOS8.0)
- 配置Merchant ID(商業ID)
-
3.2 代碼實現
- 1) 框架導入
// 用戶綁定的銀行卡信息 #import <PassKit/PassKit.h> // Apple pay的展示控件 #import <PassKit/PKPaymentAuthorizationViewController.h> // 用戶聯系信息相關 #import <AddressBook/AddressBook.h>
- 2)判斷當前設備是否可以支付
if(![PKPaymentAuthorizationViewController canMakePayments]) { NSLog(@"不能支付"); return; }
- 3) 判斷"Wallet有沒有添加該支付網絡的儲蓄卡/信用卡"
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; }
- 4) 創建一個支付請求, 並配置各項信息
// 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];
- 5) 彈出授權控制器,讓用戶給支付授權
// 3. 開始支付 PKPaymentAuthorizationViewController *paymentPane = [[PKPaymentAuthorizationViewController alloc] initWithPaymentRequest:request]; if (paymentPane == nil) { NSLog(@"授權控制器創建失敗"); return; } paymentPane.delegate = self; [self presentViewController:paymentPane animated:YES completion:nil];
- 6) 處理支付憑證
/** * 當授權成功之后會調用這個代理方法 */ - (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); } }
- 7)關閉授權控制器
/** * 當授權成功之后或者取消授權之后會調用這個代理方法 */ - (void)paymentAuthorizationViewControllerDidFinish:(PKPaymentAuthorizationViewController *)controller { NSLog(@"取消或者交易完成"); [self dismissViewControllerAnimated:YES completion:nil]; }
- 8) 支付授權的流程:
- 框架發送支付請求給安全模塊,只有安全模塊可以訪問存儲在設備上的標記化的卡信息。
- 安全模塊把特定的卡和商家等支付數據加密,以保證只有蘋果可以讀取,然后發送給框架。框架會將這些數據發送給蘋果。
- 蘋果服務器再次加密這些支付數據,以保證只有商家可以讀取。然后服務器對它進行簽名,生成支付token,然后發送給設備。
- 框架調用相應的代理方法並傳入這個token,然后你的代理方法傳送token給你的服務器。
-
3.3 服務器處理
- 驗證支付數據的哈希表和簽名
- 為加密過的支付數據解碼
- 向支付處理系統提交支付數據
- 向訂單追蹤系統提交訂單
-
處理支付請求時,你有兩個選擇;你既可以利用支付平台處理支付請求,也可以自己實現支付請求處理流程。一個常用的支付平台可以完成上述大部分操作。