iOS 微信支付
2016-07-13 13:47
429 查看
转载网上
https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=11_1
点进去之后下载SDK,另外也要把Demo下载下来,可以带你参考学习源码的使用,也可以留着以后进一步的探究:
Paste_Image.png
在新建的工程里,我们把下载的SDK拖进去,下载的SDK文件中有五个文件,那个read_me.txt可以不用留着工程里,随你喜欢,但是可以打开阅读里面的提示信息:
Paste_Image.png
导入的时候记得把微信SDKcopy到你的项目
我们先打开read_me.txt文件,其实里面就是讲了最近几个版本的更新中解决的问题,以及使用该SDK的注意事项,红色框框起来的部分我在后面的操作中都会用上,SO这个read_me文件很重要的哦。
图片文字比较小,可以放大看,当然你也可以在SDK里面的read_me文件查看
2.好,我们就按照read_me.txt做一下必须要做的流程:
Xcode 7版本之后需要导入一下框架和链接库:
Paste_Image.png
libz.tbd
libc++.tbd
SystemConfiguration.framework
CoreTelephony.framework
Security.framework
接着,按照read_me.txt的提示,我们把那段plist代码拷贝到info.plist文件中:
Paste_Image.png
Paste_Image.png
App Transport Security Settings是XCode7以后就需要开发中手动添加设置的,因为iOS9默认限制了http协议的访问。
LSApplicationQueriesSchemes是可以将要使用的URL Schemes列为白名单,这样当前应用可以使用微信的相关能力(分享、收藏、支付、登录等)。
最后还有一个操作哦,将微信支付要用到的APPID设置为URL Schemes 。
Paste_Image.png
将微信的APPID复制到这里
我们可以打开微信支付平台下载的Demo程序,可以在它的AppDelegate的源码中找到测试用的APPID:
Paste_Image.png
然后回到自己建立的工程中,写下了微信支付的流程:
Paste_Image.png
既然要注册微信,那么我们先到微信SDK的头文件中查看一下,发现只提供了两个注册方法,注释也写的很清楚:
Paste_Image.png
然后我们导入这个头文件之后,直接根据已经有的APPID进行注册:
Paste_Image.png
好,其实步骤:1、导入微信支付SDK,注册微信支付。然后2、设置微信APPID为URL Schemes前面已经做好了。
然后我们需要进行3、发起支付,调其微信支付,在这之前,我们直接看看微信官方提供给我们的Demo:
Paste_Image.png
Paste_Image.png
最后我们找到了Demo中完整的可以直接用的这部分发起微信支付的源码:
Paste_Image.png
将这段直接拷贝到我的工程中,有那么一点经验的开发者就会注意到一些,比如Demo源码使用了MRC的autorelease,你可以手动去掉,类方法可以换成实例方法,根据你的实际项目开发需求:
哦,对了,还有一个很简单但很必要的操作忘记展示出来了:
Paste_Image.png
进一步,我们在微信的SDK源码头文件中,可以找到两个很有用的方法,你也可以在微信支付平台打开开发者文档找到这两个方法的介绍:
Paste_Image.png
然后我将其运用在我的工程中
Paste_Image.png
好,就这样,步骤:3、发起微信支付,调起微信 到这里就完成了。
最后还需要做的就是,处理返回微信支付返回信息,使用了微信知否功能,不管是支付成功和失败,甚至还是用户自己取消支付,都会需要返回当前应用,并返回相关的信息。
这里就需要用到微信SDK的处理返回信息的代理协议和代理方法了:
Paste_Image.png
在微信SDK的头文件中,我们可以找到protocol协议:
Paste_Image.png
好,我们也官方Demo中看看它是如何使用的:
Paste_Image.png
Paste_Image.png
而我们只需要使用下面红色框框起来的部分代码,直接拷贝拿来使用:
Paste_Image.png
回到我的简易工程中,直接粘贴在里面用:
Paste_Image.png
那么这里面的返回信息中主要就有两个东西:resp.errCode错误码 和 resp.errStr错误原因,这两个东西在实际开发中经常遇到,所以也是面试会问到的一个细节。
接着你可以通过点进连接
https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=8_5
可以在官方开发文档中找到:
Paste_Image.png
Paste_Image.png
然后,根据实际开发需求,我们可能还需要回传微信app的相关信息:
在当前AppDelegate.m文件添加一个代理方法:
Paste_Image.png
IOS 微信支付
1.就建立一个普通的工程,直接在上面简易的使用微信SDK,并完成微信支付。https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=11_1
点进去之后下载SDK,另外也要把Demo下载下来,可以带你参考学习源码的使用,也可以留着以后进一步的探究:
Paste_Image.png
在新建的工程里,我们把下载的SDK拖进去,下载的SDK文件中有五个文件,那个read_me.txt可以不用留着工程里,随你喜欢,但是可以打开阅读里面的提示信息:
Paste_Image.png
导入的时候记得把微信SDKcopy到你的项目
我们先打开read_me.txt文件,其实里面就是讲了最近几个版本的更新中解决的问题,以及使用该SDK的注意事项,红色框框起来的部分我在后面的操作中都会用上,SO这个read_me文件很重要的哦。
图片文字比较小,可以放大看,当然你也可以在SDK里面的read_me文件查看
2.好,我们就按照read_me.txt做一下必须要做的流程:
Xcode 7版本之后需要导入一下框架和链接库:
Paste_Image.png
如下
libsqlite3.tbdlibz.tbd
libc++.tbd
SystemConfiguration.framework
CoreTelephony.framework
Security.framework
接着,按照read_me.txt的提示,我们把那段plist代码拷贝到info.plist文件中:
<key>LSApplicationQueriesSchemes</key> <array> <string>weixin</string> </array> <key>NSAppTransportSecurity</key> <dict> <key>NSAllowsArbitraryLoads</key> <true/> </dict>
Paste_Image.png
Paste_Image.png
App Transport Security Settings是XCode7以后就需要开发中手动添加设置的,因为iOS9默认限制了http协议的访问。
LSApplicationQueriesSchemes是可以将要使用的URL Schemes列为白名单,这样当前应用可以使用微信的相关能力(分享、收藏、支付、登录等)。
最后还有一个操作哦,将微信支付要用到的APPID设置为URL Schemes 。
Paste_Image.png
将微信的APPID复制到这里
我们可以打开微信支付平台下载的Demo程序,可以在它的AppDelegate的源码中找到测试用的APPID:
Paste_Image.png
然后回到自己建立的工程中,写下了微信支付的流程:
Paste_Image.png
既然要注册微信,那么我们先到微信SDK的头文件中查看一下,发现只提供了两个注册方法,注释也写的很清楚:
Paste_Image.png
然后我们导入这个头文件之后,直接根据已经有的APPID进行注册:
Paste_Image.png
好,其实步骤:1、导入微信支付SDK,注册微信支付。然后2、设置微信APPID为URL Schemes前面已经做好了。
然后我们需要进行3、发起支付,调其微信支付,在这之前,我们直接看看微信官方提供给我们的Demo:
Paste_Image.png
Paste_Image.png
最后我们找到了Demo中完整的可以直接用的这部分发起微信支付的源码:
Paste_Image.png
将这段直接拷贝到我的工程中,有那么一点经验的开发者就会注意到一些,比如Demo源码使用了MRC的autorelease,你可以手动去掉,类方法可以换成实例方法,根据你的实际项目开发需求:
- (NSString *)jumpToBizPay { //============================================================ // V3&V4支付流程实现 // 注意:参数配置请查看服务器端Demo //============================================================ NSString *urlString = @"http://wxpay.weixin.qq.com/pub_v2/app/app_pay.php?plat=ios"; //解析服务端返回json数据10 NSError *error; //加载一个NSURL对象 NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:urlString]]; //将请求的url数据放到NSData对象中 NSData *response = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil]; if ( response != nil) { NSMutableDictionary *dict = NULL; //IOS5自带解析类NSJSONSerialization从response中解析出数据放到字典中 dict = [NSJSONSerialization JSONObjectWithData:response options:NSJSONReadingMutableLeaves error:&error]; NSLog(@"url:%@",urlString); if(dict != nil){ NSMut d653 ableString *retcode = [dict objectForKey:@"retcode"]; if (retcode.intValue == 0){ NSMutableString *stamp = [dict objectForKey:@"timestamp"]; //调起微信支付 PayReq* req = [[PayReq alloc] init]; req.partnerId = [dict objectForKey:@"partnerid"]; req.prepayId = [dict objectForKey:@"prepayid"]; req.nonceStr = [dict objectForKey:@"noncestr"]; req.timeStamp = stamp.intValue; req.package = [dict objectForKey:@"package"]; req.sign = [dict objectForKey:@"sign"]; [WXApi sendReq:req]; //日志输出 NSLog(@"appid=%@\npartid=%@\nprepayid=%@\nnoncestr=%@\ntimestamp=%ld\npackage=%@\nsign=%@",[dict objectForKey:@"appid"],req.partnerId,req.prepayId,req.nonceStr,(long)req.timeStamp,req.package,req.sign ); return @""; }else{ return [dict objectForKey:@"retmsg"]; } }else{ return @"服务器返回错误,未获取到json对象"; } }else{ return @"服务器返回错误"; } }
哦,对了,还有一个很简单但很必要的操作忘记展示出来了:
Paste_Image.png
进一步,我们在微信的SDK源码头文件中,可以找到两个很有用的方法,你也可以在微信支付平台打开开发者文档找到这两个方法的介绍:
Paste_Image.png
然后我将其运用在我的工程中
Paste_Image.png
好,就这样,步骤:3、发起微信支付,调起微信 到这里就完成了。
最后还需要做的就是,处理返回微信支付返回信息,使用了微信知否功能,不管是支付成功和失败,甚至还是用户自己取消支付,都会需要返回当前应用,并返回相关的信息。
这里就需要用到微信SDK的处理返回信息的代理协议和代理方法了:
Paste_Image.png
在微信SDK的头文件中,我们可以找到protocol协议:
Paste_Image.png
好,我们也官方Demo中看看它是如何使用的:
Paste_Image.png
Paste_Image.png
而我们只需要使用下面红色框框起来的部分代码,直接拷贝拿来使用:
Paste_Image.png
回到我的简易工程中,直接粘贴在里面用:
Paste_Image.png
那么这里面的返回信息中主要就有两个东西:resp.errCode错误码 和 resp.errStr错误原因,这两个东西在实际开发中经常遇到,所以也是面试会问到的一个细节。
接着你可以通过点进连接
https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=8_5
可以在官方开发文档中找到:
Paste_Image.png
Paste_Image.png
然后,根据实际开发需求,我们可能还需要回传微信app的相关信息:
在当前AppDelegate.m文件添加一个代理方法:
Paste_Image.png
相关文章推荐
- 安卓非微信内置浏览器中的网页调起微信支付的方案研究
- 外观模式小程序JAVA源代码
- Android -- 真正的 高仿微信 打开网页的进度条效果
- java微信 客服接口-发消息 中文乱码
- 微信hit push hold !!
- 判断是否为微信浏览器的JS代码
- Android封装好的类似于RadioGroup的底部导航或顶部导航、仿微信底部导航
- 微信扫码登陆过程。
- 微信扫码支付回调验签失败,请教大神解答
- iOS开发支付集成之微信支付
- iOS开发支付集成之微信支付
- 该公众号暂时无法提供服务,请稍后再试
- 解决"友盟微信跳转提示<您的设备未安装微信>"的问题
- 微信公众号开发教程[006]-PHP使用CURL详解
- iOS开发支付集成之微信支付
- 李洪强iOS开发支付集成之微信支付
- Android微信界面的设计
- 从这3点中看如何靠微信文章引爆朋友圈?
- 生鲜电商突破硬伤 主打微信“菜篮子”
- [Web学习]微信网页ios的标题能被正确设置