iOS-微信支付(二)高潮

2017-02-18日更新

一、声明:

1.1 此文章是继iOS-微信支付(一)前戏之后的文章,有疑问,请回顾前一篇文章 1.2 微信支付签名、加密都在服务器端做,此篇文章只调用服务器接口获取(partnerId、prepayId、nonceStr、timeStamp、sign)数据,然后直接调起微信支付。(网上看到好多大神,把签名、加密等方法都放在app端做,不明白目的是什么,其实微信也是提倡把这些事情都放在服务端去做,参见APP端开发步骤

01-app端开发步骤.png

1.3 微信的DEMO真的很傻逼,把N多功能都集成到这个DEMO里面,不知为何。而且2017-02-18下载的DEMO(有xcworkspace),居然没有(V3&V4支付流程实现)这段代码了,幸好之前的保留了一份,缺少的代码见下图:

02-微信DEMO缺少代码示例.png

1.4 我的工程中因为集成了友盟第三方(登录、分享)等功能,所以微信支付的SDK就可以不用再导入到项目中了(导入也会重复报错的)需要下载SDK的同学点击这里:微信支付SDK(点击iOS开发工具包即可下载)

03-微信支付SDK.png

1.5 建议写代码之前,先看下微信支付的业务逻辑,可以少走一些弯路微信支付业务流程

04-微信支付业务流程图.png

04-微信支付业务逻辑简化版.png

二、开始集成微信支付功能

2.1 项目设置APPID

05-设置项目APPID.png

2.2 导入微信支付SDK(我的工程中因为集成了友盟第三方(登录、分享)等功能,所以微信支付的SDK就可以不用再导入到项目中了)

06-微信支付SDK介绍.png

2.3 工程中链接上(因为我的项目里面用到的东西比较多,所以我引入的库也相对多一些,大家可以不用导入我这么多的)

SystemConfiguration.framework libz.dylib libsqlite3.0.dylib libc++.dylib Security.framework CoreTelephony.framework CFNetwork.framework

07-引入一些库.png

2.4 注册微信的APPID - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { // 向微信注册wxd930ea5d5a258f4f [WXApi registerApp:@"wxb4ba3c02aa476ea1" withDescription:@"demo 2.0"];

    return YES;
}

2.5 将WXApiManager.hWXApiManager.m拖入到工程里面(能用工具类,最好用工具类,不然AppDelegate里面代码会越来越多)

08-将WXApiManager拖入到项目中.png

2.6 调起微信支付

/**
 * 点击微信支付按钮,走下面的方法
 * 去服务器请求数据(partnerId、prepayId、nonceStr、timeStamp)
 */
[[HQNetworkTools sharedTools] requestPingTaiDataWithRootCode:rootCode parameters:para finished:^(id result, NSError *error) {
    
    if (error) {
        
        HQLog(@"%@", error);
        
    } else {
        
        [MBProgressHUD hideHUD];
        int success = [result[@"success"] intValue];
        if (success == 1) {
            
            HQBaseModel *model = [HQBaseModel mj_objectWithKeyValues:result[@"data"]];
            
            if ([payType_str isEqualToString:@"1"]) {               // wepay
                
                PayReq *request    = [[PayReq alloc] init];
                request.partnerId  = model.partnerid;
                request.prepayId   = model.prepayid;
                request.package    = @"Sign=WXPay";
                request.nonceStr   = model.noncestr;
                // 注意时间戳一定是10位的(最开始我们后台返回的就是13位的,一直报错),而且后台返回的是String,要转换类型
                request.timeStamp  = [model.timestamp intValue];
                request.sign       = model.sign;
                
                /**
                 * 调起微信支付的方法
                 */
                [WXApi sendReq:request];
                
            } else if ([payType_str isEqualToString:@"2"]) {        // alipay
            
                
            }
            
        } else {
            
            [MBProgressHUD showText:result[@"errorInfo"]];
        }
    }
}];

2.7 处理微信支付回调AppDelegate里操作 2.7.1 首先在AppDelegate里面导入头文件 #import <WXApi.h> #import "WXApiManager.h"

2.7.2 其次,处理微信回调,调用handleOpenURL方法,因为随着iOS的升级,有的方法废弃了,这里建议,下面三个方法里面都增加上,以防万一

#pragma mark - 设置微信回调
// 支持所有iOS系统(被废弃的方法.但是在低版本中会用到.建议写上)
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{
    /**
     * 微信支付回调
     */
    return [WXApi handleOpenURL:url delegate:[WXApiManager sharedManager]];
}

// 仅支持iOS9以上系统,iOS8及以下系统不会回调
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey, id> *)options
{
    /**
     * 微信支付回调
     */
    return [WXApi handleOpenURL:url delegate:[WXApiManager sharedManager]];
}

