ios第三方支付

支付寶

  • 導(dǎo)入SDK
    cocoapods導(dǎo)入pod 'AliPay', 或者手動(dòng)拖都可以,不詳細(xì)說(shuō)。
  • 設(shè)置相關(guān)配置
Alipay1.png
Alipay2.png
  • 調(diào)用支付
    在需要調(diào)用的界面包含頭文件 #import <AlipaySDK/AlipaySDK.h>
[[AlipaySDK defaultService] payOrder:@"后臺(tái)返回給你的值" fromScheme:@"開(kāi)始設(shè)置的url schemes" callback:^(NSDictionary *resultDic) {
                        NSString *resultStatus = resultDic[@"resultStatus"];
                        if ([resultStatus integerValue] == 9000){
                            //網(wǎng)頁(yè)支付成功
                        }else{
                            //網(wǎng)頁(yè)支付失敗
                        }
                    }];
  • 客戶端支付結(jié)果回調(diào)
    AppDelegate.m中包含頭文件 #import <AlipaySDK/AlipaySDK.h>
- (BOOL)application:(UIApplication *)application
            openURL:(NSURL *)url
  sourceApplication:(NSString *)sourceApplication
         annotation:(id)annotation {
    
    if ([url.host isEqualToString:@"safepay"]) {
        //跳轉(zhuǎn)支付寶錢包進(jìn)行支付,處理支付結(jié)果
        [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
            if ([resultDic[@"resultStatus"] integerValue] == 9000){
                //成功
              }else {
                //失敗
              }
        }];
        return YES;
    }else{
       //這里判斷是否發(fā)起的請(qǐng)求為微信支付,如果是的話,用WXApi的方法調(diào)起微信客戶端的支付頁(yè)面(://pay 之前的那串字符串就是你的APPID,)
        return [WXApi handleOpenURL:url delegate:self];
    }
}

// NOTE: 9.0以后使用新API接口
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options
{
    if ([url.host isEqualToString:@"safepay"]) {
        //跳轉(zhuǎn)支付寶錢包進(jìn)行支付,處理支付結(jié)果
        [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
              if ([resultDic[@"resultStatus"] integerValue] == 9000){
                  //成功
                }else {
                  //失敗
                }
        }];
        return YES;
    }else{
        //這里判斷是否發(fā)起的請(qǐng)求為微信支付,如果是的話,用WXApi的方法調(diào)起微信客戶端的支付頁(yè)面(://pay 之前的那串字符串就是你的APPID,)
        return  [WXApi handleOpenURL:url delegate:self];
    }
}

微信

  • 導(dǎo)入SDK
    cocoapods 手動(dòng)托都可以 不詳細(xì)說(shuō)
  • 設(shè)置相關(guān)配置


    WeChat1.png
    WeChat2.png

    Appdelegate.m 中先注冊(cè) 包含頭文件#import "WXApi.h"

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    
    self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
    self.window.backgroundColor = [UIColor whiteColor];
    //注冊(cè)
    [WXApi registerApp:@"獲取到的appkey" withDescription:@"隨意寫"];
    return YES;
}
  • 調(diào)用支付
    在需要調(diào)用支付的界面包含頭文件 #import "WXApi.h"
