三方支付之支付宝支付集成

以下内容是我在做项目时遇到的一些小问题,主要是参考了阿里的官方文档,也有在网上找到的一些内容.主要是为了继承使用,对阿里的SDK中的东西没有做深入的讨论,希望各位有什么问题了一起交流学习下,以下内容全部是手打出来的,截图是我现做的一个demo.大神勿喷.感谢那些无偿分享技术的大牛们.

三方支付平台说明(一些废话,可以不用看的)


三方支付和内购很像,内购是用户将钱付款给苹果,之后苹果分给商户,而支付宝支付,是用户将钱付款给支付宝,,之后支付宝将钱转入到我们账户.
注意:使用三方支付是有前提的,购买的物品必须和应用程序无关,比如:团购券/衣服/电子商品等等.如果和应用程序有关,必须采用内购,否则不允许上架,比如:会员/游戏道具等.

集成支付宝


使用支付宝进行一个完整的支付,大致有以下步骤:

  • 向支付宝申请,与支付宝签约,获得商户ID(partner)和账户ID(seller)和私钥(privateKey)
  • 下载支付宝SDK
  • 生成订单信息,签名加密
  • 条用支付宝客户端,由支付宝客户端跟支付宝安全服务器打交道.
  • 支付完毕后,支付宝客户端会自动跳回到原来的应用程序
  • 在原来的应用程序中显示支付结果给用户看

三方支付平台说明(一些废话,可以不用看的)


三方支付和内够很像,内购是用户将钱付款给苹果,之后苹果分给商户,而支付宝支付,是用户将钱付款给支付宝,,之后支付宝将钱转入到我们账户.
注意:使用三方支付是有前提的,购买的物品必须和应用程序无关,比如:团购券/衣服/电子商品等等.如果和应用程序有关,必须采用内购,否则不允许上架,比如:会员/游戏道具等.

集成支付宝


使用支付宝进行一个完整的支付,大致有以下步骤:

  • 向支付宝申请,与支付宝签约,获得商户ID(partner)和账户ID(seller)和私钥(privateKey)
  • 下载支付宝SDK
  • 生成订单信息,签名加密
  • 条用支付宝客户端,由支付宝客户端跟支付宝安全服务器打交道.
  • 支付完毕后,支付宝客户端会自动跳回到原来的应用程序
  • 在原来的应用程序中显示支付结果给用户看
    大概流程下图所示:
Paste_Image.png

下面开始集成支付宝

集成前先介绍下支付宝的相关专业术语,方便理解(这些在支付宝的官网上都可以看到的)

  • API版本:支付宝网关分为两大类。一类是在支付宝开放平台建立之前就存在的商户网关,这类网关采用的访问协议称为1.0协议,协议参数中可区分的特征是需要传入partner、service等参数,以及请求网关为 https://mapi.alipay.com/gateway.do
    ,后简称mapi或API1.0;
    另外一类是随开放平台建立的开放网关,主要服务于接入开放平台的开放应用。这类网关采用的访问协议称为2.0协议,协议参数中可区分的特征是需要传入app_id、method、platform等参数,以及请求网关为 https://openapi.alipay.com/gateway.do
    ,后简称openapi或API2.0。

  • UID:user_id的简称,用户身份标示。用于表示支付宝用户的唯一标示。

  • PID:partner_id的简称,合作伙伴身份。可登录开放平台,点击用户名称,选择合作伙伴密钥查看

Paste_Image.png
  • APPID:app_id,应用身份标示。可登录开放平台,在“开放平台-管理中心-应用详情”查看。
Paste_Image.png
Paste_Image.png
  • RSA:RSA是一种公钥加密算法。能够抵抗到目前为止已知的绝大多数密码攻击,已被ISO推荐为公钥数据加密标准。主要用于公钥加密私钥解密、私钥签名公钥验签。
  • 支付宝公钥:开发者请求支付宝并获得返回时,开发者用于验签使用的公钥,查看位置如下图所示。
