美文网首页编程iOS开发之笔记摘录
Ping++/支付宝/微信/银联三方支付---iOS笔记摘录

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

作者: 平安喜乐698 | 来源:发表于2017-08-24 13:13 被阅读5241次
    目录
        1. Ping++支付
        2. 微信/支付宝/银联
    
    方式一:Ping++支付
     Ping++ 简化前台代码,快速集成支付宝,微信,银联等三方支付
    

    0.前期配置

    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

        <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公钥密钥: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
      导入系统依赖库如下图:
    
    导入系统依赖库

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

    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
    
    流程
    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)
        用户在移动应用中调起支付
    

    相关文章

      网友评论

        本文标题:Ping++/支付宝/微信/银联三方支付---iOS笔记摘录

        本文链接:https://www.haomeiwen.com/subject/hlosdxtx.html