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
记住, 数据均不为空 ,因为这里的数据是获取的支付的关键参数,如果需要设置其他的参数,可以参考上面的SDK内容.如果为空,可能导致不跳转或者支付失败.
如果考虑服务器返回数据为空的情况,可以在model的属性的get方法中,进行重写,防止为空的情况,因为为空的话,会导致不跳转等等意外情况
举例使用
下面拿阿里(支付宝)支付进行说明:
创建Model,进行赋值:
AliPayModel *model = [AliPayModel new];model.notifyUrl = item.aliPayNotifyUrl; // 这里的回调地址是服务器给的model.price = self.orderItem.originalPrice; model.orderNo = item.orderCode; // 这里是服务器定义的商品的标识码model.payTitle = @"title";model.body = @"description";
调用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简书
- TT--TTOtherPayManager(iOS微信和支付宝支付)
- iOS支付宝和微信支付
- iOS微信支付和支付宝支付开发详解
- iOS 微信支付和支付宝支付
- iOS微信支付和支付宝支付
- 微信支付,支付宝支付 iOS
- 微信支付和支付宝支付
- 支付宝支付和微信支付
- 微信支付和支付宝支付
- iOS支付[支付宝、银联、微信]
- iOS支付[支付宝、银联、微信]
- iOS 支付 [支付宝、银联、微信]
- iOS 支付 [支付宝、银联、微信]
- iOS 支付 [支付宝、银联、微信]
- iOS 支付 [支付宝、银联、微信]
- iOS 支付 [支付宝、银联、微信]
- iOS 支付 [支付宝、银联、微信]
- iOS 支付 [支付宝、银联、微信]
- [leetcode]: 404. Sum of Left Leaves
- Servlet编程
- 代码动态加载Prefab预设体
- 机器学习知识点(二十四)隐马尔可夫模型HMM维特比Viterbi算法Java实现
- eclipse常用快捷键(不定期增加)
- TT--TTOtherPayManager(iOS微信和支付宝支付)
- mac 自带的 Apache 不支持 php
- 删除有序数组中的重复元素,并返回数组的新长度
- linux下devicetree中惯用的of函数
- 多线程并发
- 去掉开机提示“android is starting”的提示框
- 海航集团负债率始终处于一个健康状态
- 百度2016实习-编号转换
- es6基础回顾--Generator函数