搜索
您的当前位置:首页正文

Ping++/支付宝/微信/银联三方支付---iOS笔记摘录

来源:二三娱乐
目录
    1. Ping++支付
    2. 微信/支付宝/银联
方式一:Ping++支付
 Ping++ 简化前台代码,快速集成支付宝,微信,银联等三方支付

0.前期配置



1.验证企业信息
2.创建应用(APP_ID后台需要)|应用设置|支付渠道(点击填写渠道,有帮助文档)
   开通 移动(支付宝,微信,银联)PC(银联,支付宝)
支付宝及网页支付宝 相关设置【登录 

       版本选择(v1.0 mapi 和2.0 openapi):开发者中心 | 网页&移动平台 | 支付接入创建应用 | 添加功能(手机网站支付|App支付)(版本:功能右方有已生效则为v2.0:openapi,否则为v1.0:mapi)
       PID:右上方账号|账户信息|角色身份PID
       支付宝账号:登录账号(企业账号)
       MD5密钥:右上方账号|密钥管理|mapi网关(1.0版本时)|合作伙伴密钥|查看MD5密钥
        右上方账号|密钥管理|mapi网关(1.0版本时)|合作伙伴密钥|RSA(SHA1)中,复制支付宝公钥内容
       应用私钥:上述私钥
        // 渠道费率          0
        // 支付宝版本       
        // 免密             否
        // 合作伙伴PID       
        // 支付宝账号        
        // MD5密钥          
        // 支付宝公钥        
        // 应用私钥         
微信  相关设置


      注册应用(获取AppID和AppSercet)

      账户中心|支付申请 (获取商户ID号)
      
      账户中心|账户设置|基本账号|新增员工登陆账号
      账户中心|账户设置|API安全|下载证书(cert文件内容:API证书  key文件内容:API证书密钥)
        // 渠道费率         0
        // APPID         
        // AppSercet     
        // 微信支付商户号   
        // API密钥        
        // 员工登陆账号     
        // API证书         
        // API证书密钥      
   银联  相关设置

        
        
        安全证书密码:上述密码
        // 渠道费率     0
        // 商户号       
        // 安全证书     
        // 安全证书密码  
注意 
    Ping++ 一定要设置webhooks:填写支付成功/失败,退款后的回调地址。否则后台无法得知是否支付成功。
  1. 配置

cocoaPods

   pod 'Pingpp'        
   默认会包含支付宝、微信、银联  
   
可个性选择 pod 'Pingpp/Alipay' pod 'Pingpp/Wx'
            Alipay(支付宝移动支付)
            Wx(微信 App 支付)
            QQWallet(QQ钱包 App 支付)
            UnionPay(银联手机支付)
            ApplePay
            Fqlpay(分期乐)
            Qgbc(量化派)
            Mmdpay(么么贷)
            CmbWallet(招行一网通)
            BfbWap(百度钱包 Wap 支付)
            Yeepay(易宝支付 Wap 支付)
            Jdpay(京东支付 Wap 支付)
            One(壹收款)

URL Schemes

1.添加自定义Sceme
    // 用于支付宝返回本App/Ping++的kUrlScheme
   项目 | Info | URL Types 添加URL Schemes 

2.添加微信Scheme(不然跳不回应用)

白名单info.plist

    <key>LSApplicationQueriesSchemes</key>
    <array>
    <string>weixin</string>
    <string>wechat</string>
    <string>alipay</string>
    <string>alipays</string>
    <string>mqq</string>
    </array>
  1. AppDelegate
                // 调试模式(有打印日志)
                // [Pingpp setDebugMode:YES];
                // 是否在 WAP 渠道中支付完成后,点击“返回商户”按钮,直接关闭支付页面
                // [Pingpp ignoreResultUrl: YES];

// 从其他应用返回时调用
// iOS 9以前
- (BOOL)application:(UIApplication *)application
            openURL:(NSURL *)url
  sourceApplication:(NSString *)sourceApplication
         annotation:(id)annotation {
    
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url sourceApplication:sourceApplication annotation:annotation];
    if (!result) {
        // 其他如支付等SDK的回调
        BOOL canHandleURL = [Pingpp handleOpenURL:url withCompletion:nil];
        return canHandleURL;
    }
    return result;
}
// iOS 9 及以后
- (BOOL)application:(UIApplication *)app
            openURL:(NSURL *)url
            options:(NSDictionary *)options {
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
    if (!result) {
        BOOL canHandleURL = [Pingpp handleOpenURL:url withCompletion:nil];
        return canHandleURL;
    }
    return result;
    
}
// 
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url{
    //
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
    if (!result) {
        // 其他如支付等SDK的回调
        BOOL canHandleURL = [Pingpp handleOpenURL:url withCompletion:nil];
        return canHandleURL;
    }
    return result;
}
  1. 调起支付

