歷經這么長時間,終于安下心來記錄一下項目中Ping++支付的相關環節和內容,不得不說Ping++確實是一款很不錯的三方支付平臺,更重要的是方便快捷,簡書App同樣也運用了此三方平臺。因為 Ping++官方給的接入指南 已經很詳盡,所以這里就簡單小結一下支付環節,附上項目中的部分代碼。
1.導入SDK并添加相關設置
- 當前項目中用的CocoaPods依賴管理工具來管理所需的第三方開源庫(這樣可以節省設置和更新第三方開源庫的時間),導入 pod 'Pingpp', '~> 2.1.0' (默認會包含支付寶、微信、銀聯和百度錢包)。
- 由于項目中需要用到微信支付所以要添加
URL Schemes:
,填入在微信平臺上注冊的應用程序的id(以wx開頭的字符串)。如下圖:
添加URL Types
2.接入開啟支付的代碼
-
導入頭文件
#import "Pingpp.h"
-
客戶端從服務器獲取
charge
對象/** * 確認支付訂單,往服務器傳遞訂單所需的參數,并返回charge對象 */ - (void)buyCarAddOrderDataWithCarid_count:(NSString *)carid_count { typeof(self) _weakSelf = self; NSString *userID = [[NSUserDefaults standardUserDefaults] objectForKey:@"user_id"]; NSString *URL = [NSString stringWithFormat:@"%@/App/Sylm/yclist",SERVERURL]; NSMutableDictionary *paramas = [NSMutableDictionary dictionary]; paramas[@"method"] = @"addorder"; paramas[@"buy_status"] = _buy_status; paramas[@"carid_count"] = carid_count; paramas[@"user_id"] = userID; paramas[@"ways"] = self.ways; //客戶端選擇的支付方式參數 paramas[@"addr_id"] = self.addressModel.address_id; [HXHttpTool post:URL params:paramas success:^(id json) { LXLog(@"%@", json); // 返回的json就是charge對象,直接拿來用,傳遞給調用喚起支付的方法 [_weakSelf wakeUpPingWithCharge:json]; } failure:^(NSError *error) { [SVProgressHUD showErrorWithStatus:@"調取支付失敗" maskType:SVProgressHUDMaskTypeGradient]; LXLog(@"%@", error); }]; }
另:附上接口對照參數(僅供參考):
接口參數
-
利用
charge
對象喚起相應支付,其中kURLScheme為本應用的URL Schemes,在支付成功之后,正常跳轉回應用。/** * 利用charge對象喚起支付 */ - (void)wakeUpPingWithCharge:(NSString *)charge { typeof(self) _weakSelf = self; [Pingpp createPayment:charge viewController:self appURLScheme:kURLScheme withCompletion:^(NSString *result, PingppError *error) { if ([result isEqualToString:@"success"]) { // 支付成功 [SVProgressHUD showSuccessWithStatus:@"支付成功" maskType:SVProgressHUDMaskTypeGradient]; // 這個方法在模擬器上運行支付時會走,真機測試時,這個方法不會觸發,沒有真機時,進行頁面跳轉調的方法 //[_weakSelf gotoSuccessVC]; } else { // 支付失敗或取消 LXLog(@"Error: code=%lu msg=%@", error.code, [error getMsg]); [SVProgressHUD showErrorWithStatus:@"取消支付" maskType:SVProgressHUDMaskTypeGradient]; } }]; }
配置 kURLScheme,如下圖:
應用Schemes
- 接收并處理支付結果,必須實現
在
AppDelegate.m
文件中實現支付結果回調的方法,這里只做ios9以上的了。
iOS 9 及以上
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString *,id> *)options {
[Pingpp handleOpenURL:url withCompletion:^(NSString *result, PingppError *error) {
LXLog(@"%@", result);
// 用通知實現支付成功的頁面跳轉
if ([result isEqualToString:@"success"]) {
[[NSNotificationCenter defaultCenter] postNotificationName:@"enterSuccessView" object:nil];
}
}];
return YES;
}
3.小結
- Ping++把支付訂單的環節都放在服務器,所以客戶端做的處理就少了許多,而且安全性更高(官方Demo用Swift寫的),贊。
- 用微信支付的時候,要用真機進行測試,且安裝的有微信客戶端
iOS9限制http協議的訪問,需要在info.plist文件中添加訪問權限,而且還要添加應用白名單,如下圖:
添加網絡訪問權限及白名單