iOS不用官方SDK实现微信和支付宝支付XHPayKit

作者:朱晓辉Allen

链接:https://juejin.im/post/5a90dd3a6fb9a0634912b755

前言

前段时间由于项目需求,移除了项目中的微信支付SDK和支付宝支付SDK,这种情况下需要自己搞定支付,第一时间考虑到的是使用openshare,但是当下载openshare下来后发现,openshare的支付接口,并不能直接替换官方SDK支付接口,

官方SDK的实现逻辑是后台订单签名完成后,客服端传签名信息及参数给支付SDK,支付SDK生成协议url,然后拉起第三方支付APP,

而openshare的支付接口是直接传拉起支付的协议url地址,将生成协议url地址的操作也交给后台来生成,

这样的话后台需要修改代码,

能否不修改后台代码,弄一个支付接口直接替换官方SDK支付接口,实现无缝对接呢,于是就研究了下微信和支付宝支付时APP间通讯关系,最后封装成XHPayKit.

特性:

 

1.XHPayKit拥有和官方SDK类似接口,可以直接替换官方SDK支付接口,如果你使用过官方SDK,那么转换为本库你只需花费极短时间.

2.XHPayKit只有10kb大小,不用导入任何依赖库,便可实现微信支付、支付宝支付,如果你想为项目瘦身或由于某种原因,不想使用官方SDK实现支付功能,此库将是一个不错的选择.

3.XHPayKit使用时,不需要配置微信等平台appid等信息,服务端配置就可以了,因为后台签名订单时会返回appid等信息给客户端.

注意:

1.先在微信、支付宝开放平台注册你的应用,并获得支付能力

2.导入此库,并请将 weixin 、 alipay 字段添加到info.plist白名单

3.添加自己APP URL Schemes,和微信回调URL Schemes,详见README文档

使用方法:

 

1.微信支付

//微信支付参数,下面7个参数,由后台签名订单后生成,并返回给客服端(与官方SDK一致)

//注意:请将下面参数设置为你自己真实订单签名后服务器返回参数,便可进行实际支付

XHPayWxReq *req = [[XHPayWxReq alloc] init];

req.openID = @"";

req.partnerId = @"";

req.prepayId = @"";

req.nonceStr = @"";

req.timeStamp = 1518156229;

req.package = @"";

req.sign = @"";

//传入订单模型,拉起微信支付

[[XHPayKit defaultManager] wxpayOrder:req completed:^(NSDictionary *resultDict) {

NSLog(@"支付结果:\n%@",resultDict);

NSInteger code = [resultDict[@"errCode"] integerValue];

if(code == 0){//支付成功

}

}];

2.支付宝支付

//支付宝订单签名,此签名由后台签名订单后生成,并返回给客户端(与官方SDK一致)

//注意:请将下面值设置为你自己真实订单签名,便可进行实际支付

NSString *orderSign = @"很长的一串支付宝订单签名";

//传入支付宝订单签名 和 自己App URL Scheme,拉起支付宝支付

[[XHPayKit defaultManager] alipayOrder:orderSign fromScheme:@"XHPayKitExample" completed:^(NSDictionary *resultDict) {

NSLog(@"支付结果:\n%@",resultDict);

NSInteger status = [resultDict[@"ResultStatus"] integerValue];

if(status == 9000){//支付成功

}

}];

3.在Appdelegate中添加以下代码 - 处理第三方支付跳回商户app携带的支付结果Url

#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_9_0

/** iOS9及以后 */

- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options

{

BOOL result = [[XHPayKit defaultManager] handleOpenURL:url];

if (!result) {//这里处理其他SDK(例如QQ登录,微博登录等)

}

return result;

}

#endif

/** iOS9以下 */

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

{

BOOL result = [[XHPayKit defaultManager] handleOpenURL:url];

if (!result) {//这里处理其他SDK(例如QQ登录,微博登录等)

}

return result;

}

其它接口:

/**

是否安装微信

@return 已安装YES,未安装NO

*/

+(BOOL)isWxAppInstalled;

/**

是否安装支付宝

@return 已安装YES,未安装NO

*/

+(BOOL)isAliAppInstalled;

支付结果resultDict释义:

微信

{

"errCode":0,

"errStr":"成功"

}

//以下状态码含义与官方SDK一致

errCode = 0,成功

errCode = -1,普通错误类型

errCode = -2,用户点击取消并返回

errCode = -3,发送失败

errCode = -4,授权失败

errCode = -5,微信不支持

支付宝

{

"result":"",

"resultStatus":"9000",

"memo":"支付成功"

}

//以下状态码含义与官方SDK一致

resultStatus = 9000,支付成功

resultStatus = 8000,正在处理中,支付结果未知(有可能已经支付成功),请查询商户订单列表中订单的支付状态

resultStatus = 4000,支付失败

resultStatus = 5000,重复请求

resultStatus = 6001,用户中途取消

resultStatus = 6002,网络连接出错

resultStatus = 6004,支付结果未知(有可能已经支付成功),请查询商户订单列表中订单的支付状态

小结:

 

XHPayKit的实现非常简单,感兴趣的同学可以下载下来研究下支付时APP间通讯.