将商品信息,支付方式发送到后台 获取charge
调起支付

#import "Pingpp.h"
    [AFNetWorkTool POST:url params:params success:^(NSURLSessionDataTask *task, id responseObject) {
        if (SUCCESS) {
            // 获取charge---字典
            NSString *charge=responseObject[@"data"];
            // kurlScheme (项目|info|urlScheme  填写scheme)
            [Pingpp createPayment:charge
                   viewController:self
                     appURLScheme:kUrlScheme
                   withCompletion:^(NSString *result, PingppError *error) {
                       if ([result isEqualToString:@"success"]) {
                           // 支付成功
                       } else {
                           [YTHUD showError:@"支付失败"];
                           NSLog(@"Error: code=%lu msg=%@", error.code, [error getMsg]);
                       }
                   }];
        }else{
            [YTHUD showError:@"支付失败,请重试"];
        }
    } fail:^(NSURLSessionDataTask *task, NSError *error) {
        [YTHUD showError:@"支付失败,请重试"];
        NSLog(@"%@",error);
    }];

其他

1.如果Xcode7编译失败,报如下错误:                  
    XXXXXXX does not contain bitcode. You must rebuild it with bitcode enabled (Xcode setting ENABLE_BITCODE), obtain an updated library from the vendor, or disable bitcode for this target.
                
解决: 项目 | build Settings | Enable Bitcode 设为false
方式二: 微信/支付宝/银联
  1. 账号
1.
注册支付宝企业账号(账户邮箱)| 填写账户信息(登录密码,支付密码,安全问题)
  | 企业实名认证(企业信息 ;营业执照,企业名称,企业名称,社会信用代码,单位所在地,住所,经营范围,营业期限,注册资本。;法定代表人:法定代表人归属地,法定代表人姓名,身份证号,证件有效期,填写人身份; 实际控制人:实际控制人归属地,实际控制人姓名,身份证号,证件有效期) ; 联系人手机号  
  | 证件照片 
  | 银行卡信息

2.1
蚂蚁金服支付宝开放平台 
  | 开发者中心 | 网页&移动平台 | 支付接入创建应用 | 添加功能(手机网站支付 | App支付)| 立即签约(添加相关信息) ->已生效 | 申请上线

2.2
 下载自动生成RSA公钥密钥工具
公钥设置到:开发者中心 |  网页&移动平台 | 查看应用 | 应用信息 | 接口加签方式 | RSA2设置应用公钥
私钥:代码中用
1. 微信开发平台(注册开发账号)
2. 创建应用,提交审核(几小时内)
3. 申请开通微信支付功能(几个工作日)

银联

  1. 开发配置
0.准备
  项目 | Info | URL Types 添加URL Schemes  本应用      用于返回本App
  白名单:。。。
  导入SDK中的AlipaySDK.bundle,AlipaySDK.framework
  导入系统依赖库如下图:
导入系统依赖库
0.准备
  创建微信应用

  导入微信SDK文件(如果集成了友盟,则不能再导入):
  导入系统依赖库(在支付宝基础上+)如下:
    libsqlite3.0.tbd

  项目 | Info | URL Types 添加URL Schemes  微信Scheme
  白名单:。。。
0.准备
导入SDK:paymentcontrol文件夹下的文件
导入系统依赖库:
  CFNetwork.framework、SystemConfiguration.framework 、libz、libPaymentControl.a

白名单:uppaysdk、uppaywallet、uppayx1、uppayx2、uppayx3
流程
  1. 代码

AppDelegate+YTPay.h

#import "AppDelegate.h"
// 微信
#import "WXApi.h"

@interface AppDelegate (YTPay)<WXApiDelegate>
// 支付
-(void)setupAliPayWX;
@end

AppDelegate+YTPay.m

#import "AppDelegate+YTPay.h"

#pragma mark 支付:aliPay wx(友盟集成了) yl
// 支付宝
#import <AlipaySDK/AlipaySDK.h>
// 银联(下载SDK)
#import "UPPaymentControl.h"

#pragma mark 友盟
#import <UShareUI/UShareUI.h>
#import <UMSocialCore/UMSocialCore.h>
#import <UMSocialCore/UMSocialManager.h>
#import "UMSocialQQHandler.h"
#import "UMSocialWechatHandler.h"
#import "UMSocialSinaHandler.h"

#define wxAppID @"weixinKey"

@implementation AppDelegate (YTPay)


// 支付
-(void)setupAliPayWX{
    // 添加友盟分享后,可不用再次注册
    [WXApi registerApp:wxAppID];
}

