您的位置:首页 > 移动开发 > 微信开发

微信支付基本流程

2015-12-25 12:30 603 查看
现在越来越多的app要求有多种支付功能,为了跟上时代的进步,现在着手去开发一些小功能,整体的流程是需要掌握下了。自己整理了一下笔记方便初入手者探讨。

1 . 将WCPay导入到工程中,编译不会发现错误是因为没有调用其中的方法,先在appdelegate didFinishLaunching中添加注册方法:

//需要导入 #import "WXApi.h"
[WXApi registerApp:@"wxb4ba3c02aa476ea1" withDescription:@"demo"];


2 . 编译下,会发现出现了许多错误,接下来需要导入以下框架:

CoreTelephony.framework,
SystemConfiguration.framework,
libz.dylib,
libsqlite3.0.dylib,
libc++.tbd


3 . 导入后便不会再有问题了。在控制器中编写代码:

- (IBAction)payAction:(UIButton *)sender {

PayReq *request = [[PayReq alloc] init];
// appid 已经发送,包括在其中了,

request.partnerId = @"10000100"; // 其余参数可参照文档
request.prepayId= @"wx20151225110409313a13567f0004263848";
request.package = @"Sign=WXPay";
request.nonceStr= @"2d21e39a1faeadd00a852027191e73e5";
request.timeStamp= 1451012649; // 从1970年1月日起的秒数
request.sign= @"7C5AD8E3CDE80EEAB124C70799A540E9";
[WXApi sendReq:request];

}


4 . 运行后便会提示问题:

App Transport Security has blocked a cleartext HTTP (http://) resource load since it is insecure. Temporary exceptions can be configured via your app’s Info.plist file.

这是因为iOS9新加了一些安全机制,再进行访问时需要在Info.plist中配置些信息

a. info.plist

LSApplicationQueriesSchemes   Array
item0 NSString weixin

NSAppTransportSecurity dict
NSAllowsArbitraryLoads BOOL YES


b. (回调用到)

在Target中找到 info 在其中URL Type中添加:Identifier:weixin url Schemes 填写代理中填写的
appid: wxb4ba3c02aa476ea1


5 . 再度运行(模拟器)出现问题:

LaunchServices: ERROR: There is no registered handler for URL scheme weixin


这是因为模拟器中并没有安装微信的原因,换成真机便不会有问题了。

6 . 回调,因为我们做支付一定是要有回调的,在微信支付代理中参照官方写法一个单例:WXPaymanager

需要在appdelegate中设置:(导入头文件)

- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url {
return [WXApi handleOpenURL:url delegate:[WXPaymanager shareManager]];
}

- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString *,id> *)options {
return [WXApi handleOpenURL:url delegate:[WXPaymanager shareManager]];
}


如果没有设置4中的url Schem是不回调的

WXPaymanager回调方法:

// 支付结果回调

- (void)onResp:(BaseResp *)resp {
if ([resp isKindOfClass:[PayResp class]]){
PayResp *response=(PayResp*)resp;
switch(response.errCode){
caseWXSuccess:
//服务器端查询支付通知或查询API返回的结果再提示成功
{
NSLog(@"支付成功");
break;
}
default:
NSLog(@"支付失败,retcode=%d",resp.errCode);
break;
}
}
}


基本流程到此结束,其余参数配置参考官方文档:

https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=9_1
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  支付 微信 app