IOS 使用支付宝的注意事项

下载官方sdk要注意很多东西,首先要确认你的软件是调用支付宝的什么支付方式,目前,我所知的有调用支付宝,支付宝钱包,支付宝网页,支付宝快捷支付,每种使用方式的代码和逻辑都不太一样,使用时要注意。这里简述一下如何使用支付宝接口。

解压接口压缩文件(文件名是 WS_MOBILE_PAY_SDK_BASE.zip),找到 iOS的压缩文件(文件名是支付宝钱包支付开发包标准版(iOS).zip)。

1. 导入代码

  1. 步骤1:  启动IDE(如Xcode),把iOS包中的压缩文件中以下文件拷贝到项目文件夹下,

    并导入到项目工程中。

  2. 步骤2:  在需要调用AlipaySDK的文件中,增加头文件引用。#import

步骤3: 配置请求信息。

AlipaySDK.bundle
AlipaySDK.framework

Order *order = [[Order alloc] init];
order.partner = partner;
order.seller = seller;
order.tradeNO = [self generateTradeNO]; //
订单ID(由商家□自□行制定)order.productName = product.subject; //商品标题order.productDescription = product.body; //商品描述

order.amount = [NSString stringWithFormat:@"%.2f",product.price]; //商品价格 

order.notifyURL = @"http://www.xxx.com"; //回调URLorder.service = @"mobile.securitypay.pay";order.paymentType = @"1";
order.inputCharset = @"utf-8";

order.itBPay = @"30m";

//应用注册scheme,AlixPayDemo-Info.plist定义URL typesNSString *appScheme = @"alisdkdemo";

//将商品信息拼接成字符串
NSString *orderSpec = [order description];NSLog(@"orderSpec = %@",orderSpec);

//获取私钥并将商户信息签名,外部商户可以根据情况存放私钥和签名,只需要遵循 RSA 签名规范,并将签名字符串 base64 编码和 UrlEncode
id signer = CreateRSADataSigner(privateKey);
NSString *signedString = [signer signString:orderSpec];

//将签名成功字符串格式化为订单字符串,请严格按照该格式NSString *orderString = nil;
if (signedString != nil) {

orderString = [NSStringstringWithFormat:@"%@&sign=\"%@\"&sign_type=\"%@\"",

                   orderSpec, signedString, @"RSA"];

[[AlipaySDK defaultService] payOrder:orderString fromScheme:appSchemecallback:^(NSDictionary *resultDic) {

          NSLog(@"reslut = %@",resultDic);

}];

[tableView deselectRowAtIndexPath:indexPath animated:YES];} 

步骤4: 配置支付宝客户端返回url处理方法。
如示例
AliSDKDemo\APAppDelegate.m 文件中,增加引用代码:#import  

@implementation AppDelegate 中增加如下代码:

- (BOOL)application:(UIApplication *)application openURL:(NSURL *)urlsourceApplication:(NSString *)sourceApplication annotation:(id)annotation{

//如果极简开发包不可用,会跳转支付宝钱包进行支付,需要将支付宝钱包的支付结果回传给开发包

if ([url.host isEqualToString:@"safepay"]) {
[[AlipaySDK defaultService] processOrderWithPaymentResult:url

standbyCallback:^(NSDictionary *resultDic) {
          NSLog(@"result = %@",resultDic);

}];}

if ([url.host isEqualToString:@"platformapi"]){//支付宝钱包快登授权返回authCode

[[AlipaySDK defaultService] processAuthResult:urlstandbyCallback:^(NSDictionary *resultDic) {

          NSLog(@"result = %@",resultDic);
       }];

}

return YES;}

2. 针对Demo的运行注意

(1) 关于签名代码问题

  •  AliSDKDemo\Util 及下面所有文件

  •  AliSDKDemo\openssl 及下面所有文件

    libcrypto.a

    libssl.a

    这些文件是为示例签名所在客户端本地使用。出于安全考虑,请商户尽量把私钥保存在服务端,在服务端进行签名验签。

    (2) 如果遇到运行后报错,类似于以下提示信息:
    Cannot find interface declaration for 'NSObject', superclass of 'Base64'

    那么需要打开报错了的文件,增加头文件。
    
    #import 
    

    (3) 如果商户要在某个文件中使用支付宝的开发包类库,需增加引用头文件。#import  

(4) 点击项目名称,点击“Build Settings”选项卡,在搜索框中,以关键字“search”搜索,对“Header Search Paths”增加头文件路径:$(SRCROOT)/项目名称。如果头文件信息已增加,可不必再增加。

