历经这么长时间,终于安下心来记录一下项目中Ping++支付的相关环节和内容,不得不说Ping++确实是一款很不错的三方支付平台,更重要的是方便快捷,简书App同样也运用了此三方平台。因为 Ping++官方给的接入指南 已经很详尽,所以这里就简单小结一下支付环节,附上项目中的部分代码。
1.导入SDK并添加相关设置
当前项目中用的CocoaPods依赖管理工具来管理所需的第三方开源库(这样可以节省设置和更新第三方开源库的时间),导入 pod 'Pingpp', '~> 2.1.0' (默认会包含支付宝、微信、银联和百度钱包)。
由于项目中需要用到微信支付所以要添加 URL Schemes:,填入在微信平台上注册的应用程序的id(以wx开头的字符串)。如下图:
添加URL Types
2.接入开启支付的代码
导入头文件
#import "Pingpp.h"
客户端从服务器获取 charge 对象
/**
* 确认支付订单,往服务器传递订单所需的参数,并返回charge对象
*/
- (void)buyCarAddOrderDataWithCarid_count:(NSString *)carid_count {
typeof(self) _weakSelf = self;
NSString *userID = [[NSUserDefaults standardUserDefaults] objectForKey:@"user_id"];
NSString *URL = [NSString stringWithFormat:@"%@/App/Sylm/yclist",SERVERURL];
NSMutableDictionary *paramas = [NSMutableDictionary dictionary];
paramas[@"method"] = @"addorder";
paramas[@"buy_status"] = _buy_status;
paramas[@"carid_count"] = carid_count;
paramas[@"user_id"] = userID;
paramas[@"ways"] = self.ways; //客户端选择的支付方式参数
paramas[@"addr_id"] = self.addressModel.address_id;
[HXHttpTool post:URL params:paramas success:^(id json) {
LXLog(@"%@", json);
// 返回的json就是charge对象,直接拿来用,传递给调用唤起支付的方法
[_weakSelf wakeUpPingWithCharge:json];
} failure:^(NSError *error) {
[SVProgressHUD showErrorWithStatus:@"调取支付失败" maskType:SVProgressHUDMaskTypeGradient];
LXLog(@"%@", error);
}];
}
另:附上接口对照参数(仅供参考):
接口参数
利用charge对象唤起相应支付,其中kURLScheme为本应用的URL Schemes,在支付成功之后,正常跳转回应用。
/**
* 利用charge对象唤起支付
*/
- (void)wakeUpPingWithCharge:(NSString *)charge {
typeof(self) _weakSelf = self;
[Pingpp createPayment:charge
viewController:self
appURLScheme:kURLScheme
withCompletion:^(NSString *result, PingppError *error) {
if ([result isEqualToString:@"success"]) {
// 支付成功
[SVProgressHUD showSuccessWithStatus:@"支付成功" maskType:SVProgressHUDMaskTypeGradient];
// 这个方法在模拟器上运行支付时会走,真机测试时,这个方法不会触发,没有真机时,进行页面跳转调的方法
//[_weakSelf gotoSuccessVC];
} else {
// 支付失败或取消
LXLog(@"Error: code=%lu msg=%@", error.code, [error getMsg]);
[SVProgressHUD showErrorWithStatus:@"取消支付" maskType:SVProgressHUDMaskTypeGradient];
}
}];
}
配置 kURLScheme,如下图:
应用Schemes
接收并处理支付结果,必须实现
在AppDelegate.m文件中实现支付结果回调的方法,这里只做ios9以上的了。
iOS 9 及以上
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary *)options {
[Pingpp handleOpenURL:url withCompletion:^(NSString *result, PingppError *error) {
LXLog(@"%@", result);
// 用通知实现支付成功的页面跳转
if ([result isEqualToString:@"success"]) {
[[NSNotificationCenter defaultCenter] postNotificationName:@"enterSuccessView" object:nil];
}
}];
return YES;
}
3.小结
Ping++把支付订单的环节都放在服务器,所以客户端做的处理就少了许多,而且安全性更高(官方Demo用Swift写的),赞。
用微信支付的时候,要用真机进行测试,且安装的有微信客户端
iOS9限制http协议的访问,需要在info.plist文件中添加访问权限,而且还要添加应用白名单,如下图:
添加网络访问权限及白名单