最近开发的项目之中用到的银行卡支付,于是参考网上的一些资料,摸索集成了银联支付的功能 ,在此分享给大家.
下面是银行给的流程图
流程图说明:
(1)用户在客户端中点击购买商品,客户端发起订单生成请求到商户后台;
(2)商户后台收到订单生成请求后,按照《手机控件支付产品接口规范》组织并推送订单信息至银联后台;
(3)银联后台接收订单信息并检查通过后,生成对应交易流水号(即TN),并回复至商户后台(应答要素:交 易流水号等);
(4)商户后台接收到交易流水号(TN),将交易流水号返回至客户端;
(5)客户端通过交易流水号(TN)调用支付控件;
(6)用户在支付控件中输入相关支付信息后,由支付控件向银联后台发起支付请求;
(7)支付成功后,银联后台将支付结果通知给商户后台;
(8)银联后台同时也将支付结果通知支付控件;
(9)支付控件显示支付结果并将支付结果返回至客户端;
第一步: 去银联支付官方SDK下载地址:https://open.unionpay.com/ajweb/help/query 下载SDK,然后导入里面paymentcontrol文件夹(demo里面没有把paymentcontrol 文件夹拖进去,需要拖进去了才能运行,这个是有点坑爹的)
第二步:我们在工程的Build Phases里添加所需的依赖库,分别是:
CFNetwork.framework
SystemConfiguration.framework
libz
libPaymentControl.a
第三步: 我们在工程info.plist设置中添加一个URL Types,如图所示:
第四步:因为在Xcode7.0之后的版本中进行http请求时,需要在工程对应的plist文件中添加App Transport Security Settings并同时设置里面Allow Arbitrary Loads 属性值为 YES;
还要在info.plist里添加白名单
<key>LSApplicationQueriesSchemes</key>
<array>
<string>uppaysdk</string>
<string>uppaywallet</string>
<string>uppayx1</string>
<string>uppayx2</string>
<string>uppayx3</string>
</array>
第五步: 如果直接编译会报错的,因为如果工程的compile source as 选项的值不是Objective–C++,则引用此头文件的文件类型都要改为.mm
第六步: 处理支付回调事件
在AppDelegate.m
- (BOOL) application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation {
//处理支付结果
[[UPPaymentControl defaultControl] handlePaymentResult:url completeBlock:^(NSString *code, NSDictionary *data) {
//结果code为成功时,先校验签名,校验成功后做后续处理
if([code isEqualToString:@"success"]) {
//数据从NSDictionary转换为NSString
NSDictionary *data;
NSData *signData = [NSJSONSerialization dataWithJSONObject:data
options:0
error:nil];
NSString *sign = [[NSString alloc] initWithData:signData encoding:NSUTF8StringEncoding];
//判断签名数据是否存在
if(data == nil){
//如果没有签名数据,建议商户app后台查询交易结果
return;
}
//验签证书同后台验签证书
//此处的verify,商户需送去商户后台做验签
if([self verify:sign]) {
//支付成功且验签成功,展示支付成功提示
}
else {
//验签失败,交易结果数据被篡改,商户app后台查询交易结果
}
}
else if([code isEqualToString:@"fail"]) {
//交易失败
}
else if([code isEqualToString:@"cancel"]) {
//交易取消
}
}];
return YES;
}
-(BOOL) verify:(NSString *) resultStr {
//验签证书同后台验签证书
//此处的verify,商户需送去商户后台做验签
return NO;
}
第七步:在控制器ViewController.mm 实现功能
-
(IBAction)pay:(id)sender {
//开始支付
/**- 支付接口
- @param tn 订单信息:找服务器要。
- @param schemeStr 调用支付的app注册在info.plist中的scheme
- @param mode 支付环境
- @param viewController 启动支付控件的viewController
- @return 返回成功失败
*/
[[UPPaymentControl defaultControl]
startPay:@"201810261856181495528"
fromScheme:@"PayProjectScheme://com.ww.cn"
mode:@"01"
viewController:self];
}