美文网首页程序员JC专题第三方应用
29.支付宝支付改版了,你知道吗?

29.支付宝支付改版了,你知道吗?

作者: IIronMan | 来源:发表于2016-10-13 17:06 被阅读604次

    这里我讲的是关于最新的支付宝支付的流程

    • 1.有个支付宝账号并申请自己的app应用

      支付宝开放平台

    • 1.1.创建应用


    • 1.2.设置bundle Id (要和自己项目的保持一致)

    • 2.公钥私钥的生成

      2.1寻找生成器


    • 2.2.下载公钥和私钥生成器


    • 2.3打开下载好的生成器,双击


    • 2.4.公钥和私钥的生成

    • 2.5.公钥的使用
    • 3.支付宝SDK的使用
    • 3.1先下载一个支付宝的SDK(官方文档->APP支付->iOS集成流程详解)
    • 3.2下载SDK
    • 3.3选择iOS客户端
    • 3.4在项目里面导入下面的组合文件夹
    • 3.5.在pch文件里面导入

      #ifdef __OBJC__
      #import <UIKit/UIKit.h>
      #import <Foundation/Foundation.h>
      #endif
      
    • 3.6.在Build Phases选项卡的Link Binary With Libraries中,增加以下依赖:


    其中,需要注意的是:
    如果是Xcode 7.0之后的版本,需要添加libc++.tbd、libz.tbd
    如果是Xcode 7.0之前的版本,需要添加libc++.dylib、libz.dylib(如下图)。
    • 3.7.上面的步骤做完运行一下,会报错

    解决办法:配置路径:配置完再运行就没事了

    • 4.在需要使用支付的地方导入下面的头文件(也可写在pch文件里面)

      //订单框架
      #import "Order.h"
      //使用RSA加密框架
      #import "DataSigner.h"
      //支付报框架
      #import <AlipaySDK/AlipaySDK.h>
      
    • 5.在点击支付的方法里面调用下面的方法

    这两项用户需要自己填写
    应用的appID
    NSString *appID = @"";

    私钥(上面的步骤有生成)
    NSString *privateKey = @"";
    - (void)doAlipayPay
    {
    //重要说明
    //这里只是为了方便直接向商户展示支付宝的整个支付流程;所以Demo中加签过程直接放在客户端完成;
    //真实App里,privateKey等数据严禁放在客户端,加签过程务必要放在服务端完成;
    //防止商户私密数据泄露,造成不必要的资金损失,及面临各种安全风险;

    /*=======================需要填写商户app申请的===================================*/
    /*============================================================================*/
    NSString *appID = @"";
    NSString *privateKey = @"";
    /*============================================================================*/
    
    //partner和seller获取失败,提示
    if ([appID length] == 0 ||
        [privateKey length] == 0)
    {
        UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"提示"message:@"缺少appId或者私钥。"
                                                       delegate:self cancelButtonTitle:@"确定"
                                              otherButtonTitles:nil];
       
        [alert show];
        return;
    }
    
    /*
     *生成订单信息及签名
     */
    //将商品信息赋予AlixPayOrder的成员变量
    Order* order = [Order new];
    
    // NOTE: app_id设置
    order.app_id = appID;
    
    // NOTE: 支付接口名称
    order.method = @"alipay.trade.app.pay";
    
    // NOTE: 参数编码格式
    order.charset = @"utf-8";
    
    // NOTE: 当前时间点
    NSDateFormatter* formatter = [NSDateFormatter new];
    [formatter setDateFormat:@"yyyy-MM-dd HH:mm:ss"];
    order.timestamp = [formatter stringFromDate:[NSDate date]];
    
    // NOTE: 支付版本
    order.version = @"1.0";
    
    // NOTE: sign_type设置
    order.sign_type = @"RSA";
    
    // NOTE: 商品数据
    order.biz_content = [BizContent new];
    order.biz_content.body = @"我是测试数据";
    order.biz_content.subject = @"1";
    order.biz_content.out_trade_no = [self generateTradeNO]; //订单ID(由商家自行制定)
    order.biz_content.timeout_express = @"30m"; //超时时间设置
    order.biz_content.total_amount = [NSString stringWithFormat:@"%.2f", 0.01]; //商品价格
    
    //将商品信息拼接成字符串
    NSString *orderInfo = [order orderInfoEncoded:NO];
    NSString *orderInfoEncoded = [order orderInfoEncoded:YES];
    NSLog(@"orderSpec = %@",orderInfo);
    
    // NOTE: 获取私钥并将商户信息签名,外部商户的加签过程请务必放在服务端,防止公私钥数据泄露;
    //       需要遵循RSA签名规范,并将签名字符串base64编码和UrlEncode
    id<DataSigner> signer = CreateRSADataSigner(privateKey);
    NSString *signedString = [signer signString:orderInfo];
    
    // NOTE: 如果加签成功,则继续执行支付
    if (signedString != nil) {
        //应用注册scheme,在AliSDKDemo-Info.plist定义URL types
        NSString *appScheme = @"alisdkdemo";
        
        // NOTE: 将签名成功字符串格式化为订单字符串,请严格按照该格式
        NSString *orderString = [NSString stringWithFormat:@"%@&sign=%@",
                                 orderInfoEncoded, signedString];
        
        // NOTE: 调用支付结果开始支付
        [[AlipaySDK defaultService] payOrder:orderString fromScheme:appScheme callback:^(NSDictionary *resultDic) {
            NSLog(@"123reslut = %@",resultDic);
            
            
        }];
      }
    }
    
    - (NSString *)generateTradeNO
    {
         static int kNumber = 15;
    
         NSString *sourceStr = @"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
         NSMutableString *resultStr = [[NSMutableString alloc] init];
         srand((unsigned)time(0));
         for (int i = 0; i < kNumber; i++)
        {
            unsigned index = rand() % [sourceStr length];
            NSString *oneStr = [sourceStr substringWithRange:NSMakeRange(index, 1)];
            [resultStr appendString:oneStr];
        }
       return resultStr;
     }
    
    • 6.回调的添加

    • 6.1.代码中的回调标识符

    • 6.2.工程中配置


    提示:如果报下面的错

    拨错:集成支付宝 报错:rsa_private read error : private key is NULL

    解决办法:

    两中解决方法

    • 1解决方法:

      1)在RSADataSigner.m文件中 搜索代码 [result appendString:@"-----BEGIN PRIVATE KEY-----\n"]; 将其改成 [result appendString:@"-----BEGIN RSA PRIVATE KEY-----\n"];
      2)在RSADataSigner.m文件中 搜索代码 [result appendString:@"\n-----END PRIVATE KEY-----"]; 将其改成 [result appendString:@"\n-----END RSA PRIVATE KEY-----"];
      
    • 2解决方法:

      A、将私钥转成PKCS8替换一下原私钥即可
      
      1、生成私钥pem,  执行命令  openssl genrsa -out rsa_private_key.pem 1024
      2、生成公钥,执行命令  openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
      3、 将RSA私钥转换成PKCS8格式,命令执行  openssl pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM -nocrypt 
      ( PHP服务端语言读取私钥不需要PKCS8转换)
      

    iOS公钥私钥生成器 密码: pqyk
    我已经拖好的需要导入的文件 密码: aqyg
    ios支付宝demo 密码: cbfx
    老版本的支付宝,自己做的demo 密码: dkwf
    老版本的支付宝集成文档

    支付宝常见的其他bug解决

      1. Redefinition of 'RSA' as different kind of symbol
      • 上那个面的问题多为sdk集成时产生的坑,因为我们公司在集成支付宝之前,有用过RSA加密,导致重名问题
        解决办法:
        (1)这个问题不是每个公司都可能遇到的,但遇到也心烦
        (2)由于支付宝中的openssl中的rsa.h文件与RSA加密有重名冲突。改掉公司自己之前导入RSA的命名,如果你牛逼也可以去改rsa.h中的
    • 2.集成支付宝 报错:rsa_private read error : private key is NULL
      两中解决方法

      1.解决方法:

      • 1>在RSADataSigner.m文件中 搜索代码 [result appendString:@"-----BEGIN PRIVATE KEY-----\n"]; 将其改成 [result appendString:@"-----BEGIN RSA PRIVATE KEY-----\n"];
      • 2>在RSADataSigner.m文件中 搜索代码 [result appendString:@"\n-----END PRIVATE KEY-----"]; 将其改成 [result appendString:@"\n-----END RSA PRIVATE KEY-----"];

      2.解决方法:

      A、将私钥转成PKCS8替换一下原私钥即可

      • 1、生成私钥pem, 执行命令 openssl genrsa -out rsa_private_key.pem 1024
      • 2、生成公钥,执行命令 openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
      • 3、 将RSA私钥转换成PKCS8格式,命令执行 openssl pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM -nocrypt
        ( PHP服务端语言读取私钥不需要PKCS8转换)
    • 3.其他
      APP支付报错ALI64处理方案
      APP支付报错ALI40247处理方案

    最后推荐其他人的博客

    1.支付宝支付

    结论:如果有不懂得地方大家可以私聊我,欢迎批评指正!!!谢谢

    相关文章

      网友评论

      本文标题:29.支付宝支付改版了,你知道吗?

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