一、前言
-
用过支付宝支付的都知道,支付宝支付有两个回调,一个是wap支付回调,一个是支付宝钱包回调,简单来说就是,一个是有支付宝app的回调,一个是没有安装支付宝的回调
/**
* 处理钱包或者独立快捷app支付跳回商户app携带的支付结果Url
*
* @param resultUrl 支付结果url
* @param completionBlock 支付结果回调
*/
- (void)processOrderWithPaymentResult:(NSURL *)resultUrl
standbyCallback:(CompletionBlock)completionBlock;
/**
* 支付接口
*
* @param orderStr 订单信息
* @param schemeStr 调用支付的app注册在info.plist中的scheme
* @param compltionBlock 支付结果回调Block,用于wap支付结果回调(非跳转钱包支付)
*/
- (void)payOrder:(NSString *)orderStr
fromScheme:(NSString *)schemeStr
callback:(CompletionBlock)completionBlock;
二、问题
-
wap支付回调是在发起支付的方法里面,而支付宝钱包的回调是在AppDelegate里面实现的,那么问题就来了,如果我有支付宝app~我在当前的页面上发起支付,但回调却不在当前页面
三、解决方案
-
使用通知,在appDelegate的支付回调中发起一个通知,然后任意页面监听这个通知就可以处理
- 优点:😓额。。。就是比较容易想到,还有一点就是可以在任意文件监听
- 缺点:
- 1.麻烦,代码较多,要监听通知、实现监听事件以及销毁通知
- 2.没办法在通知中传递发起支付页面中的参数(模型数据、状态什么的),因为发通知的不是当前页面(当然可以当前页面监听,保存需要传递的参数,然后在监听方法里面处理。。。太麻烦了吧!)
-
使用单例保存当前的回调,因为两个回调只会执行一个,在支付后可以在任意地方实现回调
- 优点:封装单例工具类,统一管理支付以及支付回调(当然上面通知方法也可以封装成工具类啦~),可以在项目中任意文件、任意方法内实现回调,因此传参问题就解决了
- 缺点:暂时没发现,觉得挺爽的~😁
四、上代码😁,这里只给出API,完整在这 gitHub地址
统一回调,需要手动实现,支付后就在此回调
/**
* @author 孔凡列, 16-09-21 08:09:06
*
* 统一支付宝的回调,支付后可以实现回调
*/
@property (nonatomic,copy)FLAlipayCallback fl_callback;
单例模式,保证项目中唯一
+ (instancetype)shareManager;
支付宝授权,需要在AppDelegate中实现,详情请看Demo
/**
* @author 孔凡列, 16-09-21 08:09:06
*
* 支付宝授权支付-AppDelegate中实现
*/
- (void)fl_alipayWithUrl:(NSURL *)url;
发起支付宝支付,需要订单信息以及appScheme(就是在info中配置的),详情请看Demo
/**
* @author 孔凡列, 16-09-21 08:09:06
*
* 发起支付,任意地方
*/
- (void)fl_alipayWithOrderStr:(NSString *)orderStr appScheme:(NSString *)appScheme;
添加新方法:发起支付,带支付完毕回调(2016.11.29更新)
/**
* @author 孔凡列
*
* 发起支付,带支付后回调
*/
- (void)fl_alipayWithOrderStr:(NSString *)orderStr appScheme:(NSString *)appScheme callBack:(FLAlipayCallback)callBack;
五、调用
- delegate 中授权跳转支付
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url {
if ([url.host isEqualToString:@"safepay"]) {
// 支付跳转支付宝钱包进行支付,处理支付结果
return [self aliPay:url];
}
return YES;
}
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation {
if ([url.host isEqualToString:@"safepay"]) {
// 支付跳转支付宝钱包进行支付,处理支付结果
return [self aliPay:url];
}
return YES;
}
- (BOOL)application:(UIApplication *)application openURL:(nonnull NSURL *)url options:(nonnull NSDictionary<NSString *,id> *)options{
if ([url.host isEqualToString:@"safepay"]) {
// 支付跳转支付宝钱包进行支付,处理支付结果
return [self aliPay:url];
}
return YES;
}
- (BOOL)aliPay:(NSURL *)url{
// 支付跳转支付宝钱包进行支付,处理支付结果
[[FLAlipayManager shareManager] fl_alipayWithUrl:url];
return YES;
}
- 任意文件中发起支付、处理支付回调
NSString *orderString = @"订单信息(签名后)";
NSString *appScheme = @"FLAlipayDemo";
/**
* @author 孔凡列, 16-09-21 08:09:06
*
* 发起支付
*/
[[FLAlipayManager shareManager] fl_alipayWithOrderStr:orderString appScheme:appScheme];
/**
* @author 孔凡列, 16-09-21 08:09:06
*
* 支付回调
*/
[FLAlipayManager shareManager].fl_callback = ^(NSDictionary *result){
if ([result[@"resultStatus"] isEqualToString:@"9000"]){
NSLog(@"支付成功");
}
else{
NSLog(@"支付失败");
}
};
六、总结
因为实际开发中,我们一般都不需要管是从哪发起调用了,只需要回调就行,所以才有上面的封装想法,还是那句,欢迎大家关注我,喜欢给个like,我会随时更新~
如果大家使用过程中有问题,尽管留言,我会马上更新,最新更新的代码会在 gitHub 上,喜欢给个star
(2016.11.30)最新更新了微信和支付宝支付-看我的,用我的就够了,统一了微信和支付宝支付管理,欢迎关注,给个like 和 star