简聊iOS支付集成(支付宝和微信支付)

时间:2022-05-08 11:37:10

一.支付集成是什么

1.现在大部分app都有快捷支付功能,支付集成将第三方支付平台集成到自己的项目中,能够完成自己项目中的支付功能,

二.支付集成的使用

<1>.支付宝:

下载SDK和Demo:https://doc.open.alipay.com/doc2/detail.htm?treeId=54&articleId=104509&docType=1

配置相关信息:

1.导入SDK:

AlipaySDK.bundle

AlipaySDK.framework

2.配置静态库:在Build Phases选项卡的Link Binary With Libraries中
简聊iOS支付集成(支付宝和微信支付)
 
到此刻如果command+B的话没有报错,,说明你已经成功了,下面就要上代码了:
 
4.1在你点击支付的按钮的点击事件中写上如下代码
  //向支付宝发送请求
  [[AlipaySDK defaultService] payOrder:orderString fromScheme:appScheme callback:^(NSDictionary *resultDic) {

             NSLog(@"reslut = %@",resultDic);

         }];

这里面有必要解释一下.,orderString 是后台返回来的,是一个已经签名的字符串,支付宝的demo是前端进行签名的,为了安全,签名应该放在后台进行管理

4.2 在AppDelegate.m 导入头文件

#import <AlipaySDK/AlipaySDK.h>

并写下如下代码,这个函数主要作用是,从支付宝客户端返回到商户客户端的时候调用,在这里返回支付的结果状态

 #pragma mark -----当从支付宝客户端返回到商户客户端的时候调用
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options
{
//跳转支付宝钱包进行支付,处理支付结果
[[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
NSString* message; switch([[resultDic objectForKey:@"resultStatus"] integerValue])
{
case :message = @"订单支付成功";break;
case :message = @"正在处理中";break;
case :message = @"订单支付失败";break;
case :message = @"用户中途取消";break;
case :message = @"网络连接错误";break;
default:message = @"未知错误";
}
UIAlertController *aalert = [UIAlertController alertControllerWithTitle:nil
message:message
preferredStyle:UIAlertControllerStyleAlert];
[aalert addAction:[UIAlertAction actionWithTitle:@"好的" style:UIAlertActionStyleCancel handler:nil]];
UIViewController *root = self.window.rootViewController;
[root presentViewController:aalert animated:YES completion:nil]; }];
return YES;
25 }
恭喜你到此你的支付宝已经集成成功了

<2>微信支付:

1.下载SDK:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=11_1

导入SDK和文件:

libWeChatSDK.a

WechatAuthSDK.h

WXApi.h

WXApiObject.h

2.配置相关的静态库

简聊iOS支付集成(支付宝和微信支付)

3.配置URL Schemes:箭头指向的商户自己的AppID

简聊iOS支付集成(支付宝和微信支付)

在此刻Commd+B如果不报错,说明你集成成功了,
 
下面就添加代码了
4.创建集成:NSObject的WXApiManager.h的微信管理类
 
WXApiManager.h文件代码如下:
 //
// WXApiManager.h
// 支付集成
//
// Created by HYYT_IOS_ONE on 16/5/14.
// Copyright © 2016年 圣哥哥. All rights reserved.
// #import <Foundation/Foundation.h>
#import "WXApi.h" @protocol WXApiManagerDelegate <NSObject> @optional @end @interface WXApiManager : NSObject<WXApiDelegate> @property (nonatomic, assign) id<WXApiManagerDelegate> delegate; + (instancetype)sharedManager; @end
WXApiManager.m文件代码如下:
 //
// WXApiManager.m
// 支付集成
//
// Created by HYYT_IOS_ONE on 16/5/14.
// Copyright © 2016年 圣哥哥. All rights reserved.
// #import "WXApiManager.h" @implementation WXApiManager #pragma mark - LifeCycle
+(instancetype)sharedManager {
static dispatch_once_t onceToken;
static WXApiManager *instance;
dispatch_once(&onceToken, ^{
instance = [[WXApiManager alloc] init];
});
return instance;
} - (void)dealloc { } #pragma mark -----实现微信的代理 - (void)onResp:(BaseResp *)resp{ if([resp isKindOfClass:[PayResp class]]){
//支付返回结果,实际支付结果需要去微信服务器端查询
NSString *strMsg,*strTitle = [NSString stringWithFormat:@"支付结果"]; switch (resp.errCode) {
case WXSuccess:
strMsg = @"支付结果:成功!";
NSLog(@"支付成功-PaySuccess,retcode = %d", resp.errCode);
break; default:
strMsg = [NSString stringWithFormat:@"支付结果:失败!retcode = %d, retstr = %@", resp.errCode,resp.errStr];
NSLog(@"错误,retcode = %d, retstr = %@", resp.errCode,resp.errStr);
break;
}
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:strTitle message:strMsg delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil, nil];
[alert show]; } } @end

在AppDelegate.m文件中导入头文件

#import "WXApiManager.h"

写下如下代码

[WXApi registerApp:@"wxb4ba3c02aa476ea1" withDescription:@"demo 2.0"];

 #pragma mark -----当从客户端返回到商户客户端的时候调用
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options
{
return [WXApi handleOpenURL:url delegate:[WXApiManager sharedManager]]; }

最后在点击事件的文件中添加头文件

#import "WXApi.h"

#import "WXApiManager.h"

并写上以下代码就大功告成

 #pragma mark ----微信支付
- (NSString *)jumpToBizPay {
//============================================================
// V3&V4支付流程实现
// 注意:参数配置请查看服务器端Demo
// 更新时间:2015年11月20日
//============================================================
NSString *urlString = @"http://wxpay.weixin.qq.com/pub_v2/app/app_pay.php?plat=ios";
//解析服务端返回json数据
NSError *error;
//加载一个NSURL对象
NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:urlString]];
//将请求的url数据放到NSData对象中
NSData *response = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];
if ( response != nil) {
NSMutableDictionary *dict = NULL;
//IOS5自带解析类NSJSONSerialization从response中解析出数据放到字典中
dict = [NSJSONSerialization JSONObjectWithData:response options:NSJSONReadingMutableLeaves error:&error]; NSLog(@"url:%@",urlString);
if(dict != nil){
NSMutableString *retcode = [dict objectForKey:@"retcode"];
if (retcode.intValue == ){
NSMutableString *stamp = [dict objectForKey:@"timestamp"];
//调起微信支付
PayReq* req = [[PayReq alloc] init];
req.partnerId = [dict objectForKey:@"partnerid"];
req.prepayId = [dict objectForKey:@"prepayid"];
req.nonceStr = [dict objectForKey:@"noncestr"];
req.timeStamp = stamp.intValue;
req.package = [dict objectForKey:@"package"];
req.sign = [dict objectForKey:@"sign"];
[WXApi sendReq:req];
//日志输出
NSLog(@"appid=%@\npartid=%@\nprepayid=%@\nnoncestr=%@\ntimestamp=%ld\npackage=%@\nsign=%@",[dict objectForKey:@"appid"],req.partnerId,req.prepayId,req.nonceStr,(long)req.timeStamp,req.package,req.sign );
return @"";
}else{
return [dict objectForKey:@"retmsg"];
}
}else{
return @"服务器返回错误,未获取到json对象";
}
}else{
return @"服务器返回错误";
}
}

总结:在集成第三方的时候,一般先导入库,然后配置依赖库,最后做好相关配置,,基本上就大工告成