默认是在账号等信息注册好,验证签名已经在后台完成的的情况下移动端需要进行的操作
第一步:根据官方文档添加对应的支付宝,微信支付所需要的依赖库(略)
第二步:APPDELEGATE中操作
1.添加支付宝支付、微信支付所需要的头文件,与支付宝不同的是微信支付用的是协议,支付宝支付是回调获取相应支付信息状态,所以微信支付需要遵守协议。还有就是微信支付在客户端手到支付成功的状态后,需要与后台进行二次确认。
#支付宝支付
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options
{
if ([url.host isEqualToString:@"safepay"]) {
//跳转支付宝钱包进行支付,处理支付结果
[[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
NSLog(@"result = %@",resultDic);
//9000 支付成功
[[NSNotificationCenter defaultCenter]postNotificationName:@"aliPayResult" object:nil userInfo:resultDic];
}];
}else {
//微信支付
return [WXApi handleOpenURL:url delegate:self];
}
return YES;
}
#微信支付的代理方法
-(void)onResp:(BaseResp *)resp{
//启动微信支付的response
NSString *payResoult = [NSString stringWithFormat:@"%@", resp];
if([resp isKindOfClass:[PayResp class]]){
//支付返回结果,实际支付结果需要去微信服务器端查询
NSLog(@"微信支付结果===%@",payResoult);
switch (resp.errCode) {
case 0:
//payResoult = @支付结果:成功!;
[[NSNotificationCenter defaultCenter]postNotificationName:@"wxSuccessPay" object:nil];
NSLog(@"-------支付成功");
break;
case -1:
//payResoult = @支付结果:失败!;
[MBProgressHUD Pro_showAlertWithTitle:@"支付失败"];
break;
case -2:
//payResoult = @用户已经退出支付!;
[MBProgressHUD Pro_showAlertWithTitle:@"已退出支付"];
break;
default:
//payResoult = [NSString stringWithFormat:@支付结果:失败!retcode = %d, retstr = %@, resp.errCode,resp.errStr];
[MBProgressHUD Pro_showAlertWithTitle:@"支付失败"];
break;
}
}
}
第三步:在需要支付的界面进行的操作
[[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(aliPayResult:) name:@"aliPayResult" object:nil];
[[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(wxPaySuccess) name:@"wxSuccessPay" object:nil];
#pragma 支付宝支付
/**
*BodyDic 向后台传的参数,用于获取支付的订单信息
*/
-(void)aliPay:(NSDictionary *)bodyDic{
[[WebService_Pay shareInstance]getAliPayParamWithBody:bodyDic andResult:^(BOOL success, BaseResponse *response) {
if (success) {
// NOTE: 调用支付结果开始支付
NSString *appScheme=@"xxxxxxx"; //这里填上一个唯一的标识
NSString *orderStr=response.object;
[[AlipaySDK defaultService] payOrder:orderStr fromScheme:appScheme callback:^(NSDictionary *resultDic) {
NSLog(@"%@",resultDic);
}];
}else{
if (response.msg.length>0) {
[MBProgressHUD Pro_showAlertWithTitle:response.msg];
}
}
}];
}
//支付宝支付结果通知
-(void)aliPayResult:(NSNotification*)noti{
//9000表示支付成功
NSInteger resultStatus=[[noti.userInfo objectForKey:@"resultStatus"] integerValue];
if ( resultStatus==9000) {
NSLog(@“支付宝支付成功后相应操作”);
}else{
//支付失败
[MBProgressHUD Pro_showAlertWithTitle:@"支付失败"];
}
}
#pragma 微信支付
/**
*BodyDic 向后台传的参数,用于获取支付的订单信息
*/
-(void)wxPay:(NSDictionary *)bodyDic{
[[WebService_Pay shareInstance]getWXPayParamWithBody:bodyDic andResult:^(BOOL success, BaseResponse *response) {
if (success) {
NSLog(@"%@",response.object);
NSDictionary *wxDic=response.object;
//向微信注册您的APPID
[WXApi registerApp:[wxDic objectForKey:@"appid"]];
PayReq *req =[[PayReq alloc]init];
req.partnerId =[wxDic objectForKey:@"partnerid"];
req.prepayId =[wxDic objectForKey:@"prepayid"];
req.package =[wxDic objectForKey:@"packageValue"];
req.nonceStr =[wxDic objectForKey:@"noncestr"];
req.timeStamp =[[wxDic objectForKey:@"timestamp"] intValue];
req.sign =[wxDic objectForKey:@"sign"];
//调起支付
[WXApi sendReq:req];
}
}];
}
//微信支付成功跳转到支付成功界面
-(void)wxPaySuccess{
NSLog(@"微信支付成功后相应操作”);
}
第四部:设置URL schemes,微信支付直接填写APPID就好,支付宝支付填写在发起支付时填写的appShemes
这里以微信为例,简单介绍下支付流程
微信支付流程:
1.用户打开客户端,选择商品下单
2.客户端请求生成支付订单
3.商家后台调用统一下单API
4.微信支付系统生成预付单,返回商家后台预付单信息
5.商家后台根据预付单信息,生成相应的客户端支付信息,返回客户端prepay_id,sign等支付参数
6.客户端通过支付参数调用SDK调起微信支付,向微信支付系统发起支付请求
7.微信支付系统验证支付参数,APP支付权限等,返回需要支付授权。
8.用户确认支付,输入密码
9.客户端向微信支付系统验证授权,完成支付交易,分别向客户端,和商家后台返回相应的支付结果
10.商家后台接受和保存支付通知,向微信支付系统返回告知已成功接收处理
11.客户端通过回调接口执行回调,向商家后台查询实际支付结果
12.商家后台调用微信查询API查询支付结果,返回支付结果
13.客户端展示支付结果