29.支付宝支付改版了,你知道吗?
这里我讲的是关于最新的支付宝支付的流程
-
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解决
-
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转换)
最后推荐其他人的博客
结论:如果有不懂得地方大家可以私聊我,欢迎批评指正!!!谢谢