目录
1. Ping++支付
2. 微信/支付宝/银联
方式一:Ping++支付
Ping++ 简化前台代码,快速集成支付宝,微信,银联等三方支付
不推荐使用,因为收费+不安全
- 前期配置
Ping++开发者平台(https://www.pingxx.com/?from=1&desc=ping++)
1.验证企业信息
2.创建应用(APP_ID后台需要)|应用设置|支付渠道(点击填写渠道,有帮助文档)
开通 移动(支付宝,微信,银联)PC(银联,支付宝)
支付宝及网页支付宝 相关设置【登录 蚂蚁金服开放平台(https://open.alipay.com/platform/home.htm)】
版本选择(v1.0 mapi 和2.0 openapi):开发者中心 | 网页&移动平台 | 支付接入创建应用 | 添加功能(手机网站支付|App支付)(版本:功能右方有已生效则为v2.0:openapi,否则为v1.0:mapi)
PID:右上方账号|账户信息|角色身份PID
支付宝账号:登录账号(企业账号)
MD5密钥:右上方账号|密钥管理|mapi网关(1.0版本时)|合作伙伴密钥|查看MD5密钥
支付宝公钥:自动生成RSA公钥和私钥(http://demo.pingxx.com/tools/genrsa.php)将公钥去头去尾填写在 右上方账号|密钥管理|mapi网关(1.0版本时)|合作伙伴密钥|RSA(SHA1)中,复制支付宝公钥内容
应用私钥:上述私钥
// 渠道费率 0
// 支付宝版本
// 免密 否
// 合作伙伴PID
// 支付宝账号
// MD5密钥
// 支付宝公钥
// 应用私钥
微信 相关设置
登录微信开发平台(https://open.weixin.qq.com)
注册应用(获取AppID和AppSercet)
登录微信商户平台(https://pay.weixin.qq.com/index.php)
账户中心|支付申请 (获取商户ID号)
账户中心|账户设置|API安全|设置API密钥(32位密钥生成器http://tool.c7sky.com/password/)|
账户中心|账户设置|基本账号|新增员工登陆账号
账户中心|账户设置|API安全|下载证书(cert文件内容:API证书 key文件内容:API证书密钥)
// 渠道费率 0
// APPID
// AppSercet
// 微信支付商户号
// API密钥
// 员工登陆账号
// API证书
// API证书密钥
银联 相关设置
商户号:登录银联(https://open.unionpay.com/)账号,申请后邮箱(商户号)
安全证书:下载银联证书(https://cs.cfca.com.cn/cgi-bin/userCertDownload/v_input.do;jsessionid=F38E0FBDD0BF8B32CBA6EF5F91DDC106?displayAgreement=true填入序列号和授权码--邮箱)并导出(填写密码)上传银联,上传Ping++
安全证书密码:上述密码
// 渠道费率 0
// 商户号
// 安全证书
// 安全证书密码
注意
Ping++ 一定要设置webhooks:填写支付成功/失败,退款后的回调地址。否则后台无法得知是否支付成功。
- 配置
cocoaPods
pod 'Pingpp'
默认会包含支付宝、微信、银联
可个性选择 pod 'Pingpp/Alipay' pod 'Pingpp/Wx'
Alipay(支付宝移动支付)
Wx(微信 App 支付)
QQWallet(QQ钱包 App 支付)
UnionPay(银联手机支付)
ApplePay
Fqlpay(分期乐)
Qgbc(量化派)
Mmdpay(么么贷)
CmbWallet(招行一网通)
BfbWap(百度钱包 Wap 支付)
Yeepay(易宝支付 Wap 支付)
Jdpay(京东支付 Wap 支付)
One(壹收款)
URL Schemes
1.添加自定义Sceme
// 用于支付宝返回本App/Ping++的kUrlScheme
项目 | Info | URL Types 添加URL Schemes
2.添加微信Scheme(不然跳不回应用)
白名单info.plist
<key>LSApplicationQueriesSchemes</key>
<array>
<string>weixin</string>
<string>wechat</string>
<string>alipay</string>
<string>alipays</string>
<string>mqq</string>
</array>
- AppDelegate
// 调试模式(有打印日志)
// [Pingpp setDebugMode:YES];
// 是否在 WAP 渠道中支付完成后,点击“返回商户”按钮,直接关闭支付页面
// [Pingpp ignoreResultUrl: YES];
// 从其他应用返回时调用
// iOS 9 及以后
- (BOOL)application:(UIApplication *)app
openURL:(NSURL *)url
options:(NSDictionary *)options {
BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
if (!result) {
BOOL canHandleURL = [Pingpp handleOpenURL:url withCompletion:nil];
return canHandleURL;
}
return result;
}
// iOS 9以前
- (BOOL)application:(UIApplication *)application
openURL:(NSURL *)url
sourceApplication:(NSString *)sourceApplication
annotation:(id)annotation {
BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url sourceApplication:sourceApplication annotation:annotation];
if (!result) {
// 其他如支付等SDK的回调
BOOL canHandleURL = [Pingpp handleOpenURL:url withCompletion:nil];
return canHandleURL;
}
return result;
}
//
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url{
//
BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
if (!result) {
// 其他如支付等SDK的回调
BOOL canHandleURL = [Pingpp handleOpenURL:url withCompletion:nil];
return canHandleURL;
}
return result;
}
- 调起支付
将商品信息,支付方式发送到后台 获取charge
调起支付
#import "Pingpp.h"
[AFNetWorkTool POST:url params:params success:^(NSURLSessionDataTask *task, id responseObject) {
if (SUCCESS) {
// 获取charge---字典
NSString *charge=responseObject[@"data"];
// kurlScheme (项目|info|urlScheme 填写scheme)
[Pingpp createPayment:charge
viewController:self
appURLScheme:kUrlScheme
withCompletion:^(NSString *result, PingppError *error) {
if ([result isEqualToString:@"success"]) {
// 支付成功
} else {
[YTHUD showError:@"支付失败"];
NSLog(@"Error: code=%lu msg=%@", error.code, [error getMsg]);
}
}];
}else{
[YTHUD showError:@"支付失败,请重试"];
}
} fail:^(NSURLSessionDataTask *task, NSError *error) {
[YTHUD showError:@"支付失败,请重试"];
NSLog(@"%@",error);
}];
其他
1.如果Xcode7编译失败,报如下错误:
XXXXXXX does not contain bitcode. You must rebuild it with bitcode enabled (Xcode setting ENABLE_BITCODE), obtain an updated library from the vendor, or disable bitcode for this target.
解决: 项目 | build Settings | Enable Bitcode 设为false
方式二: 微信/支付宝/银联
- 账号
1.
注册支付宝企业账号(账户邮箱)| 填写账户信息(登录密码,支付密码,安全问题)
| 企业实名认证(企业信息 ;营业执照,企业名称,企业名称,社会信用代码,单位所在地,住所,经营范围,营业期限,注册资本。;法定代表人:法定代表人归属地,法定代表人姓名,身份证号,证件有效期,填写人身份; 实际控制人:实际控制人归属地,实际控制人姓名,身份证号,证件有效期) ; 联系人手机号
| 证件照片
| 银行卡信息
2.1
蚂蚁金服支付宝开放平台
| 开发者中心 | 网页&移动平台 | 支付接入创建应用 | 添加功能(手机网站支付 | App支付)| 立即签约(添加相关信息) ->已生效 | 申请上线
2.2
RSA公钥密钥:https://docs.open.alipay.com/291/105971 下载自动生成RSA公钥密钥工具
公钥设置到:开发者中心 | 网页&移动平台 | 查看应用 | 应用信息 | 接口加签方式 | RSA2设置应用公钥
私钥:代码中用
1. 微信开发平台(注册开发账号)
2. 创建应用,提交审核(几小时内)
3. 申请开通微信支付功能(几个工作日)
银联
- 开发配置
支付宝
支付宝SDK下载地址
0.准备
项目 | Info | URL Types 添加URL Schemes 本应用 用于返回本App
白名单:。。。
导入SDK中的AlipaySDK.bundle,AlipaySDK.framework
导入系统依赖库如下图:
微信(没有网页版支付)
微信支付开发文档
0.准备
创建微信应用
导入微信SDK文件(如果集成了友盟,则不能再导入):
导入系统依赖库(在支付宝基础上+)如下:
libsqlite3.0.tbd
项目 | Info | URL Types 添加URL Schemes 微信Scheme
白名单:。。。
银联
SDK下载
0.准备
导入SDK:paymentcontrol文件夹下的文件
导入系统依赖库:
CFNetwork.framework、SystemConfiguration.framework 、libz、libPaymentControl.a
白名单:uppaysdk、uppaywallet、uppayx1、uppayx2、uppayx3
- 代码
AppDelegate+YTPay.h
#import "AppDelegate.h"
// 微信
#import "WXApi.h"
@interface AppDelegate (YTPay)<WXApiDelegate>
// 支付
-(void)setupAliPayWX;
@end
AppDelegate+YTPay.m
#import "AppDelegate+YTPay.h"
#pragma mark 支付:aliPay wx(友盟集成了) yl
// 支付宝
#import <AlipaySDK/AlipaySDK.h>
// 银联(下载SDK)
#import "UPPaymentControl.h"
#pragma mark 友盟
#import <UShareUI/UShareUI.h>
#import <UMSocialCore/UMSocialCore.h>
#import <UMSocialCore/UMSocialManager.h>
#import "UMSocialQQHandler.h"
#import "UMSocialWechatHandler.h"
#import "UMSocialSinaHandler.h"
#define wxAppID @"weixinKey"
@implementation AppDelegate (YTPay)
// 支付
-(void)setupAliPayWX{
// 添加友盟分享后,可不用再次注册
[WXApi registerApp:wxAppID];
}
// ios8及以下
-(BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation{
//
BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url sourceApplication:sourceApplication annotation:annotation];
if (!result) {
if ([url.host isEqualToString:@"safepay"]) {
[[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
NSLog(@"result = %@",resultDic);
}];
return YES;
} else if([url.host isEqualToString:@"pay"]){
return [WXApi handleOpenURL:url delegate:self];
}else{
[[UPPaymentControl defaultControl]handlePaymentResult:url completeBlock:^(NSString *code, NSDictionary *data) {
//
if([code isEqualToString:@"success"]) {
// success
}else if([code isEqualToString:@"fail"]) {
// failed
}else if([code isEqualToString:@"cancel"]) {
// cancel
}
}];
}
}
return result;
}
// ios9及以上
-(BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options{
//
BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url];
if (!result) {
if ([url.host isEqualToString:@"safepay"]) {
[[AlipaySDK defaultService] processOrderWithPaymentResult:url standbyCallback:^(NSDictionary *resultDic) {
NSLog(@"result = %@",resultDic);
}];
return YES;
} else if([url.host isEqualToString:@"pay"]){
return [WXApi handleOpenURL:url delegate:self];
}else{
[[UPPaymentControl defaultControl]handlePaymentResult:url completeBlock:^(NSString *code, NSDictionary *data) {
// sign —— 签名后做Base64的数据
// data —— 用于签名的原始数据,结构如下:
// pay_result —— 支付结果success,fail,cancel
// tn —— 订单号
if([code isEqualToString:@"success"]) {
// success
}else if([code isEqualToString:@"fail"]) {
// failed
}else if([code isEqualToString:@"cancel"]) {
// cancel
}
}];
}
}
return result;
}
#pragma mark WXApiDelegate
//
-(void)onReq:(BaseReq *)req{
}
// 支付一次(调用一次sendReq)后调用
-(void)onResp:(BaseResp *)resp{
//
switch (resp.errCode) {
case WXSuccess:{
// 以App服务器返回的信息为准
NSLog(@"支付成功");
}
break;
case WXErrCodeUserCancel:{
NSLog(@"用户取消");
}
break;
default:
// 签名错误、未注册APPID、项目设置APPID不正确、注册的APPID与设置的不匹配、其他异常等
NSLog(@"支付失败,retcode=%d",resp.errCode);
break;
}
}
@end
支付
// 支付宝/微信/银联
#import <AlipaySDK/AlipaySDK.h>
#import <WXApi.h>
#import "UPPaymentControl.h"
#pragma mark AliPay WXPay
-(void)aliPayWXPay{
将商品信息发给后台,后台加签,返回paramStr或paramDic
支付宝Alipay
// 后台返回
NSString *paramStr=@"";
[[AlipaySDK defaultService] payOrder:paramStr fromScheme:@"appScheme,在Info|URL Type中设置" callback:^(NSDictionary *resultDic) {
//
NSNumber *number = resultDic[@"resultStatus"];
if (number.integerValue == 9000) {
// success
} else if (number.integerValue == 6001) {
// cancel
} else {
// failed
}
}];
微信WX
// 该字典由后台返回
NSDictionary *paramDic=[NSDictionary new];
//
PayReq *req = [[PayReq alloc] init];
// 商户ID (注意参数名必须相同,否则无法跳转到微信)
req.partnerId = paramDic[@"partnerid"];
// 预支付订单ID(将商品信息传给后台后,后台调用预支付接口获得)
req.prepayId = paramDic[@"prepayid"];
// 唯一性随机字符串
req.nonceStr = paramDic[@"noncestr"];
// 时间戳
req.timeStamp = (UInt32)[paramDic[@"timestamp"] integerValue];
req.package = @"Sign=WXPay";
// 签名
req.sign = paramDic[@"sign"];
// 调起支付,回调见onResp
[WXApi sendReq:req];
// 结果回调在AppDelegate中,使用通知发送结果
银联
// 调起支付
[[UPPaymentControl defaultControl]startPay:@"交易流水号--将商品信息传给后台,由后台获得" fromScheme:@"本应用Scheme" mode:@"测试" viewController:self];
// 结果回调在AppDelegate中,使用通知发送结果
}
其他
支付模式
刷卡支付(线下面对面)
商家扫描 用户微信钱包内的“刷卡条码/二维码”
扫码支付
用户扫描 商家“二维码”
公众号支付
用户在微信的商户h5页面调起支付
APP支付(网页支付,调起支付App)
用户在移动应用中调起支付
内购
如果购买的是实物(商城类应用),就可以调用支付宝,微信啦,银联等三方支付。
如果购买的是虚拟物品(非实物,在本app中使用和消耗),就一定要用内购,否则会被拒绝上线。
例如:游戏币,在线书籍,虚拟金币,虚拟道具
内购要和苹果3/7分成。充值相同的钱,相对来说,iOS是比安卓吃亏的,但是用iOS毕竟土豪多。
网上有一篇专门介绍内购的,比较详细。
内购