iOS微信支付,按照官方文档导入微信SDK。大致分为四步。
1、项目设置微信AppID,商户在微信开放平台申请开发APP应用后,微信开放平台会生成APP的唯一标识APPID。在Xcode中打开项目,设置项目属性中的URL Schemes为您的APPID。
2、商户APP工程中引入微信lib库和头文件,调用API前,需要先向微信注册您的APPID,代码如下:
[WXApi registerApp:@"wxd930ea5d5a258f4f" withDescription:@"demo 2.0"];
3、调起支付,商户服务器生成支付订单,先调用【统一下单API】生成预付单,获取到prepay_id后将参数再次签名传输给APP发起支付。从服务器请求加密后的字符串来调起微信客户端。
4、支付结果回调,照微信SDK Sample,在类实现onResp函数,支付完成后,微信APP会返回到商户APP并回调onResp函数,开发者需要在该函数中接收通知,判断返回错误码,如果支付成功则去后台查询支付结果再展示用户实际支付结果。注意一定不能以客户端返回作为用户支付的结果,应以服务器端的接收的支付通知或查询API返回的结果为准。
由于本身项目里面导入了友盟SDK6.1.0(里面包含了微信SDK),此时就不在重复导入微信SDK1.8.0,若没有导入,此时需要导入。可以通过cocoapods方式,可以手动导入。
*在工程的Podfile里面添加以下代码:
pod 'WechatOpenSDK'
保存并执行pod install,然后用后缀为.xcworkspace的文件打开工程。
注意:
命令行下执行pod search WechatOpenSDK,如显示的WechatOpenSDK版本不是最新的,则先执行pod repo update操作更新本地repo的内容
1、调起微信支付详细代码如下:
在AppDelegate中对微信key先进行注册:[WXApi registerApp:appkey];
调起微信支付
AppDelegate *delegate = (AppDelegate *)[UIApplication sharedApplication].delegate;
delegate.AlipayResultCallback = handler;
NSDictionary *dict = @{};
//商城大订单号
NSString *orderBigId = kCheckNil(jsDict[@"orderBigId"]);
//商城支付流水号
NSString *orderBizCode = kCheckNil(jsDict[@"orderBizCode"]);
//支付渠道
NSString *payWay = kCheckNil(jsDict[@"payWay"]);
// orderBigId = 20170927000000005201;
// orderBizCode = 20170927000000000200;
// payWay = alipay;
[[ShopManager sharedInstance] alipayOrderBigId:orderBigId inSerialNo:orderBizCode payWay:payWay
onComplete:^(BOOL isSuccessful, id result, NSString *error) {
if (isSuccessful)
{
NSDictionary *alipayDict = (NSDictionary *)result;
if (alipayDict)
{
//此时做个标记:标记是支付调起的支付宝或微信客户端
[[NSUserDefaults standardUserDefaults] setObject:@"isActived" forKey:@"alipay"];
if (alipayDict[@"wrappedThreePartyReqBody"] && [payWay isEqualToString:@"alipay"])
{
[[AlipaySDK defaultService] payOrder:alipayDict[@"wrappedThreePartyReqBody"] fromScheme:@"xhscmall" callback:^(NSDictionary *resultDic){
XHLog(@"resultDic = %@",resultDic);
handler(YES,resultDic);
}];
}
else if (alipayDict[@"wrappedThreePartyReqBody"] && [payWay isEqualToString:@"wechatpay"])
{
//回调字典给H5,成功回调statusCode为9000,失败回调空字符串。
[[PayServer sharedPayServer] wxPay:alipayDict[@"wrappedThreePartyReqBody"] withcomplete:^(PayType type, NSDictionary * _Nonnull message) {
if (type == PaySuccess) {
handler(YES,message);
}else if(type == PayCancle){
handler(NO,message);
}else if (type == PayFail){
handler(NO,message);
}
}];
}
}
}
else
{
handler(NO,dict);
}
}];
对后台返回的json字符串进行解析分解
if (![WXApi isWXAppInstalled]) {
complete(PayUnInstall, @{@"errorMsg":@"未安装微信!"});
return;
}
//json字符串转字典
if (payInfoString == nil) {
return;
}
NSData *jsonData = [payInfoString dataUsingEncoding:NSUTF8StringEncoding];
NSError *err;
NSDictionary *payInfo = [NSJSONSerialization JSONObjectWithData:jsonData
options:NSJSONReadingMutableContainers
error:&err];
if(err)
{
NSLog(@"json解析失败:%@",err);
return;
}
self.complete = complete;
self.uid = uid;
//组装微信支付请求信息
PayReq* request = [[PayReq alloc] init];
request.partnerId = [NSString stringWithFormat:@"%@",[payInfo objectForKey:@"partnerid"]];
request.prepayId= [NSString stringWithFormat:@"%@",[payInfo objectForKey:@"prepayid"]];
request.package = [NSString stringWithFormat:@"%@",[payInfo objectForKey:@"packages"]];
request.nonceStr= [NSString stringWithFormat:@"%@",[payInfo objectForKey:@"noncestr"]];
//服务端此时返回的是毫秒级,需要除以1000转换成秒级。
NSMutableString *stamp = [payInfo objectForKey:@"timestamp"];
//转换成UInt32
request.timeStamp = (UInt32)stamp.intValue;
request.sign= [NSString stringWithFormat:@"%@",[payInfo objectForKey:@"sign"]];
BOOL flag = [WXApi sendReq:request];
if (!flag) {
complete(PayFail, @{@"errorMsg":@"微信支付参数错误!"});
}
else{
//请求成功
NSLog(@"微信支付请求成功");
}
-(void)onResp:(BaseResp *)resp{
if ([resp isKindOfClass:[PayResp class]]) {
PayResp *response = (PayResp *)resp;
PayType type = PaySuccess;
//先写一个状态码为空字符串,支付成功将字符串置为9000,支付失败字符串继续为空。
NSString *statusCode = @"";
switch (response.errCode) {
case WXSuccess: {
type = PaySuccess;
statusCode = @"9000";
break;
}
case WXErrCodeUserCancel: {
type = PayCancle;
break;
}
default: {
type = PayFail;
break;
}
}
if (self.complete) {
self.complete(type, @{@"errorMsg":response.description,@"resultStatus":statusCode});
}
}
}
此时有三种回调的同步支付结果:支付成功,支付失败,支付取消。
同步结果不能作为App支付的依据,还是要根据微信订单号或者商户订单号去后台查验支付结果作为最终的支付依据。