// ios8及以下
-(BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation{
    //
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url sourceApplication:sourceApplication annotation:annotation];
    if (!result) {
        if ([url.host isEqualToString:@"safepay"]) {
            [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
                NSLog(@"result = %@",resultDic);
            }];
            return YES;
        } else if([url.host isEqualToString:@"pay"]){
            return [WXApi handleOpenURL:url delegate:self];
        }else{
            [[UPPaymentControl defaultControl]handlePaymentResult:url completeBlock:^(NSString *code, NSDictionary *data) {
                //
                if([code isEqualToString:@"success"]) {
                    // success
                }else if([code isEqualToString:@"fail"]) {
                    // failed
                }else if([code isEqualToString:@"cancel"]) {
                    // cancel
                }
            }];
        }
    }
    return result;
}
// ios9及以上
-(BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options{
    //
    BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
    if (!result) {
        if ([url.host isEqualToString:@"safepay"]) {
            [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
                NSLog(@"result = %@",resultDic);
            }];
            return YES;
        } else if([url.host isEqualToString:@"pay"]){
            return [WXApi handleOpenURL:url delegate:self];
        }else{
            [[UPPaymentControl defaultControl]handlePaymentResult:url completeBlock:^(NSString *code, NSDictionary *data) {
                // sign —— 签名后做Base64的数据
                // data —— 用于签名的原始数据,结构如下:
                //  pay_result —— 支付结果success,fail,cancel
                //  tn          —— 订单号
                if([code isEqualToString:@"success"]) {
                    // success
                }else if([code isEqualToString:@"fail"]) {
                    // failed
                }else if([code isEqualToString:@"cancel"]) {
                    // cancel
                }
            }];
        }
    }
    return result;
}


#pragma mark WXApiDelegate
//
-(void)onReq:(BaseReq *)req{
}
// 支付一次(调用一次sendReq)后调用
-(void)onResp:(BaseResp *)resp{
    //
    switch (resp.errCode) {
        case WXSuccess:{
                // 以App服务器返回的信息为准
                NSLog(@"支付成功");
            }
            break;
        case WXErrCodeUserCancel:{
            NSLog(@"用户取消");
        }
            break;
        default:
            // 签名错误、未注册APPID、项目设置APPID不正确、注册的APPID与设置的不匹配、其他异常等
            NSLog(@"支付失败,retcode=%d",resp.errCode);
            break;
    }
}

@end

支付

// 支付宝/微信/银联
#import <AlipaySDK/AlipaySDK.h>
#import <WXApi.h>
#import "UPPaymentControl.h"

#pragma mark AliPay WXPay
-(void)aliPayWXPay{
    
将商品信息发给后台,后台加签,返回paramStr或paramDic


支付宝Alipay
    // 后台返回
    NSString *paramStr=@"";
    [[AlipaySDK defaultService] payOrder:paramStr fromScheme:@"appScheme,在Info|URL Type中设置" callback:^(NSDictionary *resultDic) {
        //
        NSNumber *number = resultDic[@"resultStatus"];
        if (number.integerValue == 9000) {
            // success
        } else if (number.integerValue == 6001) {
            // cancel
        } else {
            // failed
        }
    }];
    
微信WX
    // 该字典由后台返回
    NSDictionary *paramDic=[NSDictionary new];
    //
    PayReq *req = [[PayReq alloc] init];
    // 商户ID (注意参数名必须相同,否则无法跳转到微信)
    req.partnerId = paramDic[@"partnerid"];
    // 预支付订单ID(将商品信息传给后台后,后台调用预支付接口获得)
    req.prepayId = paramDic[@"prepayid"];
    // 唯一性随机字符串
    req.nonceStr = paramDic[@"noncestr"];
    // 时间戳
    req.timeStamp = (UInt32)[paramDic[@"timestamp"] integerValue];
    req.package = @"Sign=WXPay";
    // 签名
    req.sign = paramDic[@"sign"];
    // 调起支付,回调见onResp
    [WXApi sendReq:req];
    // 结果回调在AppDelegate中,使用通知发送结果


银联
    // 调起支付
    [[UPPaymentControl defaultControl]startPay:@"交易流水号--将商品信息传给后台,由后台获得" fromScheme:@"本应用Scheme" mode:@"测试" viewController:self];
    // 结果回调在AppDelegate中,使用通知发送结果
}
其他

支付模式

 刷卡支付(线下面对面)
    商家扫描 用户微信钱包内的“刷卡条码/二维码”
 扫码支付
    用户扫描 商家“二维码”
 公众号支付
    用户在微信的商户h5页面调起支付
 APP支付(网页支付,调起支付App)
    用户在移动应用中调起支付
Top