iOS應用之 "Ping++" 支付集成

歷經這么長時間,終于安下心來記錄一下項目中Ping++支付的相關環(huán)節(jié)和內容,不得不說Ping++確實是一款很不錯的三方支付平臺,更重要的是方便快捷,簡書App同樣也運用了此三方平臺。因為 Ping++官方給的接入指南 已經很詳盡,所以這里就簡單小結一下支付環(huán)節(jié),附上項目中的部分代碼。

1.導入SDK并添加相關設置

  • 當前項目中用的CocoaPods依賴管理工具來管理所需的第三方開源庫(這樣可以節(jié)省設置和更新第三方開源庫的時間),導入 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];
                      // 這個方法在模擬器上運行支付時會走,真機測試時,這個方法不會觸發(fā),沒有真機時,進行頁面跳轉調的方法
                      //[_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++把支付訂單的環(huán)節(jié)都放在服務器,所以客戶端做的處理就少了許多,而且安全性更高(官方Demo用Swift寫的),贊。
  • 用微信支付的時候,要用真機進行測試,且安裝的有微信客戶端
  • iOS9限制http協議的訪問,需要在info.plist文件中添加訪問權限,而且還要添加應用白名單,如下圖:


    添加網絡訪問權限及白名單
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容