iOS:APP 支付-微信支付、支付寶支付

當前主流 APP 內(nèi)購支付方式為微信支付、支付寶支付,結(jié)合項目對兩類支付做簡單總結(jié)。

一、微信支付流程

微信支付(官方):
簽名算法:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=4_3
APP 開發(fā)步驟:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=8_5
API 列表:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=9_1#

微信支付流程圖

1.引入支付 SDK,完成相關配置

APP 開發(fā)步驟:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=8_5
資源中心:https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1419319164&lang=zh_CN

2.APP 內(nèi)購支付流程

2.1 APP 商品下單

商品下單需先調(diào)用后端接口

  • 1.驗證用戶 token 接口
  • 2.請求后端接口,返回微信 prepayid

2.2 調(diào)起支付

  • 1.制作簽名(也可以服務器端制作簽名)
    微信需要二次簽名
  • 2.調(diào)起支付接口
-(void)signWXPay:(NSString *)prepayid{
    payRequsestHandler *req = [[payRequsestHandler alloc] init];
    [req init:APP_ID mch_id:MCH_ID];
    //設置密鑰
    [req setKey:PARTNER_ID];
    
    NSMutableDictionary *signParams = [NSMutableDictionary dictionary];
    [signParams setObject: APP_ID        forKey:@"appid"];
    
    NSString  *time_stamp, *nonce_str;
    time_t now;
    time(&now);
    time_stamp  = [NSString stringWithFormat:@"%ld", now];
    nonce_str = [WXUtil md5:time_stamp];
    
    [signParams setObject: nonce_str   forKey:@"noncestr"];
    [signParams setObject: @"Sign=WXPay"      forKey:@"package"];
    [signParams setObject: MCH_ID        forKey:@"partnerid"];
    [signParams setObject: time_stamp   forKey:@"timestamp"];
    [signParams setObject: prepayid     forKey:@"prepayid"];

    //生成簽名
    NSString *sign  = [req createMd5Sign:signParams];
    
    //調(diào)起微信支付https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=9_12&index=2
    if (sign != nil) {
        PayReq* req1             = [[PayReq alloc] init];
        req1.openID              = APP_ID;
        req1.partnerId           = MCH_ID;
        req1.prepayId            = prepayid;
        req1.nonceStr            = nonce_str;
        req1.timeStamp           = time_stamp.intValue;
        req1.package             = @"Sign=WXPay";
        req1.sign                = sign;
        [WXApi sendReq:req1];
    }
}

2.3 處理回調(diào)

-(void)onResp:(BaseResp *)resp
{
#pragma mark 微信分享返回resp是SendMessageToWXResp類型
    if ([resp isKindOfClass:[SendAuthResp class]]) {
        SendAuthResp *aresp = (SendAuthResp *)resp;
        if (aresp.errCode == 0)
        {
        }else if (aresp.errCode == -4){
            //   [self messageShow:@"用戶拒絕"];
        }else if (aresp.errCode == -2){
            //  [self messageShow:@"用戶取消"];
        }
    }

    if([resp isKindOfClass:[PayResp class]]){
        //支付返回結(jié)果,實際支付結(jié)果需要去微信服務器端查詢
        switch (resp.errCode) {
            case WXSuccess:
            {
            #支付成功-相關處理代碼
            }
                break;
            default:
                if (resp.errCode == -4){
                    //[self messageShow:@"用戶拒絕"];
                }else if (resp.errCode == -2){
                    // [self messageShow:@"用戶取消"];
                }
                #支付失敗-相關處理代碼
                break;
        }
    }
}

二、支付寶支付

支付寶支付(官方):
APP 支付介紹:https://docs.open.alipay.com/204
iOS 集成流程:https://docs.open.alipay.com/204/105295/
參數(shù)說明:https://docs.open.alipay.com/204/105465/
簽名專區(qū):https://docs.open.alipay.com/291/
API 列表:https://docs.open.alipay.com/api/

支付處理體系

接入流程

1.引入支付 SDK,完成相關配置

APP 開發(fā)步驟:https://docs.open.alipay.com/204/105295/
資源中心:https://docs.open.alipay.com/54/104509/

2.APP 內(nèi)購支付流程

2.1 APP 商品下單

商品下單需先調(diào)用后端接口

