美文网首页程序员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