iOS 开发之 - 微信支付

发布于 2025-11-04 19:13:48 字数 4995 浏览 1 评论 0

iOS 开发之 - 微信支付

作为 iOS 开发者,支付无疑是很重要的,特别是这两年几乎到处都是微信支付、支付宝支付。相比支付宝支付,觉得微信支付还算简单,但还是建议预先看下 文档 。开始说文章的内容吧,这篇文章主要分为四个部分:创建应用、了解支付的流程、集成微信 SDK,最后是实现支付的 demo。

第一步:创建应用

通常来说注册 APP 这样的事情是部门经理做的,所以这一步也可以忽略~~~

微信开放平台 的管理中心 创建一个应用。 此应用官方称七日内审核通过,一般都是三四天!而关于填写经营信息、填写商户信息、填写对公帐号信息在这里就忽略不写了。有兴趣的朋友可以了解下 这篇文章

创建应用

第二步:了解支付的流程

如果做过其它支付,就会发现这些流程其实都差不多,就像我们平时用手机支付买东西一样。下边的流程两分钟大概就能读完,很容易理解!

1> 用户使用 APP 客户端,选择商品下单。 2> APP 客户端将用户的商品数据传给商户服务器,请求生成支付订单。 3> 商户后台调用统一下单 API 向微信的服务器发送请求,微信服务器生成预付单,并生成一个 prepay_id 返回给商户后台。 4> 商户后台将这个 prepay_id 返回给商户客户端。 5> 用户点击确认支付,这时候商户客户端调用 SDK 打开微信客户端,进行微信支付。 6> 微信客户端向微信服务器发起支付请求并返回支付结果(他们之间交互用的就是 prepay_id 这个参数,微信的服务器要验证微信客户端传过去的参数是否跟第三步中生成的那个 id 一致)。 7> 用户输入支付密码后,微信客户端提交支付授权,跟微信服务器交互,完成支付 8> 微信服务器给微信客户端发送支付结果提示,并异步给商户服务器发送支付结果通知。 9> 商户客户端通过支付结果回调接口查询支付结果,并向后台检查支付结果是否正确,后台返回支付结果。 10> 商户客户端显示支付结果,完成订单,发货。

第三步:集成 SDK

其实严格来说,这一步才是微信支付的真正开始。首先我们应该下载 微信 SDK ,如有需要,还可把 【微信支付】APP 支付示例 下载下来看看。下面是集成 SDK 的具体步骤:

1.把下载好的 SDK 导入工程(如下图)(我下的是 OpenSDK1.7.4 版本)

把下载好的 SDK 导入工程

2.导入微信支付 SDK 依赖库(如下图)

导入微信支付 SDK 依赖库

3.设置 URL Scheme 在注册微信平台 APP 的时候,会给一个唯一识别标识符(APPID),需要填写在工程中。(如下图)

设置 URL Scheme

配置好上述参数后就可以写代码了~

第四部:代码

代码分为以下步骤:

1.在 Appdelegate 中注册微信 APPID 这是首先要做的事情。

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

  // 向微信终端注册 ID
  [WXApi registerApp:@"wx0f8d5e0eadd2d4b7" withDescription:@"demo test"];

  return YES;
}

2.获取微信支付所必要的参数 接着,在微信支付的.m 文件中获取微信支付所必要的参数。为了提高数据安全性,下单、签名等操作一般都是在后台完成的,因此以下这些参数后台会给我们。我们主要得知道这些参数如何设置:

  // 发起微信支付,设置参数
  PayReq *request   = [[PayReq alloc] init];  // 创建支付对象
  request.openID = @""; // 由用户微信号和 AppID 组成的唯一标识
  request.partnerId = @""; // 商家 ID
  request.prepayId  = @""; // 预支付订单 ID
  request.package   = @"Sign=WXPay"; // 数据和签名
  request.nonceStr  = @""; // 随机编码
  NSDate *date = [NSDate date];
  NSString * timeSp = [NSString stringWithFormat:@"%ld", (long)[date timeIntervalSince1970]];
  UInt32 timeStamp = [timeSp intValue];
  request.timeStamp = timeStamp; // 时间戳
  request.sign = @""; // 签名,签名一般都会加密

  //发送请求到微信,等待微信返回 onResp
  [WXApi sendReq:request];

3.微信支付回调 最后要在 Appdelegate.m 文件中添加微信支付结果 onResp 回调方法

// 判断发起的请求是否为微信支付,如果是就回调
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString *,id> *)options {
  return [WXApi handleOpenURL:url delegate:self];
}

#pragma mark - WXApiDelegate
// 微信支付结果回调方法
- (void)onResp:(BaseResp *)resp {
  NSString *payResoult = [NSString stringWithFormat:@"%d", resp.errCode];

  if([resp isKindOfClass:[PayResp class]]){

    /**
     WXSuccess       = 0,  成功
    WXErrCodeCommon   = -1,  普通错误类型
    WXErrCodeUserCancel = -2,  用户点击取消并返回
    WXErrCodeSentFail   = -3,  发送失败
    WXErrCodeAuthDeny   = -4,  授权失败
    WXErrCodeUnsupport  = -5,  微信不支持
     */
    //支付返回结果,实际支付结果需要去微信服务器端查询
    switch (resp.errCode) {
      case WXSuccess:
        payResoult = @"支付成功";
        break;
      case WXErrCodeCommon:
        payResoult = @"支付失败";
        break;
      case WXErrCodeUserCancel:
        payResoult = @"用户点击取消并返回";
        break;
      default:
        // 错误码 以及 错误提示字符串
        payResoult = [NSString stringWithFormat:@"支付结果:失败!retcode = %d, retstr = %@", resp.errCode,resp.errStr];
        break;
    }
  }
}

结束语:在开发中,微信支付常常与其它技术配合使用,比如 MD5 加密,AFN 等等。有空闲的话会一一整理出来与大家分享!另外文章写的如果有什么错误,还请大家指出来,谢谢大家!

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。