// 支持目前所有iOS系统
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
{
    /**
     * 微信支付回调
     */
    return [WXApi handleOpenURL:url delegate:[WXApiManager sharedManager]];
}

2.7.3 在WXApiManager中处理支付成功或者失败的回调(我这里是给支付控制器发送通知,然后跳转到"已付款订单页面"或者"待付款订单页面",详见下一篇文章iOS-微信支付(三)结局) #pragma mark - WXApiDelegate - (void)onResp:(BaseResp *)resp { if([resp isKindOfClass:[PayResp class]]) {

        // 支付返回结果,实际支付结果需要去微信服务器端查询
        NSString *strMsg = [NSString stringWithFormat:@"支付结果"];
        
        switch (resp.errCode) {
            case WXSuccess:
                strMsg = @"支付结果:成功!";
                HQLog(@"支付成功-PaySuccess,retcode = %d", resp.errCode);
                /** 发送支付成功的通知 */
                [[NSNotificationCenter defaultCenter] postNotificationName:HQPaySuccessNotification object:nil userInfo:nil];
                break;
                
            default:
                strMsg = [NSString stringWithFormat:@"支付失败"];
                HQLog(@"错误,retcode = %d, retstr = %@", resp.errCode,resp.errStr);
                /** 发送支付失败的通知 */
                [[NSNotificationCenter defaultCenter] postNotificationName:HQCancelPayNotification object:nil userInfo:nil];
                break;
        }
    }
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏每日一篇技术文章

VR+全景播放器+头控讲解-03

1031
来自专栏游戏杂谈

IOS判断用户的网络类型(2/3/4G、wifi)

直接贴代码吧,ios7之后是获取的较为准确,7以下我拿iphone5测试的是无法区分3g/2g。连iphone4都能升到7.1.4,而且目前主流的设备7以下的系...

1122
来自专栏Rindew的iOS技术分享

iOS百度地图POI详情检索与路径规划(附Demo)

3526
来自专栏青玉伏案

iOS开发之多表视图滑动切换示例(仿"头条"客户端)---优化篇

  前几天发布了一篇iOS开发之多表视图滑动切换示例(仿"头条"客户端)的博客,之所以写这篇博客,是因为一位iOS初学者提了一个问题,简单的写了个demo做了个...

2307
来自专栏数据和云

Oracle 12.2中那些温暖人心的特性

在OOW 2015大会上,Oracle已经发布了12.2的Beta版本,其中的很多亮点新特性引人瞩目,包括在IMO和Multitenant方面,以及在Shard...

3926
来自专栏数据和云

关于 Oracle 存储双活配置和实战

作者简介 ? 任小闯 云和恩墨交付技术顾问,6年以上数据库开发维护工作经历,Oracle 10g OCM,Oracle 11g OCP,曾就职于某互联网行业任数...

3938
来自专栏安恒信息

一些APT攻击案例分享

2014年我们所知的所有网络攻击,实际上还只是冰山一角,未来的网络空间将出现更多错综复杂、有组织性甚至是由敌对国家发起的网络袭击。APT攻击事件目前趋于爆发式增...

4235
来自专栏FreeBuf

极客DIY:使用Arduino制作一块开源手表

1 - 引言 首先让我们看下这个项目要考虑到的问题: 1.)使用100%Arduino兼容性硬件 2.)保证存储器足够大可以装下大量的稍后会扩展的新内容 ...

2506
来自专栏FreeBuf

样本分析 | 当“网络冲突”中的诱饵文件被用于真实的攻击事件

Cisco Talos最近发现了知名黑客组织74(又名Tsar Team,Sofacy,APT28,Fancy Bear…)的一种新型恶意行动,具有讽刺意味的是...

25410
来自专栏FreeBuf

适用于渗透测试不同阶段的工具收集整理

该资源清单列表涵盖了一系列,适用于渗透测试不同阶段的开源/商业工具。如果你想为此列表添加贡献,欢迎你向我发送pull request。

8440

扫码关注云+社区