ios第三方支付

支付寶

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

微信

  • 導入SDK
    cocoapods 手動托都可以 不詳細說
  • 設置相關配置


    WeChat1.png
    WeChat2.png

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

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    
    self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
    self.window.backgroundColor = [UIColor whiteColor];
    //注冊
    [WXApi registerApp:@"獲取到的appkey" withDescription:@"隨意寫"];
    return YES;
}
  • 調用支付
    在需要調用支付的界面包含頭文件 #import "WXApi.h"
#pragma mark --- 微信
- (void)payWithWeChat:(NSDictionary *)para{
    //字典是是后臺返回給你的數據  對應的鍵值對可能不一樣,根據實際情況來寫
    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];
    }
    //需要創建這個支付對象
    PayReq *req   = [[PayReq alloc] init];
    //由用戶微信號和AppID組成的唯一標識,用于校驗微信用戶
    req.openID = appid;
    // 商家id,在注冊的時候給的
    req.partnerId = partnerId;
    // 預支付訂單這個是后臺跟微信服務器交互后,微信服務器傳給你們服務器的,你們服務器再傳給你
    req.prepayId  = prepayid;
    // 根據財付通文檔填寫的數據和簽名
    //這個比較特殊,是固定的,只能是即req.package = Sign=WXPay
    req.package = package;
    // 隨機編碼,為了防止重復的,在后臺生成
    req.nonceStr  = nonceStr;
    // 這個是時間戳,也是在后臺生成的,為了驗證支付的
    req.timeStamp =timeStamp;
    // 這個簽名也是后臺做的
    req.sign = sign;
    //發送請求到微信,等待微信返回onResp
    [WXApi sendReq:req];
}
#pragma mark - sign加密(一般都是后臺加密)
-(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"];//隨機字符串
    [signParams setObject:package_key forKey:@"package"];//擴展字段  參數為 Sign=WXPay
    [signParams setObject:partnerid_key forKey:@"partnerid"];//商戶賬號
    [signParams setObject:prepayid_key forKey:@"prepayid"];//此處為統一下單接口返回的預支付訂單號
    [signParams setObject:[NSString stringWithFormat:@"%u",timestamp_key] forKey:@"timestamp"];//時間戳
    
    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];
}
  • 微信支付結果回調
    請參考開始支付寶結果回調,兩個方法中有寫到微信,接下來就只寫微信支付結果的處理,也是在appdelegate中實現
#pragma mark - 微信支付
//9.0前的方法,為了適配低版本 保留
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url{
    return [WXApi handleOpenURL:url delegate:self];
}


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

可以在獲取支付結果成功或失敗的時候發送通知,以便在支付的界面處理成功或失敗的操作

//支付寶發送支付結果通知
[[NSNotificationCenter defaultCenter] postNotificationName:@"AliPay" object:resultDic[@"resultStatus"]];
//在調用支付界面接受通知(viewDidLoad中實現)
[[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];
}
//微信發送支付結果通知
[[NSNotificationCenter defaultCenter] postNotificationName:@"WechatPay" object:[NSString stringWithFormat:@"%d", resp.errCode]];
//在調用支付界面接受通知(viewDidLoad中實現)
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(wechatPayResult:) name:@"WechatPay" object:nil];
#pragma mark - 微信回調
- (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];
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 本篇主要介紹接入App原生微信支付的具體步驟(簽名在服務端進行生成,客戶端主要就是吊起支付) 注冊相關信息 1,在...
    修煉一顆真心閱讀 725評論 0 1
  • 支付寶流程 微信支付 它跟馬云寶最大的區別在于 你的設備上沒有安裝支付寶的話會自動掉用網頁版支付,然而馬化騰的微信...
    iOS_Alex閱讀 1,752評論 0 9
  • 前言 其實支付很簡單,下載官方的SDK,根據里面的開發者文檔和Demo,配置支付,不會可以問客服。(畢竟掏錢了嘛)...
    煎餅果子鄭能量閱讀 1,769評論 0 6
  • iOS支付 iOS支付分為兩類,第三方支付和應用內支付(內購)。 第三方支付包括:支付寶支付、微信支付、銀聯支付、...
    請輸入賬號名閱讀 6,304評論 3 22
  • 打Boos 模式。(天天飛車) 天天飛車,
    臥龍1閱讀 176評論 0 0