版權(quán)聲明:本文為作者原創(chuàng)文章组橄, 如果有相同的或者相似的衣吠,那將是我的榮幸。
Apple Pay是什么小压?
Apple Pay目前在國(guó)內(nèi)上線(xiàn)已有一段時(shí)間,這意味著消費(fèi)者可通過(guò) 蘋(píng)果手機(jī)椰于、蘋(píng)果手表
等智能設(shè)備來(lái)進(jìn)行支付怠益,它的功能類(lèi)似一個(gè)“卡包”,講實(shí)體銀行卡虛擬到手機(jī)里瘾婿,用戶(hù)可以綁定儲(chǔ)蓄卡或信用卡
實(shí)現(xiàn)刷卡支付蜻牢。
為什么使用Apple Pay
從理論上看:微信支付也好、支付寶也好偏陪,均屬于“結(jié)算平臺(tái)”抢呆,他們會(huì)透過(guò)銀聯(lián),從你的銀行里提出現(xiàn)金代為托管笛谦;直至你把金錢(qián)放回銀行之前抱虐,都只能在微信/支付寶上使用。但 Apple Pay 只是一張電子信用卡饥脑,你的錢(qián)仍然在銀行里恳邀,付款時(shí)直接從銀聯(lián)向銀行提取。而從技上術(shù)上灶轰,微信支付也好谣沸、支付寶也好,在付款時(shí)都要透過(guò)相機(jī)或條碼機(jī)笋颤,讀取一次性的二維碼乳附;而 Apple Pay 則透過(guò)近場(chǎng)通信 (NFC) 的方式,讀取 iPhone 上的 Token 令牌伴澄。
從實(shí)際上看:目前微信支付及支付寶的優(yōu)勢(shì)在于低入場(chǎng)門(mén)檻:商店只要有臺(tái)智能手機(jī)赋除,就毋須為移動(dòng)支付購(gòu)入/租用新設(shè)備,而消費(fèi)者也不需要很高端的旗艦級(jí)設(shè)備秉版。而 Apple Pay 優(yōu)勢(shì)是良好的用戶(hù)體驗(yàn)贤重,使用 Apple Pay 付費(fèi),既安全清焕、又快捷并蝗、隱私度也比較高祭犯。
設(shè)備支持有哪些要求?
Apple Pay需要支持NFC
功能滚停,目前只限于iPhone 6s沃粗、iPhone 6s Plus、iPhone 6键畴、iPhone 6 Plus和Apple Watch這幾款設(shè)備使用最盅。同時(shí),用戶(hù)需講手機(jī)操作系統(tǒng)版本升級(jí)到iOS 9.2
以上起惕,Apple Watch則需要Watch OS 2.1
版本以上涡贱。
Apple Pay如何使用?
在iPhone
上惹想,先打開(kāi)系統(tǒng)自帶的Wallet
應(yīng)用问词,后點(diǎn)右上角的?
符號(hào),這時(shí)你有兩個(gè)選擇嘀粱,可以用攝像頭拍卡就能識(shí)別激挪,也可以手動(dòng)輸入,或者通過(guò)iTunes綁定锋叨,至于Apple Watch
怎么使用垄分,應(yīng)該操作差不多,具體情況本人未去實(shí)踐娃磺,還望諒解薄湿。
Apple Pay環(huán)境配置
-
配置Bundle ID
-
添加商戶(hù)的ID
-
把工程中對(duì)應(yīng)的Bundle ID添加進(jìn)去
-
點(diǎn)擊創(chuàng)建好的商戶(hù)ID
-
編輯商戶(hù)ID
-
添加CSR文件
-
下載配置好的商戶(hù)ID
-
創(chuàng)建對(duì)應(yīng)的App IDs
-
勾選Apple Pay
-
配置支付環(huán)境
-
Clean一下工程,如果工程自動(dòng)添加此文件則以上步驟正確
App項(xiàng)目?jī)?nèi)部集成方式
Apple Pay使用了PassKit框架偷卧,所以需要導(dǎo)入相應(yīng)頭文件
#import <PassKit/PassKit.h>
接收Apple Pay處理信息的回調(diào)嘿般,需要遵守協(xié)議,實(shí)現(xiàn)相應(yīng)的代理方法
@interface ViewController ()<PKPaymentAuthorizationViewControllerDelegate>
@end
為了方便測(cè)試涯冠,觸發(fā)支付操作時(shí)間寫(xiě)在touchBegan:
方法中
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
// code...
}
具體代碼實(shí)現(xiàn)如下:
- 判斷設(shè)備是否支持Apple Pay快捷支付功能
if (![PKPaymentAuthorizationViewController canMakePayments]) {
// 提示用戶(hù)該設(shè)備不支持Apple Pay快捷支付功能
// code...
return;
}
- 判斷設(shè)備是否綁定過(guò)可支付的銀行卡
/**
* 若沒(méi)有可用銀行卡炉奴,則跳轉(zhuǎn)到設(shè)置銀行卡界面
* PKPaymentNetworkVisa Visa國(guó)際卡
* PKPaymentNetworkChinaUnionPay 中國(guó)銀聯(lián)
* PKPaymentNetworkDiscover Discover(美國(guó)流行的信用卡)
*/
if (![PKPaymentAuthorizationViewController canMakePaymentsUsingNetworks:@[PKPaymentNetworkVisa, PKPaymentNetworkChinaUnionPay, PKPaymentNetworkDiscover]]) {
// 進(jìn)入設(shè)置銀行卡界面
[[[PKPassLibrary alloc] init] openPaymentSetup];
}
- 設(shè)置商品參數(shù)
// 創(chuàng)建商品
NSDecimalNumber *firstAmount = [NSDecimalNumber decimalNumberWithString:@"1.11"];
NSDecimalNumber *secondAmount = [NSDecimalNumber decimalNumberWithString:@"2.22"];
NSDecimalNumber *thirdAmount = [NSDecimalNumber decimalNumberWithString:@"3.33"];
NSDecimalNumber *amountSum = [NSDecimalNumber zero];
amountSum = [amountSum decimalNumberByAdding:firstAmount];
amountSum = [amountSum decimalNumberByAdding:secondAmount];
amountSum = [amountSum decimalNumberByAdding:thirdAmount];
/**
* @param label 商品名稱(chēng)(英文名稱(chēng)默認(rèn)全部顯示大寫(xiě))
* @param amount 商品價(jià)格 - NSDecimalNumber類(lèi)型
*/
PKPaymentSummaryItem *firstItem = [PKPaymentSummaryItem summaryItemWithLabel:@"FirstItem" amount:firstAmount];
PKPaymentSummaryItem *secondItem = [PKPaymentSummaryItem summaryItemWithLabel:@"SecondItem" amount:secondAmount];
PKPaymentSummaryItem *thirdItem = [PKPaymentSummaryItem summaryItemWithLabel:@"ThirdtItem" amount:thirdAmount];
PKPaymentSummaryItem *itemsSum = [PKPaymentSummaryItem summaryItemWithLabel:@"PJChao" amount:amountSum];
- 創(chuàng)建支付請(qǐng)求(基本配置)
PKPaymentRequest *request = [[PKPaymentRequest alloc] init];
// 設(shè)置商戶(hù)ID(merchant IDs)
request.merchantIdentifier = @"merchant.com.zpj.ApplePayTest";
// 設(shè)置國(guó)家代碼(中國(guó)大陸)
request.countryCode = @"CN";
// 設(shè)置支付貨幣(人民幣)
request.currencyCode = @"CNY";
// 設(shè)置商戶(hù)的支付標(biāo)準(zhǔn)(3DS支付方式必須支持,其他方式可選)
request.merchantCapabilities = PKMerchantCapability3DS;
request.paymentSummaryItems = @[firstItem, secondItem, thirdItem, itemsSum];
/**
* 以上參數(shù)都是必須的
* 以下參數(shù)不是必須的
*/
// 設(shè)置收據(jù)內(nèi)容
request.requiredBillingAddressFields = PKAddressFieldAll;
// 設(shè)置送貨內(nèi)容
request.requiredShippingAddressFields = PKAddressFieldAll;
// 設(shè)置送貨方式
PKShippingMethod *method = [PKShippingMethod summaryItemWithLabel:@"阿敏" amount:[NSDecimalNumber decimalNumberWithString:@"10.00"]];
method.identifier = @"阿敏物流";
method.detail = @"12小時(shí)到達(dá)";
request.shippingMethods = @[method];
- 顯示支付界面
PKPaymentAuthorizationViewController *paymentVC = [[PKPaymentAuthorizationViewController alloc] initWithPaymentRequest:request];
paymentVC.delegate = self;
if (paymentVC == nil) return;
[self presentViewController:paymentVC animated:YES completion:nil];
- 代理方法的實(shí)現(xiàn)
#pragma mark - <PKPaymentAuthorizationViewControllerDelegate>
- (void)paymentAuthorizationViewController:(PKPaymentAuthorizationViewController *)controller
didAuthorizePayment:(PKPayment *)payment
completion:(void (^)(PKPaymentAuthorizationStatus status))completion
{
/**
* 在這里支付信息應(yīng)發(fā)送給服務(wù)器/第三方的SDK(銀聯(lián)SDK/易寶支付SDK/易智付SDK等)
* 再根據(jù)服務(wù)器返回的支付成功與否進(jìn)行不同處理
* 這里直接返回支付成功
*/
completion(PKPaymentAuthorizationStatusSuccess);
}
- (void)paymentAuthorizationViewControllerDidFinish:(PKPaymentAuthorizationViewController *)controller
{
// 點(diǎn)擊支付/取消按鈕隱藏界面
[controller dismissViewControllerAnimated:YES completion:nil];
}
附上測(cè)試結(jié)果
終于寫(xiě)完了蛇更,如果有什么問(wèn)題瞻赶,還望大神給予指點(diǎn),Thank you派任。