�一、软硬件环境
类型:移动支付
目标:给公司的App集成支付宝付款功能
开发环境:OSX 10.11, Xcode7.1,
SDK:支付宝钱包支付接口开发包2.0标准版
查看移动支付的相关说明文档、下载SDK和Demo,点这里。
二、集成SDK
step:1: 在工程目录下新建一个文件夹,存放支付宝相关SDK和工具类文件。
step:2: 将SDK中的文件拷贝至新建的文件夹:
Util、openssl、libssl.a、libcrypto.a、AlipaySDK.bundle、AlipaySDK.framework、APAuthV2Info.h、APAuthV2Info.m、Order.h、Order.m
step:3: 将该文件夹拖入工程;
step:4: 添加框架SystemConfiguration.framework;
step:5: 此时会遇到编译报错的情况,根据报错情况添加相应的头文件即可;
.在Util文件夹下base64.h中添加 #import
.在Util文件夹下openssl_wrapper.h中添加#import
.如果遇到Error : Lexical or Preprocessor Issue 'openssl/asn1.h' file not found,在工程的Building Setting中查找Framework Search Paths,添加$(PROJECT_DIR)/AliSDK2_2_3或者$(SRCROOT)/AliSDK2_3_3,其中AliSDK2_3_3为刚才新建的文件夹名。
.如遇到其它报错信息,请百度或Google自行解决。
step:6: 设置�跳转参数
如果手机装有支付宝客户端,则支付时自动调用该客户端,如果没有安装,则调用网页版的支付页面。
在支付完成后根据跳转参数回到之前的应用。
设置方法:在工程的Target里找到Info - URL Type,点+号新建,在URL Schemes里将App的identifier添加进来,然后在AppDelegate中添加如下代码:
#pragma mark �跳转至支付宝App或网页版支付宝
- (BOOL)application:(UIApplication*)application openURL:(NSURL*)url sourceApplication:(NSString*)sourceApplication
annotation:(id)annotation {
//跳转至支付宝App进行支付,处理支付结果
[[AlipaySDKdefaultService]processOrderWithPaymentResult:urlstandbyCallback:^(NSDictionary*resultDic) {
#warning 是一坑,请注意
//这里不用写任何代码,支付结果会在下面的代码中进行处理
}];
returnYES;
}
step:7: 在调用支付宝App或网页版支付宝进行支付的viewController里做如下操作:
#pragma mark 支付核心代码
- (void)alipay {
//获得公钥私钥的方法在支付宝相关文档里有说明
//合作者身份(PID)2088开头的16位数字。
NSString *partner = @"";
//支付宝账号
NSString *seller = @"";
//RSA私钥转化的pkcs8格式私钥
NSString *privateKey = @"";
//支付宝提供的公钥
NSString *publicKey = @"";
//服务器异步通知页面
#warning TODO:需更改
NSString *AlipayNotifyURL = @"";
/*
*生成订单信息及签名
*/
//将商品信息赋予AlixPayOrder的成员变量
Order *order = [[Order alloc] init];
order.partner = partner;
order.seller = seller;
#warning TODO:服务器提供相关交易信息
order.tradeNO = [self generateTradeNO]; //订单ID(由商家自行制定)
order.productName = self.product.subject; //商品标题
order.productDescription = self.product.body; //商品描述
order.amount = [NSString stringWithFormat:@"%.2f",self.product.price]; //商品价格
order.notifyURL = @"http://www.xxx.com"; //回调URL
order.service = @"mobile.securitypay.pay";
order.paymentType = @"1"; //默认是1
order.inputCharset = @"utf-8";
order.itBPay = @"30m"; //订单过期时间:30分钟
order.showUrl = @"m.alipay.com";
//需要告诉支付宝刚才给该App定义的URL Types,以便跳转回来的时候使用
NSString *appScheme = @"test";
//将商品信息拼接成支付宝要求的字符串(自动调用支付宝提供的类来实现)
NSString *orderSpec = [order description];
//获取私钥并将商户信息签名,外部商户可以根据情况存放私钥和签名,只需要遵循RSA签名规范,并将签名字符串base64编码和UrlEncode
id signer = CreateRSADataSigner(privateKey);
NSString *signedString = [signer signString:orderSpec];
//将签名成功字符串格式化为订单字符串,请严格按照该格式
NSString *orderString = nil;
if (signedString != nil) {
orderString = [NSString stringWithFormat:@"%@&sign=\"%@\"&sign_type=\"%@\"",
orderSpec, signedString, @"RSA"];
[[AlipaySDK defaultService] payOrder:orderString fromScheme:appScheme callback:^(NSDictionary *resultDic) {
#warning TODO: 以下为自定义内容,用�于处理支付结果
//支付宝返回结果
NSDictionary *result = [self.paymentResult handleResultWithDictionary:resultDic andPublicKey:publicKey];
//如果返回结果为真,则隐藏支付按钮,并显示返回首页按钮
if ([result[@"result"] boolValue] == YES) {
//更新界面label文字
[self.paymentResultLabel setText:result[@"info"] textColor:[UIColor myGreenColor]];
[self hidePaymentResultControll:NO];
} else {
[self.paymentResultLabel setText:result[@"result"] textColor:[UIColor myRedColor] fontSize:18.0];
}
}];
}
}
#pragma mark 随机生成订单号
#warning TODO:在与服务器正式调试时记得删除
- (NSString *)generateTradeNO
{
static int kNumber = 15;
NSString *sourceStr = @"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
NSMutableString *resultStr = [[NSMutableString alloc] init];
for (int i = 0; i < kNumber; i++) {
unsigned index = arc4random() % [sourceStr length];
NSString *oneStr = [sourceStr substringWithRange:NSMakeRange(index, 1)];
[resultStr appendString:oneStr];
}
return resultStr;
}
参考文章:
- iOS支付宝2.3.3SDK集成开发(Swift1.2)
- 集成支付宝钱包支付iOS SDK的方法与经验