将来跳槽用面试iOS资料

iOS微信支付填坑记

2016-06-04  本文已影响3520人  黑暗中的孤影

最近公司的APP需要接入微信支付功能。因为在这之前做了不少功课,所以总体步骤还是比较顺利,但是最后在拉起微信App里,总是出现-2错误码。这个地方坑了我好长时间,我相信读者可能会砬到过这种情况。最后在安卓同事的帮助下总算搞定了,成功进入支付页面。下面我来总结iOS微信支付的坑。

1: 下载微信支付SDK和Demo,网址微信支付

在这里我不得不吐槽微信支付的Demo开发者,此Demo还是2012年写的,是用MRC来管理内存,而且这个Demo我一直没有运行起来。我个人建议不要看这个Demo了,按照我下面的说明配置即可。下载完成后将SDK文件解压后放到你的项目里。在这里我说明一下,如果你用了友盟的社会化分享并且还支持微信的话,那你就不需要下载微信支付SDK了,直接可以用友盟里面的SDK文件。

2:配置App跳转的白名单。iOS9 大家都懂的

App跳转白名单

3:配置iOS UrlSchema,这个作为iOS开发者都知道啦

Url Schema 就是你在申请微信支付的App key


配置URL Types

4:添加框架Framework和dylib文件

有时侯添加SDK后项目不能编译通过,这种通常是你还没有加入SDK必要的dylib或者framework文件,确保在Link Binary With Libraries里加入以下Library


添加需要的Library
SystemConfiguration.framework,
libz.dylib,
libsqlite3.0.dylib,
libc++.dylib
CoreTelephony.frame

5 :在AppDelegate文件里面的方法里面微信注册您的APPID

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    // Override point for customization after application launch.
    
    [WXApi registerApp:@"此处填入微信分配的APPID"];//一般写以wx开头的Id
    //[WXApi registerApp:@"wxd930ea5d5a258f4f" withDescription:@"demo 2.0"];
    return YES;
}

里面的两个方法使用做任意一个即可

6:获取订单的重要信息,这个一般Server的同事会提供。我们需要下面最5个关键的属性:

 "appid": "wxb423c568326b71ee",//微信开放平台审核通过的应用APPID
 "partnerId": "1326631501",//微信支付分配的商户号
 "nonceStr": "EStCEnC8lVvIBV10",//随机字符串
 "prepayId": "wx20160601113412a39d0f4d700072397236",//预支付交易会话标识
 "sign":"E0A8028B79F4E64885B9D930E6FD88E2" //sign,这个是签名,但是很有可能这个签名是有问题的,我用不了

7:生成PayReq对象

PayReq *request = [PayReq new];
request.partnerId = @"1326631501";
request.prepayId= @"wx20160601113412a39d0f4d700072397236";
request.package = @"Sign=WXPay"; //package必定是这个
request.nonceStr= @"EStCEnC8lVvIBV10";
 NSDate *datenow = [NSDate date];
      NSString *timeSp = [NSString stringWithFormat:@"%ld", (long)[datenow timeIntervalSince1970]];
   UInt32 timeStamp =[timeSp intValue];
   request.timeStamp= timeStamp; //timeStamp是个十位数字

//request.sign= @"E0A8028B79F4E64885B9D930E6FD88E2";
   DataMD5 *md5 = [[DataMD5 alloc] init];
        request.sign=[md5 createMD5SingForPay:payInfo.appId partnerid:p.partnerId prepayid:p.prepayId package:p.package noncestr:p.nonceStr timestamp:p.timeStamp];
        NSLog(@"%@",p.sign);
       
[WXApi sendReq:request];

在这里值得说明;对于timeStamp,对当前的时间戳就行。再将其转成10位数字。
对于sign,在这里有个大坑,如果你直接使用了server返回的sign,那么在调起微信App后,发现这个页面只有一个确定按钮,无法实现支付功能,

调起微信支付后出现这种情况

点了确定按钮返回App后,给出的错误码中-2,就是是说,用户取消支付,什么玩意?
这其实就是传递接口的字段导致的问题。那么如何解决呢?首先确保以下几点

要注意在加密的方法里添加商户密钥key
  [contentString appendFormat:@"key=%@",@"E0A8028B79F4E64885B9D930E6FD88E2"];
      [UMSocialWechatHandler setWXAppId:SHARE_WX appSecret:SHARE_WX_SECRET url:SHAREURL];
        
      [WXApi registerApp:SHARE_WX withDescription:@"demo"];

这下返回码为-2的问题应该可以解决了,如果还是不行,可以和Server的同事商量返回的属性有没有问题。

8:最后还的回调问题,当用户完成支付或者取消支付,都要跳转回App,需要在这里处理一下url

 if url.host?.compare("pay") == NSComparisonResult.OrderedSame && url.host == "pay" {
         WXApi.handleOpenURL(url,delegate: WXApiManager.sharedManager())
         return true
        }

如果返回的url是pay,那么就是微信支付的跳回。需要调用 WXApi.handleOpenURL来处理,需要把Demo的WXApiManager文件拷贝到项目里面,调用它来处理回调。

上面就是我在开发微信支付SDK遇到的坑了,希望可以帮助大家。

上一篇下一篇

猜你喜欢

热点阅读