#pragma mark --- 微信
- (void)payWithWeChat:(NSDictionary *)para{
    //字典是是后臺(tái)返回給你的數(shù)據(jù)  對(duì)應(yīng)的鍵值對(duì)可能不一樣,根據(jù)實(shí)際情況來(lái)寫
    NSString *appid = [NSString stringWithFormat:@"%@", para[@"ios"][@"appid"]];
    NSString *partnerId = [NSString stringWithFormat:@"%@", para[@"ios"][@"partnerid"]];
    NSString *prepayid = [NSString stringWithFormat:@"%@", para[@"ios"][@"prepayid"]];
    NSString *package = [NSString stringWithFormat:@"%@", para[@"ios"][@"package"]];
    NSString *nonceStr = [NSString stringWithFormat:@"%@", para[@"ios"][@"noncestr"]];
    NSString *sign = [NSString stringWithFormat:@"%@", para[@"ios"][@"sign"]];
    UInt32 timeStamp = 0;
    if (para[@"ios"][@"timestamp"]) {
        timeStamp = [para[@"ios"][@"timestamp"] unsignedIntValue];
    }
    //需要?jiǎng)?chuàng)建這個(gè)支付對(duì)象
    PayReq *req   = [[PayReq alloc] init];
    //由用戶微信號(hào)和AppID組成的唯一標(biāo)識(shí),用于校驗(yàn)微信用戶
    req.openID = appid;
    // 商家id,在注冊(cè)的時(shí)候給的
    req.partnerId = partnerId;
    // 預(yù)支付訂單這個(gè)是后臺(tái)跟微信服務(wù)器交互后,微信服務(wù)器傳給你們服務(wù)器的,你們服務(wù)器再傳給你
    req.prepayId  = prepayid;
    // 根據(jù)財(cái)付通文檔填寫的數(shù)據(jù)和簽名
    //這個(gè)比較特殊,是固定的,只能是即req.package = Sign=WXPay
    req.package = package;
    // 隨機(jī)編碼,為了防止重復(fù)的,在后臺(tái)生成
    req.nonceStr  = nonceStr;
    // 這個(gè)是時(shí)間戳,也是在后臺(tái)生成的,為了驗(yàn)證支付的
    req.timeStamp =timeStamp;
    // 這個(gè)簽名也是后臺(tái)做的
    req.sign = sign;
    //發(fā)送請(qǐng)求到微信,等待微信返回onResp
    [WXApi sendReq:req];
}
#pragma mark - sign加密(一般都是后臺(tái)加密)
-(NSString *)createMD5SingForPayWithAppID:(NSString *)appid_key partnerid:(NSString *)partnerid_key prepayid:(NSString *)prepayid_key package:(NSString *)package_key noncestr:(NSString *)noncestr_key timestamp:(UInt32)timestamp_key{
    NSMutableDictionary *signParams = [NSMutableDictionary dictionary];
    [signParams setObject:appid_key forKey:@"appid"];//微信appid 例如wxfb132134e5342
    [signParams setObject:noncestr_key forKey:@"noncestr"];//隨機(jī)字符串
    [signParams setObject:package_key forKey:@"package"];//擴(kuò)展字段  參數(shù)為 Sign=WXPay
    [signParams setObject:partnerid_key forKey:@"partnerid"];//商戶賬號(hào)
    [signParams setObject:prepayid_key forKey:@"prepayid"];//此處為統(tǒng)一下單接口返回的預(yù)支付訂單號(hào)
    [signParams setObject:[NSString stringWithFormat:@"%u",timestamp_key] forKey:@"timestamp"];//時(shí)間戳
    
    NSMutableString *contentString  =[NSMutableString string];
    NSArray *keys = [signParams allKeys];
    //按字母順序排序
    NSArray *sortedArray = [keys sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) {
        return [obj1 compare:obj2 options:NSNumericSearch];
    }];
    //拼接字符串
    for (NSString *categoryId in sortedArray) {
        if (   ![[signParams objectForKey:categoryId] isEqualToString:@""]
            && ![[signParams objectForKey:categoryId] isEqualToString:@"sign"]
            && ![[signParams objectForKey:categoryId] isEqualToString:@"key"]
            )
        {
            [contentString appendFormat:@"%@=%@&", categoryId, [signParams objectForKey:categoryId]];
        }
    }
    //添加商戶密鑰key字段  API 密鑰
    [contentString appendFormat:@"key=%@", @"商戶秘鑰"];
    NSString *result = [self md5String:contentString];//md5加密
    return result;
}
- (NSString *)md5String:(NSString *)string
{
    if(string == nil || [string length] == 0) return nil;
    unsigned char digest[CC_MD5_DIGEST_LENGTH], i;
    CC_MD5([string UTF8String], (int)[string lengthOfBytesUsingEncoding:NSUTF8StringEncoding], digest);
    NSMutableString *ms = [NSMutableString string];
    for(i=0;i<CC_MD5_DIGEST_LENGTH;i++)
    {
        [ms appendFormat: @"%02x", (int)(digest[i])];
    }
    return [ms copy];
}
  • 微信支付結(jié)果回調(diào)
    請(qǐng)參考開(kāi)始支付寶結(jié)果回調(diào),兩個(gè)方法中有寫到微信,接下來(lái)就只寫微信支付結(jié)果的處理,也是在appdelegate中實(shí)現(xiàn)