5-1 增加头文件信息

(5) 点击项目名称,点击“Build Phases”选项卡,在“Link Binary with Librarles”选项中,新增“AlipaySDK.framework”和“SystemConfiguration.framework”两个系统库文件。如果商户项目中已有这两个库文件,可不必再增加。

5-2 增加系统库文件 

(6) 点击项目名称,点击“Info”选项卡,在“URL Types”选项中,点击“+”,在“URL Schemes”中输入“alisdkdemo”。“alisdkdemo”来自于文件“APViewController.m”的 NSString *appScheme = @"alisdkdemo";

5-3 配置 URL Schemes

3. 配置基本信息打开“APViewController.m”文件,对以下三个参数进行编辑

5-1 IOS基本信息配置

NSString *partner = @"";
NSString *seller = @"";
NSString *privateKey = @"";

参数

含义

partner

合作身份者ID,以 2088 开头由 16 位纯数字组成的字符串。请参考“7.1 如何获得PID与密钥”。

seller

支付宝收款账号,手机号码或邮箱格式。

private_key

商户方的私钥,pkcs8 格式。请参考“7.2 RSA密钥生成与使用”。

4. 代码示例运行逻辑

  1. 步骤1:  调用 order.m 里的函数 description 将商品信息拼接成字符串作为待签名字符串,

    如:

  2. 步骤2:  使用类CreateRSADataSigner,调用signString签名函数做签名,如:

  3. 步骤3:  把签名结果赋值给参数 sign,并把 sign 加入之前的待签名数组中,此时得到的便是要请求给支付宝的全部数据。

"partner=\"2088101568353491\"&seller_id=\"2088101568353491\"&out_trade_no=\"YR2VGG3G1I31XDZ\"&subject=\"1\"&body=\" 我 是 测 试 数 据\"&total_fee=\"0.02\"¬ify_url=\"http://www.xxx.com\"&service=\"mobile.securitypay.pay\"&payment_type=\"1\"&_input_charset=\"utf-8\"&it_b_pay=\"30m\"&show_url=\"m.alipay.com\""

"GsSZgPloF1vn52XAItRAldwQAbzIgkDyByCxMfTZG%2FMapRoyrNIJo4U1LUGjHp6gdBZ7U8jA1kljLPqkeGv8MZigd3kH25V0UK3Jc3C94Ngxm5S%2Fz5QsNr6wnqNY9sx%2Bw6DqNdEQnnks7PKvvU0zgsynip50lAhJmflmfHvp%2Bgk%3D"

"partner=\"2088101568353491\"&seller_id=\"2088101568353491\"&out_trade_no=\"YR2VGG3G1I31XDZ\"&subject=\"1\"&body=\" 我 是 测 试 数 据\"&total_fee=\"0.02\"¬ify_url=\"http://www.xxx.com\"&service=\"mobile.securitypay.pay\"&payment_type=\"1\"&_input_charset=\"utf-8\"&it_b_pay=\"30m\"&show_url=\"m.alipay.com\"&sign=\"GsSZgPloF1vn52XAItRAldwQAbzIgkDyByCxMfTZG%2FMapRoyrNIJo4U1LUGjHp6gdBZ7U8jA1kljLPqkeGv8MZigd3kH25V0UK3Jc3C94Ngxm5S%2Fz5QsNr6wnqNY9sx%2Bw6DqNdEQnnks7PKvvU0zgsynip50lAhJmflmfHvp%2Bgk%3D\"&sign_type=\"RSA\""

步骤4: 调用(AlipaySDK *)defaultService 类下面的支付接口函数,唤起支付宝支付页面。

appScheme app info.plist 注册的 scheme。 

5-4 支付宝支付页面后面的动作全由买家在支付宝收银台中操作完成。如果设备中有支付宝客户端,会

优先调用支付宝客户端进行支付,支付完成后会重新唤起商户 app

步骤5: 当这笔交易被买家支付成功后支付宝收银台上显示该笔交易成功,并提示用户“返回”。此时在 APAppDelegate.m -

(BOOL)application:(UIApplication )application openURL:(NSURL )urlsourceApplication:(NSString *)sourceApplication annotation:(id)annotation 中调用获取返回数据的代码:

拿到返回数据:
点取消后返回

对其做 URLDecode

点确认后返回

