iOS不用官方SDK實現微信和支付寶支付XHPayKit

微信、支付寶支付

前言

前段時間因爲項目需求,移除了項目中的微信支付SDK和支付寶支付SDK,這種狀況下須要本身搞定支付,第一時間考慮到的是使用openshare,可是當下載openshare下來後發現,openshare的支付接口,並不能直接替換官方SDK支付接口,
官方SDK的實現邏輯是後臺訂單簽名完成後,客服端傳簽名信息及參數給支付SDK,支付SDK生成協議url,而後拉起第三方支付APP,
而openshare的支付接口是直接傳拉起支付的協議url地址,將生成協議url地址的操做也交給後臺來生成, 這樣的話後臺須要修改代碼,
可否不修改後臺代碼,弄一個支付接口直接替換官方SDK支付接口,實現無縫對接呢,因而就研究了下微信和支付寶支付時APP間通信關係,最後封裝成XHPayKit.git

特性:

1.XHPayKit擁有和官方SDK相似接口,能夠直接替換官方SDK支付接口,若是你使用過官方SDK,那麼轉換爲本庫你只需花費極短期.
2.XHPayKit只有10kb大小,不用導入任何依賴庫,即可實現微信支付、支付寶支付,若是你想爲項目瘦身或因爲某種緣由,不想使用官方SDK實現支付功能,此庫將是一個不錯的選擇.
3.XHPayKit使用時,不須要配置微信等平臺appid等信息,服務端配置就能夠了,由於後臺簽名訂單時會返回appid等信息給客戶端.github

注意:

1.先在微信、支付寶開放平臺註冊你的應用,並得到支付能力
2.導入此庫,並請將 weixin 、 alipay 字段添加到info.plist白名單
3.添加本身APP URL Schemes,和微信回調URL Schemes,詳見README文檔服務器

使用方法:

1.微信支付

//微信支付參數,下面7個參數,由後臺簽名訂單後生成,並返回給客服端(與官方SDK一致)
 //注意:請將下面參數設置爲你本身真實訂單簽名後服務器返回參數,即可進行實際支付
XHPayWxReq *req = [[XHPayWxReq alloc] init];
req.openID = @"";
req.partnerId = @"";
req.prepayId = @"";
req.nonceStr = @"";
req.timeStamp = 1518156229;
req.package = @"";
req.sign = @"";
        
//傳入訂單模型,拉起微信支付
[[XHPayKit defaultManager] wxpayOrder:req completed:^(NSDictionary *resultDict) {
          NSLog(@"支付結果:\n%@",resultDict);
          NSInteger code = [resultDict[@"errCode"] integerValue];
          if(code == 0){//支付成功
                
          }
}];

複製代碼

2.支付寶支付

//支付寶訂單簽名,此簽名由後臺簽名訂單後生成,並返回給客戶端(與官方SDK一致)
//注意:請將下面值設置爲你本身真實訂單簽名,即可進行實際支付
NSString *orderSign = @"很長的一串支付寶訂單簽名";
        
//傳入支付寶訂單簽名 和 本身App URL Scheme,拉起支付寶支付
[[XHPayKit defaultManager] alipayOrder:orderSign fromScheme:@"XHPayKitExample" completed:^(NSDictionary *resultDict) {
    NSLog(@"支付結果:\n%@",resultDict);
    NSInteger status = [resultDict[@"ResultStatus"] integerValue];
    if(status == 9000){//支付成功
                
    }
}];

複製代碼

3.在Appdelegate中添加如下代碼 - 處理第三方支付跳回商戶app攜帶的支付結果Url

#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_9_0
/** iOS9及之後 */
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options
{
    BOOL result = [[XHPayKit defaultManager] handleOpenURL:url];
    if (!result) {//這裏處理其餘SDK(例如QQ登陸,微博登陸等)
        
    }
    return result;
}
#endif
/** iOS9如下 */
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{
    BOOL result = [[XHPayKit defaultManager] handleOpenURL:url];
    if (!result) {//這裏處理其餘SDK(例如QQ登陸,微博登陸等)
        
    }
    return result;
}

複製代碼

其它接口:

/** 是否安裝微信 @return 已安裝YES,未安裝NO */
+(BOOL)isWxAppInstalled;

/** 是否安裝支付寶 @return 已安裝YES,未安裝NO */
+(BOOL)isAliAppInstalled;

複製代碼

支付結果resultDict釋義:

微信

{
    "errCode":0,
    "errStr":"成功"
}

//如下狀態碼含義與官方SDK一致
errCode = 0,成功
errCode = -1,普通錯誤類型
errCode = -2,用戶點擊取消並返回
errCode = -3,發送失敗
errCode = -4,受權失敗 
errCode = -5,微信不支持
複製代碼

支付寶

{
    "result":"",
    "resultStatus":"9000",
    "memo":"支付成功"
}

//如下狀態碼含義與官方SDK一致
resultStatus = 9000,支付成功
resultStatus = 8000,正在處理中,支付結果未知(有可能已經支付成功),請查詢商戶訂單列表中訂單的支付狀態
resultStatus = 4000,支付失敗
resultStatus = 5000,重複請求
resultStatus = 6001,用戶中途取消
resultStatus = 6002,網絡鏈接出錯
resultStatus = 6004,支付結果未知(有可能已經支付成功),請查詢商戶訂單列表中訂單的支付狀態

複製代碼

小結:

XHPayKit的實現很是簡單,感興趣的同窗能夠下載下來研究下支付時APP間通信.
代碼地址:github.com/CoderZhuXH/…微信

相關文章
相關標籤/搜索