#pragma mark - 微信支付
//9.0前的方法,為了適配低版本 保留
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url{
    return [WXApi handleOpenURL:url delegate:self];
}


//微信SDK自帶的方法,處理從微信客戶端完成操作后返回程序之后的回調(diào)方法,顯示支付結(jié)果的
-(void) onResp:(BaseResp*)resp
{
    //啟動(dòng)微信支付的response
    NSString *payResoult = [NSString stringWithFormat:@"errcode:%d", resp.errCode];
    if([resp isKindOfClass:[PayResp class]]){
        //支付返回結(jié)果,實(shí)際支付結(jié)果需要去微信服務(wù)器端查詢
        switch (resp.errCode) {
            case 0:
                payResoult = @"支付結(jié)果:成功!";
                break;
            case -1:
                payResoult = @"支付結(jié)果:失敗!";
                break;
            case -2:
                payResoult = @"用戶已經(jīng)退出支付!";
                break;
            default:
                payResoult = [NSString stringWithFormat:@"支付結(jié)果:失??!retcode = %d, retstr = %@", resp.errCode,resp.errStr];
                break;
        }
    }
}

可以在獲取支付結(jié)果成功或失敗的時(shí)候發(fā)送通知,以便在支付的界面處理成功或失敗的操作

//支付寶發(fā)送支付結(jié)果通知
[[NSNotificationCenter defaultCenter] postNotificationName:@"AliPay" object:resultDic[@"resultStatus"]];
//在調(diào)用支付界面接受通知(viewDidLoad中實(shí)現(xiàn))
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(alipay:) name:@"AliPay" object:nil];
//支付寶客戶端支付成功通知
- (void)alipay:(NSNotification *)not{
    if ([not.object isEqualToString:@"9000"]) {
        //支付成功
    }else if ([not.object isEqualToString:@"6001"]){
        //用戶取消支付
    }else{
        //支付失敗
    }
    [[NSNotificationCenter defaultCenter] removeObserver:not];
}
//微信發(fā)送支付結(jié)果通知
[[NSNotificationCenter defaultCenter] postNotificationName:@"WechatPay" object:[NSString stringWithFormat:@"%d", resp.errCode]];
//在調(diào)用支付界面接受通知(viewDidLoad中實(shí)現(xiàn))
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(wechatPayResult:) name:@"WechatPay" object:nil];
#pragma mark - 微信回調(diào)
- (void)wechatPayResult:(NSNotification *)not{
    if ([not.object integerValue] == 0) {
        //支付成功
    }else if ([not.object integerValue] == -1){
        //支付失敗
    }else if ([not.object integerValue] == -2){
        //用戶退出支付
    }
    [[NSNotificationCenter defaultCenter] removeObserver:not];
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

  • 本篇主要介紹接入App原生微信支付的具體步驟(簽名在服務(wù)端進(jìn)行生成,客戶端主要就是吊起支付) 注冊(cè)相關(guān)信息 1,在...
    修煉一顆真心閱讀 910評(píng)論 0 1
  • 支付寶流程 微信支付 它跟馬云寶最大的區(qū)別在于 你的設(shè)備上沒(méi)有安裝支付寶的話會(huì)自動(dòng)掉用網(wǎng)頁(yè)版支付,然而馬化騰的微信...
    iOS_Alex閱讀 1,774評(píng)論 0 9
  • 前言 其實(shí)支付很簡(jiǎn)單,下載官方的SDK,根據(jù)里面的開(kāi)發(fā)者文檔和Demo,配置支付,不會(huì)可以問(wèn)客服。(畢竟掏錢了嘛)...
    煎餅果子鄭能量閱讀 1,829評(píng)論 0 6
  • iOS支付 iOS支付分為兩類,第三方支付和應(yīng)用內(nèi)支付(內(nèi)購(gòu))。 第三方支付包括:支付寶支付、微信支付、銀聯(lián)支付、...
    請(qǐng)輸入賬號(hào)名閱讀 6,472評(píng)論 3 22
  • 打Boos 模式。(天天飛車) 天天飛車,
    臥龍1閱讀 200評(píng)論 0 0

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