iOS支付之 Ping++、支付宝、微信、银联

目录
    1. Ping++支付
    2. 微信/支付宝/银联
方式一:Ping++支付
 Ping++ 简化前台代码,快速集成支付宝,微信,银联等三方支付
 不推荐使用,因为收费+不安全
  1. 前期配置
Ping++开发者平台(https://www.pingxx.com/?from=1&desc=ping++)

1.验证企业信息
2.创建应用(APP_ID后台需要)|应用设置|支付渠道(点击填写渠道,有帮助文档)
   开通 移动(支付宝,微信,银联)PC(银联,支付宝)
支付宝及网页支付宝 相关设置【登录 蚂蚁金服开放平台(https://open.alipay.com/platform/home.htm)】

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

登录微信开发平台(https://open.weixin.qq.com)
      注册应用(获取AppID和AppSercet)
登录微信商户平台(https://pay.weixin.qq.com/index.php)
      账户中心|支付申请 (获取商户ID号)
      账户中心|账户设置|API安全|设置API密钥(32位密钥生成器http://tool.c7sky.com/password/)|
      账户中心|账户设置|基本账号|新增员工登陆账号
      账户中心|账户设置|API安全|下载证书(cert文件内容:API证书  key文件内容:API证书密钥)
        // 渠道费率         0
        // APPID         
        // AppSercet     
        // 微信支付商户号   
        // API密钥        
        // 员工登陆账号     
        // API证书         
        // API证书密钥      
银联  相关设置

        商户号:登录银联(https://open.unionpay.com/)账号,申请后邮箱(商户号)
        安全证书:下载银联证书(https://cs.cfca.com.cn/cgi-bin/userCertDownload/v_input.do;jsessionid=F38E0FBDD0BF8B32CBA6EF5F91DDC106?displayAgreement=true填入序列号和授权码--邮箱)并导出(填写密码)上传银联,上传Ping++
        安全证书密码:上述密码
        // 渠道费率     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

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

// 从其他应用返回时调用
// 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;
}
// 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;
}
// 
- (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公钥密钥:https://docs.open.alipay.com/291/105971 下载自动生成RSA公钥密钥工具
公钥设置到:开发者中心 |  网页&移动平台 | 查看应用 | 应用信息 | 接口加签方式 | RSA2设置应用公钥
私钥:代码中用

微信
微信开发平台(注册开发账号)

1. 微信开发平台(注册开发账号)
2. 创建应用,提交审核(几小时内)
3. 申请开通微信支付功能(几个工作日)

银联

  1. 开发配置

支付宝
支付宝SDK下载地址

0.准备
  项目 | Info | URL Types 添加URL Schemes  本应用      用于返回本App
  白名单:。。。
  导入SDK中的AlipaySDK.bundle,AlipaySDK.framework
  导入系统依赖库如下图:
iOS支付之 Ping++、支付宝、微信、银联_第1张图片
导入系统依赖库

微信(没有网页版支付)
微信支付开发文档

0.准备
  创建微信应用

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

  项目 | Info | URL Types 添加URL Schemes  微信Scheme
  白名单:。。。

银联
SDK下载

0.准备
导入SDK:paymentcontrol文件夹下的文件
导入系统依赖库:
  CFNetwork.framework、SystemConfiguration.framework 、libz、libPaymentControl.a

白名单:uppaysdk、uppaywallet、uppayx1、uppayx2、uppayx3
iOS支付之 Ping++、支付宝、微信、银联_第2张图片
流程
  1. 代码

AppDelegate+YTPay.h

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

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

AppDelegate+YTPay.m

#import "AppDelegate+YTPay.h"

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

#pragma mark 友盟
#import 
#import 
#import 
#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 *)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 
#import 
#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)
    用户在移动应用中调起支付

内购

如果购买的是实物(商城类应用),就可以调用支付宝,微信啦,银联等三方支付。

如果购买的是虚拟物品(非实物,在本app中使用和消耗),就一定要用内购,否则会被拒绝上线。
    例如:游戏币,在线书籍,虚拟金币,虚拟道具
    内购要和苹果3/7分成。充值相同的钱,相对来说,iOS是比安卓吃亏的,但是用iOS毕竟土豪多。

网上有一篇专门介绍内购的,比较详细。
内购

你可能感兴趣的:(iOS支付之 Ping++、支付宝、微信、银联)