代码地址:github.com/CoderZhuXH/…

原文地址:https://www.cnblogs.com/henusyj-1314/p/8543275.html

时间: 2024-08-24 05:20:02

iOS不用官方SDK实现微信和支付宝支付XHPayKit的相关文章

Android H5调起原生微信或支付宝支付

Android H5调起原生微信或支付宝支付 WebView调用原生微信或支付宝回调:其原理就是在shouldOverrideUrlLoading(final WebView view, String url)方法中进行拦截处理. 由于支付宝的取消支付之后跳转的页面显示不太友好,所以集成支付宝SDK-手机网站支付转APP支付,说明文档参照https://docs.open.alipay.com/204/105695/.按照说明集成aliPaySdk. 初始化WebView: private vo

使用开源库MAGICODES.WECHAT.SDK进行微信公众号支付开发

概要 博客使用Word发博,发布后,排版会出现很多问题,敬请谅解.可加群获取原始文档. 本篇主要讲解微信支付的开发流程,相关业务基于MAGICODES.WECHAT.SDK实现.通过本篇教程,您可以很方便的快速完成微信公众号支付的开发. 关于Magicodes.WeChat.SDK MAGICODES.WECHAT.SDK为心莱团队封装的轻量级微信SDK,现已全部开源,开源库地址为:https://github.com/xin-lai/Magicodes.WeChat.SDK 更多介绍,请关注后

MUI 微信 和支付宝支付 (前台代码)

<!-- 校园公告详情界面 用于显示校园公告的详情信息 在校园公告界面点击某一条目后 进入本界面查看详情 --> <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maxim

微信、支付宝支付绑定多个商户号

微信 当有多个收款或对账账户的需求的时候,可以通过微信服务商申请新的支付商户号,然后让服务商在配置中,给你设定默认关注的公众号是同一个公众号id就可以了. https://www.zhihu.com/question/33628407 支付宝 https://openclub.alipay.com/read.php?tid=2123&fid=56&page=1 原文地址:https://www.cnblogs.com/y-blog/p/9166813.html

微信与支付宝支付 浏览器判断&amp;页面关闭

以下为php浏览器头判断代码实例: public function getUserAgent(){ return isset($_SERVER['HTTP_USER_AGENT']) ? $_SERVER['HTTP_USER_AGENT'] : '';} $agent = self::getUserAgent(); if (strpos($agent, 'MicroMessenger') === false) { throw new Q_Exception('请使用微信打开', Lib_Cod

微信和支付宝实现

支付基本上是很多产品都必须的一个模块,大家最熟悉的应该就是微信和支付宝支付了,不过更多的可能还是停留在直接sdk的调用上,甚至和业务系统高度耦合,网上也存在各种解决方案,但大多形式各异,东拼西凑而成.所以这里我介绍下OSS.PayCenter开源跨平台支付组件 及其框架设计.并对常用支付模式进行一个全面介绍,方便大家开发以及跨平台使用.这篇文章主要围绕以下几个模块: 1. 微信和支付宝对比 2. 支付模式介绍 3. OSS.PayCenter框架设计 4. 调用示例 5. 注意事项 一. 微信和

iOS提交AppStore审核时:提示有其他支付并隐藏功能被拒的处理办法

背景提示:数字类产品(比如购买会员等不需要配送实物的商品),Apple规定必须使用苹果IAP应用内支付,给Apple分成30%.打包的时候不要勾选微信或支付宝等其他支付方式.如果你提交的包里包含了微信支付宝等支付的sdk,即使没使用,Appstore也会认为你有隐藏方式,以后会绕过iap,不给Apple分成,因此拒绝你的App上线 应用中如果没有交易功能,不要包含支付相关模块和支付相关的js代码 应用中如果只包含虚拟物品交易,只能使用苹果应用内支付(IAP),不能使用支付宝和微信支付 应用中如果

iOS开发笔记14:微博/微信登录与分享、微信/支付宝支付

产品中接入了微博/微信的第三方登录分享功能.微信和支付宝的第三方支付功能,之前在开发过程中涉及到这些部分,于是抽空将接入过程梳理了一遍. 1.微博.微信.支付宝SDK相关接入设置 (1)微博SDK SDK下载 设置URL Scheme,用于从第三方应用或浏览器中启动app 将SDK添加到工程中(支持CocoaPods),app启动时(didFinishLaunchingWithOptions)注册appkey 重写AppDelegate 的handleOpenURL和openURL方法,其它引用

iOS友盟分享--集成Facebook官方SDK

一直用的友盟分享,最近客户提了个新需求要求可以分享到Facebook  想到友盟就有FB分享 万分激动啊.. 但是测试后发现 友盟的Facebook 两种都存在一定问题.. 第一种   使用系统自带Facebook需要先在手机上设置Facebook账号 优点:这种分享简单 不需要配置Facebook AppID 缺点:继承了系统Facebook 不能预填写分享内容的特点(一般的app分享内容是要预填写的  怎么着也得王婆卖瓜对不对..所以这个缺点很致命); 第二种:使用应用内网页分享 (这种分享