1.驗證用戶 token 接口
2.請求后端接口,返回支付寶簽名(也可以 APP 做簽名)
簽名專區(qū):https://docs.open.alipay.com/291/

簽名返回示例:
請求參數(shù)說明:https://docs.open.alipay.com/204/105465/

charset=utf-8
&biz_content=%7B%2timeout_express%2%2230m%22%2Cproduct_code%22%3AQUICK_MSECURITY_PAY%2C%22total_amount%8A%A1%E8%B4%B5%E5%AE%BE%E5body%22%3A%22%E9%99%E8%85%BE%E4%B8%93%E4%BA%AB%22%2C%22out_trade_no%22%3A%22Z******%22%2C%22passback_params%22%3A%222
&method=alipay.****.app.pay
&notify_url=http%3A%2F%2Fletapi.*******.net%2FretrunPay%2Fali
&app_id=201****890181
&sign_type=RSA2
&version=1.0
&timestamp=****+11%3A52%3A18
&sign=ShkofgVliErCyPGXdmW%2BOcdjQPBSILSigZzLhy3jzj6dQZcQEqsOMvsSMmOQ0lWK3YzlrcnWMQmY71%2Fo3Es8icbNtkRaQAx8%2FjwANDzf50x0bD5AEFcGFDX4icaSKs%2BGk5VGhYbiZP6VeW8cYaWE8Gyg3A9fGbufN1yWA8uB5SrQaBo9EeieI%2Bj%2BqPY4CVtoP9acOvr2HPrR2DKmqLNO%2FSjmWPiVqxkg%3D%3D****;
2.2 調(diào)起支付

返回參數(shù)說明:https://docs.open.alipay.com/204/105301/

-(void)Alipay:(NSString *)orderString{
    [[AlipaySDK defaultService] payOrder:orderString fromScheme:@"alisdk****" callback:^(NSDictionary *resultDic) {
        NSLog(@"==注意這里是支付寶返回結(jié)果=====%@",resultDic);
        NSNumber *restNum = [resultDic objectForKey:@"resultStatus"];
        if ([restNum integerValue] == 9000) {
            [[NSNotificationCenter defaultCenter] postNotificationName:@"paySuccess" object:nil];
        } else{
            [[NSNotificationCenter defaultCenter] postNotificationName:@"payFailure" object:nil];
        }
    }];
}
resultStatus 結(jié)果碼
2.3支付回調(diào)
#pragma mark - 支付寶支付回調(diào)
-(void)aliPay:(NSURL *)url{
    [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
        NSNumber *restNum = [resultDic objectForKey:@"resultStatus"];
        if ([restNum integerValue] == 9000) {
            //支付成功處理代碼
        }else{
            //支付失敗處理代碼
        }
    }];
}

其他

如果項目還引入了友盟分享的話還需要在代理方法里設置。

- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{
    NSLog(@"%@", url.host);
    if ([url.host isEqualToString:@"safepay"]){//支付寶支付
        [self aliPay:url];
    }else if ([url.host isEqualToString:@"pay"]) {//微信支付
        return [WXApi handleOpenURL:url delegate:self];
    }else{
        //6.3的新的API調(diào)用,是為了兼容國外平臺(例如:新版facebookSDK,VK等)的調(diào)用[如果用6.2的api調(diào)用會沒有回調(diào)],對國內(nèi)平臺沒有影響
        BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url sourceApplication:sourceApplication annotation:annotation];
        if (!result) {
            // 其他如支付等SDK的回調(diào)
        }
        return result;
    }
    return YES;
}
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 支付流程官方文檔:https://docs.open.alipay.com/204/105297/ 官方文檔提供的...
    追沐閱讀 1,840評論 0 4
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,147評論 25 708
  • 去年的雪 靜靜地 慢慢地 飄落在昏黃而柔和的 路燈燈光里 有些調(diào)皮的 支棱在我 毛茸茸的黑色的袖口上 像碎裂的鏡屑...
    代小魚兒閱讀 320評論 0 0
  • CountDownLatch中count down是倒數(shù)的意思,latch則是門閂的含義。整體含義可以理解為倒數(shù)的...
    charming_coder閱讀 97,503評論 24 86

友情鏈接更多精彩內(nèi)容