iOS开发微信支付详解(一)

网上看了好多博客文章,与关于微信支付的我拢了拢主要的,可以看看
这是导入的库和配置的URLType

1869333-5a26a95263fc5956.png

一、首先在AppDelegate.m 里

#import "AppDelegate.h"
#import "WXApi.h"
#import "ViewController.h"
@interface AppDelegate ()
@end
@implementation AppDelegate

这里就两行代码注册微信:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// Override point for customization after application launch.
ViewController *viewVC = [[ViewController alloc] init];
UINavigationController *nav = [[UINavigationController alloc] initWithRootViewController:viewVC];
self.window.backgroundColor = [UIColor whiteColor];
[self.window setRootViewController:nav];
// 向微信注册
BOOL isOk = [WXApi registerApp:@""];
if (isOk){NSLog(@"注册微信成功");
}else{NSLog(@"注册微信失败");
}return YES;
}

这里的代码就是吊起微信客户端的微信支付功能

- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary*)options
{
// 跳转到URL scheme中配置的地址
NSLog(@"跳转到URL scheme中配置的地址-->%@",url);
return [WXApi handleOpenURL:url delegate:self];  //WXApiDelegate协议
}

微信支付结果回调

- (void)onResp:(BaseResp *)resp
{
NSString *strMsg = [NSString stringWithFormat:@"-errcode:%d", resp.errCode];
NSString *strTitle;
if([resp isKindOfClass:[SendMessageToWXResp class]])
{
strTitle = [NSString stringWithFormat:@"发送媒体消息结果"];
}

if([resp isKindOfClass:[PayResp class]]){
#warning 4.支付返回结果,实际支付结果需要去自己的服务器端查询  由于demo的局限性这里直接使用返回的结果
strTitle = [NSString stringWithFormat:@"支付结果"];
// 返回码参考:https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=9_12
switch (resp.errCode) {
case WXSuccess:{
strMsg = @"支付结果:成功!";
NSLog(@"支付成功-PaySuccess,retcode = %d", resp.errCode);
NSNotification *notification = [NSNotification notificationWithName:@"ORDER_PAY_NOTIFICATION" object:@"success"];
[[NSNotificationCenter defaultCenter] postNotification:notification];
break;
}

default:{
strMsg = [NSString stringWithFormat:@"支付结果:失败!retcode = %d, retstr = %@", resp.errCode,resp.errStr];
NSLog(@"错误,retcode = %d, retstr = %@", resp.errCode,resp.errStr);
NSNotification *notification = [NSNotification notificationWithName:@"ORDER_PAY_NOTIFICATION"object:@"fail"];
[[NSNotificationCenter defaultCenter] postNotification:notification];
break;
}

}

}

UIAlertController *alert = [UIAlertController alertControllerWithTitle:strTitle message:strMsg preferredStyle:UIAlertControllerStyleAlert];
UIAlertAction *action = [UIAlertAction actionWithTitle:@"OK" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {
NSLog(@"知道了");
}];
[alert addAction:action];
[self.window.rootViewController presentViewController:alert animated:YES completion:nil];
NSLog(@"title = %@ message = %@", strTitle, strMsg);
}

二、在ViewController.m里面

#import "ViewController.h"
#import "WXApi.h"
@interface ViewController ()
@end
@implementation ViewController
```
/**
*  微信支付需要后台做大量的工作。
*  SDK及官方Demo下载:https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=11_1
*  官方的开发步骤参考这里:https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=8_5
*  这篇文档说的也挺详细:http://wenku.baidu.com/link?url=II3oeAaiH9NXWqdoO5HwXWCGcEermreHGBAqKvYfyKz_JVQ2n4NlA56e0H1HJWTNFfUsrTAgjegHBeUpMRzN0S318qcVklep7VCq0wBkpv7
*  还有这篇:http://www.cocoachina.com/bbs/read.php?tid=303132

** 移除通知**
```
- (void)dealloc
{
[[NSNotificationCenter defaultCenter]removeObserver:self];
}
```
** 监听通知**
```
- (void)viewWillAppear:(BOOL)animated{
[super viewWillAppear:animated];
if([WXApi isWXAppInstalled]) // 判断 用户是否安装微信
{
// 监听一个通知
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(getOrderPayResult:) name:@"ORDER_PAY_NOTIFICATION" object:nil];
}

}
```
```
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
self.navigationItem.title = @"微信支付";
UIButton *payButton = [UIButton buttonWithType:UIButtonTypeCustom];
payButton.frame = CGRectMake(50, 100, self.view.frame.size.width - 100, 60);
payButton.backgroundColor = [UIColor lightGrayColor];
[payButton setTitle:@"微信支付" forState:UIControlStateNormal];
[payButton setImage:[UIImage imageNamed:@"payNow_weixin"] forState:UIControlStateNormal];
[payButton setImageEdgeInsets:UIEdgeInsetsMake(5, -20, 0, 0)];
payButton.layer.cornerRadius = 5;
[payButton addTarget:self action:@selector(weChatPay) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:payButton];
}
```
**#pragma mark - 微信支付**
```
- (void)weChatPay
{
#warning 1.向自己的服务器请求订单生成预支付订单信息
NSString *string = [NSString stringWithFormat:@""];
[ZqNetWork getRequestWithURLString:string Parameters:nil RequestHead:nil DataReturnType:DataReturnTypeData SuccessBlock:^(NSData *data) {
NSDictionary *resultDic = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:nil];
// 具体参数根据自己后台来,这里不做示范
// 后台可以参考:https://pay.weixin.qq.com/wiki/doc/api/app.php?chapter=9_12
NSDictionary *dict = [resultDic objectForKey:@""];
if (dict != nil) {
NSMutableString *stamp  = [dict objectForKey:@""];
// 生成预支付订单信息
PayReq *req            = [[PayReq alloc] init];
req.openID              = [dict objectForKey:@""];
req.partnerId          = @"";
req.prepayId            = [dict objectForKey:@""];
req.nonceStr            = [dict objectForKey:@""];
req.timeStamp          = stamp.intValue;
req.package            = [dict objectForKey:@""];
req.sign                = [dict objectForKey:@""];
#warning 2.调起微信支付
if ([WXApi sendReq:req])
{
NSLog(@"调起成功!!!!");
}

else
{
NSLog(@"调起失败!!!");
}

}

} FailureBlock:^(NSError *error) {
NSLog(@"%@", error);
}];
}
```
**#pragma mark - 收到支付成功的消息后作相应的处理**
```
- (void)getOrderPayResult:(NSNotification *)notification
{
if ([notification.object isEqualToString:@"success"])
{
NSLog(@"支付成功!");
}

else
{
NSLog(@"支付失败!");
}

}
```
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容