"alisdkdemo://safepay/?{"memo":{"result":"","memo":" 用 户 中 途 取 消","ResultStatus":"6001"},"requestType":"safepay"}"

"alisdkdemo://safepay/?%7B%22memo%22:%7B%22result%22:%22partner=%5C%222088101568353491%5C%22&seller_id=%5C%222088101568353491%5C%22&out_trade_no=%5C%22QU6ZOD85K4HVQFN%5C%22&subject=%5C%221%5C%22&body=%5C%22%E6%88%91%E6%98%AF%E6%B5%8B%E8%AF%95%E6%95%B0%E6%8D%AE%5C%22&total_fee=%5C%220.02%5C%22¬ify_url=%5C%22http:%5C/%5C/www.xxx.com%5C%22&service=%5C%22mobile.securitypay.pay%5C%22&payment_type=%5C%221%5C%22&_input_charset=%5C%22utf-8%5C%22&it_b_pay=%5C%2230m%5C%22&show_url=%5C%22m.alipay.com%5C%22&success=%5C%22true%5C%22&sign_type=%5C%22RSA%5C%22&sign=%5C%22pg16DPA%5C/cIRg1iUFCl8lYZG54de+kfw+vCj32hGWye97isZ1A4bW6RNaDXHhZXVaI5Vk2YDxhNUl85EHRd+EL7%5C/+ogQTnsaEHl+D13PuZExIXRKGBnkYqaNV6kH6hDygnf5IOtoojHWLQyem7oRBVzB0vlF%5C/+YGFpzFHZyTVpM8=%5C%22%22,%22memo%22:%22%22,%22ResultStatus%22:%229000%22%7D,%22requestType%22:%22safepay%22%7D"

对其做 URLDecode

"alisdkdemo://safepay/?{"memo":{"result":"partner=\"2088101568353491\"&seller_id=\"2088101568353491\"&out_trade_no=\"QU6ZOD85K4HVQFN\"&subject=\"1\"&body=\" 我 是 测 试 数 据\"&total_fee=\"0.02\"¬ify_url=\"http:\/\/www.xxx.com\"&service=\"mobile.securitypay.pay\"&payment_type=\"1\"&_input_charset=\"utf-8\"&it_b_pay=\"30m\"&show_url=\"m.alipay.com\"&success=\"true\"&sign_type=\"RSA\"&sign=\"pg16DPA\/cIRg1iUFCl8lYZG54de+kfw+vCj32hGWye97isZ1A4bW6RNaDXHhZXVaI5Vk2YDxhNUl85EHRd+EL7\/+ogQTnsaEHl+D13PuZExIXRKGBnkYqaNV6kH6hDygnf5IOtoojHWLQyem7oRBVzB0vlF\/+YGFpzFHZyTVpM8=\"","memo":"","ResultStatus":"9000"},"requestType":"safepay"}"

之后,对这些数据做处理。

注意:

  •  由于在跳转支付宝客户端支付的过程中,商户app在后台很可能被系统kill了,所以 pay 接口的 callback 就会失效,请商户对 standbyCallback 返回的回调结果进行处理;

  •  同步返回数据时,建议通过服务端的验签功能代码做验签处理,之后再对返回的数据做业务逻辑处理;

  •  须以服务器异步通知的结果数据为准,并对其做业务逻辑处理。 

注意事项:1.一定要修改test中info.plist中的url 信息,且要与自己设置的appScheme相同,否则则支付宝软件不返回数据且不退出支付宝,也不返回原app

                  2.使用前先确认自己的版本是哪一个,是否是最新的

                  3.部分包需要import 头文件

                  4.遇到openssl 报错时 首先检查build setting 中的Header   Search Paths 是否设置,然后看看自己的文件中openssl 和util 是都放在各自的文件夹中,若是与项目文件放在一起,则需要将项目中"openssl/ " 删除掉,或者重新整理下openssl ,将器放在文件夹中

               5.使用时记得对其返回的resultStatus做处理 

      如下:

-(NSString *)dealWithResultCode

{

    int a =[self intValue];

    switch (a) {

        case 9000:

            return @"订单支付成功";

            break;

        case 8000:

            return @"正在处理中";

            break;

        case 4000:

            return @"订单支付失败";

            break;

        case 6001:

            return @"用户中途取消";

            break;

        case 6002:

            return @"网络连接出错";

            break;

        default:

            break;

    }

    return @"不能识别";

}


 以上就是我使用的见解与说明。



你可能感兴趣的:(ios开发)