先簡單介紹一下
1.首先呢來說一說Apple Pay 的使用前提
1)設備的支持(iPhone6以上版本)
iPhone設備 支持手機app內支付 店內支付
Apple Watch 支持店內支付
iPad 支持app內支付
2)系統的支持(iOS8.0+版本,最好升級到當前最新版本iOS9.2)(iOS9.2,Apple Pay 增加了對銀聯卡的支持,此時就意味着可以在國內使用了)
使用的時候 需要在wallet應用當中,輸入銀行卡信息(銀行支持)
2.應用場景呢
1)線下支付 (商家支持:要求必須有支持NFC的刷卡機)
2)線上支付
接下來要說的就是app開發集成步驟了
1.配置支付環境
1)使用XCode創建一個工程,並設置好對應的BundleID
//com.sn.ApplePay
2)註冊並配置一個商業標示符
登陸開發者中心
進入證書配置欄目
添加一個App ID (App Services開啓Apple Pay)
配置Merchant ID
爲Merchant ID 配置證書,並下載證書安裝到鑰匙串 (會有一個問題提示是否支持美國以外的地區使用,選擇yes no是不同的,按照提示做就可以)
檢查安裝到鑰匙串中的證書是否有效
綁定Merchant ID到App ID
3)配置XCode項目,開啓Apple Pay功能
系統版本調到最低iOS8.0
開啓Apple Pay功能
2.現在用一下代碼舉例實現一下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
#import <PassKit/PassKit.h>//支付框架 - ( void )appLePayDemo { //PKPaymentButton//自帶樣式按鈕 (Apple Pay) //判斷當前設備是否支持蘋果支付 if (![PKPaymentAuthorizationViewController canMakePayments]) { NSLog(@ "當前設備不支持Apply Pay" ); return ; } //判斷是否添加了銀行卡 /* extern NSString * const PKPaymentNetworkAmex NS_AVAILABLE(NA, 8_0); extern NSString * const PKPaymentNetworkChinaUnionPay NS_AVAILABLE(NA, 9_2); extern NSString * const PKPaymentNetworkDiscover NS_AVAILABLE(NA, 9_0); extern NSString * const PKPaymentNetworkInterac NS_AVAILABLE(NA, 9_2); extern NSString * const PKPaymentNetworkMasterCard NS_AVAILABLE(NA, 8_0); extern NSString * const PKPaymentNetworkPrivateLabel NS_AVAILABLE(NA, 9_0); extern NSString * const PKPaymentNetworkVisa NS_AVAILABLE(NA, 8_0); */ // 目前判斷 visa卡 銀聯卡 銀聯卡(iOS9.2) if (![PKPaymentAuthorizationViewController canMakePaymentsUsingNetworks:@[PKPaymentNetworkVisa,PKPaymentNetworkChinaUnionPay]]) { //創建一個按鈕用戶點擊跳轉添加銀行卡的界面 PKPaymentButton * button = [PKPaymentButton buttonWithType:PKPaymentButtonTypeSetUp style:PKPaymentButtonStyleWhiteOutline]; //添加到界面上 //添加點擊事件 [button addTarget:self action:@selector(jump) forControlEvents:UIControlEventTouchUpInside]; } //創建一個購買按鈕 PKPaymentButton * button = [PKPaymentButton buttonWithType:PKPaymentButtonTypeBuy style:PKPaymentButtonStyleBlack]; //添加到界面上 //添加點擊事件 [button addTarget:self action:@selector(buy) forControlEvents:UIControlEventTouchUpInside]; } //跳轉到添加銀行卡界面 - ( void )jump { PKPassLibrary * pl = [[PKPassLibrary alloc] init]; [pl openPaymentSetup]; } //購買商品 - ( void )buy { //創建一個支付請求 PKPaymentRequest * request = [[PKPaymentRequest alloc] init]; //配置支付請求 //配置商家ID request.merchantIdentifier = @ "Merchant ID" ; //商家ID //配置貨幣代碼 以及國家代碼 (中國的) request.currencyCode = @ "CNY" ; request.countryCode = @ "CN" ; //配置請求支持的支付網絡//與上面判斷最好一致 request.supportedNetworks = @[PKPaymentNetworkVisa,PKPaymentNetworkChinaUnionPay]; //配置商戶處理方式 /* PKMerchantCapability3DS = 1UL << 0, // Merchant supports 3DS PKMerchantCapabilityEMV = 1UL << 1, // Merchant supports EMV PKMerchantCapabilityCredit NS_ENUM_AVAILABLE_IOS(9_0) = 1UL << 2, // Merchant supports credit PKMerchantCapabilityDebit NS_ENUM_AVAILABLE_IOS(9_0) = 1UL << 3 // Merchant supports PKMerchantCapability3DS | PKMerchantCapabilityEMV... */ request.merchantCapabilities = PKMerchantCapability3DS; //配置購買的商品列表 /* + (instancetype)summaryItemWithLabel:(NSString *)label amount:(NSDecimalNumber *)amount; + (instancetype)summaryItemWithLabel:(NSString *)label amount:(NSDecimalNumber *)amount type:(PKPaymentSummaryItemType)type NS_AVAILABLE(NA, 9_0); PKPaymentSummaryItemTypeFinal, // The payment summary item's amount is known to be correct 確定的 PKPaymentSummaryItemTypePending // The payment summary item's amount is estimated or unknown - e.g, a taxi fare 不確定的 */ //注意: 支付列表最後一個代表彙總 NSDecimalNumber * price1 = [NSDecimalNumber decimalNumberWithString:@ "10.00" ]; PKPaymentSummaryItem * item1 = [PKPaymentSummaryItem summaryItemWithLabel:@ "商品名稱" amount:price1]; NSDecimalNumber * price2 = [NSDecimalNumber decimalNumberWithString:@ "10.00" ]; PKPaymentSummaryItem * item2 = [PKPaymentSummaryItem summaryItemWithLabel:@ "商品名稱" amount:price2]; //彙總以上兩個商品 NSDecimalNumber * price3 = [NSDecimalNumber decimalNumberWithString:@ "20.00" ]; PKPaymentSummaryItem * item3 = [PKPaymentSummaryItem summaryItemWithLabel:@ "某某公司或者商城" amount:price3]; request.paymentSummaryItems = @[item1,item2,item3]; //配置請求的附加項 /* PKAddressFieldNone PKAddressFieldPostalAddress PKAddressFieldPhone PKAddressFieldEmail PKAddressFieldName PKAddressFieldAll */ //是否顯示 invoice 收貨地址 顯示哪些選項 request.requiredBillingAddressFields = PKAddressFieldAll; //是否顯示快遞地址 顯示哪些選項 request.requiredShippingAddressFields = PKAddressFieldAll; //配置快遞方式 NSArray <PKShippingMethod> NSDecimalNumber * p1 = [NSDecimalNumber decimalNumberWithString:@ "18.00" ]; PKShippingMethod * method1 = [PKShippingMethod summaryItemWithLabel:@ "順風快遞" amount:p1]; method1.identifier = @ "shunfeng" ; //詳細描述 method1.detail = @ "24小時送到" ; NSDecimalNumber * p2 = [NSDecimalNumber decimalNumberWithString:@ "10.00" ]; PKShippingMethod * method2 = [PKShippingMethod summaryItemWithLabel:@ "申通快遞" amount:p2]; method2.identifier = @ "shentong" ; method2.detail = @ "送貨上門" ; request.shippingMethods = @[method1,method2]; //配置快遞的類型 自取 等 /* PKShippingTypeShipping, PKShippingTypeDelivery, PKShippingTypeStorePickup, PKShippingTypeServicePickup */ request.shippingType = PKShippingTypeStorePickup; //添加一些附加的數據 request.applicationData = [@ "buyID=12345" dataUsingEncoding:NSUTF8StringEncoding]; //驗證用戶的支付授權 PKPaymentAuthorizationViewController * avc = [[PKPaymentAuthorizationViewController alloc] initWithPaymentRequest:request]; [self presentViewController:avc animated:YES completion:nil]; } |