TT--TTOtherPayManager(iOS微信和支付宝支付)

来源:互联网 发布:37龙神契约进阶数据 编辑:程序博客网 时间:2024/05/14 13:03

本文来自简书,原文地址:http://www.jianshu.com/p/8cbe1a5b6704

前言

针对iOS的支付,在之前,TTFrameWork仅仅写了关于苹果的内购AppPurchaseManager,这次的更新,我融入了关于第三方(支付宝和微信)支付,采用最简单的调用方式,一站式解决方案.

提醒

根据微信支付和阿里(支付宝)支付的官方SDK的说明,进行支付的签名等一些信息,尽量放到 服务端 去做,特别是阿里支付需要涉及到 私钥(yuè) ,这里,为了方便开发者更容易理解,将签名的过程和内容放到客户端进行处理.

用途

针对苹果的审核理念,虚拟货币必须使用苹果内购,比如会员的充值等等,但是,限制于苹果服务器的不稳地以及高延迟,很多国内的开发者就按耐不住躁动的心,开始网项目中融入国内的微信和阿里支付,当然,这个也是需要技巧的,不如审核隐藏什么的,这个具体的方案就不多说了,毕竟存在风险,而且已经举报,查实就会被下架,特别是知名的APP,比如QQ购买会员依然是内购,所以,这个就看你们是怎么选择了.

正传

下面针对更新进行说明:

1. 导入库,关于相关的库的导入,请参考微信和支付宝sdk,那里比较详细

微信iOS接入说明
微信SDK

阿里支付iOS接入说明
阿里支付SDK

ps:导入库会出现很多问题,后续,我会在我的简书,推出相关的解决方案

2. 设置相关的注册的信息:

在TTConst中进行设置

// 微信#define WECHATAPPIDKEY              @"" // appiid#define WECHATAPPSECRETKEY          @"" // SECRETKEY#define WECHATPARTNERID             @"" // 商户号#define WECHATPARTNERKEY            @"" // 密钥// 阿里#define ALIPAYAPPID                 @"" // appid#define ALIPAYPRIVATEKEY            @"" // 私钥(这个对于阿里支付的私钥,建议放到服务器端去做)

3. UIAppleDelegate中的设置

  • 注册微信和阿里支付的相关SDK
    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { return [TTPAY_MANAGER registerApp];}
  • 微信/支付宝APP对支付结果进行回调

    这里需要执行协议,也就是微信和支付宝在客户端支付完后,会进行APP进行跳转的回调,相关的信息会通过协议进行表达.

    这里,我们对两种支付方式的回调进行了分装,通过Url.host进行区分,这里具体如实现可以查看实现方式.

    iOS 9.0 之前

    - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation {   return [TTPAY_MANAGER handleUrl:url];}

    iOS 9.0 之后

    - (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options {   return [TTPAY_MANAGER handleUrl:url];}
4. 使用
  • 相关Model进行赋值

    创建微信和支付宝对应的数据Model


    阿里支付Model

    微信支付Model


    记住, 数据均不为空 ,因为这里的数据是获取的支付的关键参数,如果需要设置其他的参数,可以参考上面的SDK内容.如果为空,可能导致不跳转或者支付失败.
    如果考虑服务器返回数据为空的情况,可以在model的属性的get方法中,进行重写,防止为空的情况,因为为空的话,会导致不跳转等等意外情况

  • 举例使用

    下面拿阿里(支付宝)支付进行说明:

    1. 创建Model,进行赋值:

      AliPayModel *model = [AliPayModel new];model.notifyUrl = item.aliPayNotifyUrl; // 这里的回调地址是服务器给的model.price = self.orderItem.originalPrice; model.orderNo = item.orderCode; // 这里是服务器定义的商品的标识码model.payTitle = @"title";model.body = @"description";
    2. 调用payWithOrderMessage,传入model就行,接下来会有相关的状态进行回调

      [TTPAY_MANAGER payWithOrderMessage:model successBlock:^{NSLog(@"----成功了");} cancelBlock:^{NSLog(@"----取消了");} failureBlock:^(NSString *errStr) {NSLog(@"----失败了");}];

最后,可以通过回调进行相应的处理,从而完成支付.

补充:

整套的支付开发流程,大家可以去查看一下对应的SDK,需要补充的是,毕竟这个不是自家的东西,很多东西局限性在于延迟或者数据对接问题,因此,你需要跟服务器对接好,比如服务器验证回调信息等等情况,以及相关的已经扣款,但是服务器无响应的情况,这个需要根据具体的产品需求进行相关的设置.

总结:

在开始的时候,看SDK的说明文档很懵逼,因为,参数太多,看不过来,而且也不知道哪些是需要填写的,哪些是选择填写的,而且,涉及到公司产品的需求,许多东西需要动态化处理.当时查看了很多的Demo,发现都是采用的官网给给出的Demo实例,针对签名部分,并没有给出很清楚的实例,如微信的二次签名,以及支付宝的私钥签名,这个其实是接入支付SDK的难点,因为,决定雷锋一把,写了这个傻瓜式的支付Tool,这个你可以直接拿过去用,拖入自己的工程,会报一些错误,可以从网上查找一下答案,这个网上都会有相关的内容,我就不一一列举了.

项目

这个第三方支付的Manager是我的TTFrameWork的一个分支,作为一个模块,已经上传到Github了,欢迎大家多多下载.
总项目地址:TTFrameWork
支付项目地址:TTOtherPayManager
TTFrameWork的简书地址:TTFrameWork简书

原创粉丝点击