Paste_Image.png

下载支付宝SDK

Paste_Image.png
  • 双击打开demo
Paste_Image.png
  • 具体支付代码
    // 1.添加签约后的 商户ID/账号ID/商户方的私钥
    NSString *partner = @"";
    NSString *seller = @"";
    NSString *privateKey = @"";
    // 2.生成订单信息
    Order *order = [[Order alloc] init];
    order.partner = partner;            // 商户ID
    order.seller = seller;              //  账号ID
    order.tradeNO = nil;                //订单ID(由商家自行制定)
    order.productName = product.title;  //商品标题
    order.productDescription = product.detail; //商品描述
    order.amount = [NSString stringWithFormat:@"%.2f",product.price]; //商品价格
    // 购买成功后的服务器的回调地址
    order.notifyURL =  @"http://www.xxx.com"; //回调URL

// 固定写法
    order.service = @"mobile.securitypay.pay";
    order.paymentType = @"1";
    order.inputCharset = @"utf-8";
    order.itBPay = @"15m"; // 支付超时时间
    order.showUrl = @"m.alipay.com";
 //应用注册scheme,在AlixPayDemo-Info.plist定义URL types
 NSString *appScheme = @"appScheme"; // appScheme建议填写成自己的bundle ID 
下面是截图
Paste_Image.png
 //将商品信息拼接成字符串
 NSString *orderSpec = [order description];
 NSLog(@"orderSpec = %@",orderSpec);
 
 //获取私钥并将商户信息签名,外部商户可以根据情况存放私钥和签名,只需要遵循RSA签名规范,并将签名字符串base64编码和UrlEncode
 id<DataSigner> 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) {
            NSLog(@"reslut = %@",resultDic);
        }];
    }
    // 支付接口类方法,唤起支付界面
+ (void)payOrder:(NSString *)orderStr fromScheme:(NSString *)schemeStr
 callback:(CompletionBlock)completionBlock

在appDelegate里面
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation{

    if ([url.host isEqualToString:@"safepay"]) {
        //跳转支付宝钱包进行支付,处理支付结果
        [[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
            TFLog(@"result = %@",resultDic);  
            // 处理支付结果
        }];
    }
}

**返回值说明**
支付结束后SDK将回调completionBlock并将支付结果resultDic(NSDictionary *类型)作为参数传入该Block。resultDic中主要包含两个字段,如下所示:
resultCode  NSString *  返回码,标识支付状态,含义如下:
9000——订单支付成功
8000——正在处理中
4000——订单支付失败
5000——重复请求
6001——用户中途取消
6002——网络连接出错

以上是支付宝支付所需要用到的,具体实现的时候,还有一些坑需要注意.

首先把支付宝的SDK集成到自己的项目中

Paste_Image.png

把SDK拖拽到自己项目中一定要注意,如果你们公司是用svn管理的,里面的静态库libcrypto.a和libssl.a要用命令行添加到svn的管理下

Paste_Image.png
  • 首先添加上依赖库,阿里给的官网文档依赖库截图是这样的:
Paste_Image.png

按照官网文档添加依赖库,添加完成后还是报错
拖拽SDK的时候一定要把截图里面红框框中的拖进去
编译后报错

Paste_Image.png

查看报错原因,你会发现原来是文件Base64.h和openssl_wrapper.h中没有导入#import <Foundation/Foundation.h> 框架,阿里的demo是在.pch里添加的,分别在这两个文件中导入Foundation头文件就可以了.再次编译,还是报错,最大的坑来了

Paste_Image.png

openssl/asn1.h file not found

Paste_Image.png

再次编译,接着报错,所有的操作都是按照阿里的文档操作的.最后发现还是依赖库的问题

Paste_Image.png

缺少libc++.tbd这个库

Paste_Image.png

缺少CoreMotion.framework这个库

Paste_Image.png

缺少libz.tbd这个库


Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容