近期,公司项目需要集成支付业务(支付宝,微信,建行龙支付),对于支付宝、及微信就不做总结了,毕竟网络上参考资料太多了。今天主要说一下集成建行支付,在开始之前先吐槽一下建行的集成文档那叫一个烂啊!好吧!不说了,开始啦!
以下对建行支付的字段进行介绍:分为必要及非必要的;
//必要字段 @property (copy, nonatomic) NSString *MERCHANTID ;//商户代码 (*重要的) @property (copy, nonatomic) NSString *POSID;//商户柜台代码(*重要的) @property (copy, nonatomic) NSString *BRANCHID;//分行代码(*重要的) @property (copy, nonatomic) NSString *ORDERID;//订单号:由商户提供,最长30位 @property (copy, nonatomic) NSString *PAYMENT;//付款金额:由商户提供,按实际金额给出 @property (copy, nonatomic) NSString *CURCODE;//币种,01表示人民币:01 @property (copy, nonatomic) NSString *TXCODE;//交易码 由建行统一分配为520100 @property (copy, nonatomic) NSString *REMARK1; @property (copy, nonatomic) NSString *REMARK2; @property (copy, nonatomic) NSString *TYPE;//接口类型:1 @property (copy, nonatomic) NSString *PUB;//公钥后30位(*重要的) @property (copy, nonatomic) NSString *GATEWAY; //网关类型 @property (copy, nonatomic) NSString *CLIENTIP;//客户端IP @property (copy, nonatomic) NSString *REGINFO;//客户注册信息 @property (copy, nonatomic) NSString *PROINFO;//客户购买的商品 @property (copy, nonatomic) NSString *REFERER; //商户URL
//非必要字段 @property (copy, nonatomic) NSString *INSTALLNUM;//银行代码3 @property (copy, nonatomic) NSString *SMERID;//二级商户代码111 @property (copy, nonatomic) NSString *SMERNAME;//二级商户名称 @property (copy, nonatomic) NSString *SMERTYPEID;//二级商户类别代码112 @property (copy, nonatomic) NSString *SMERTYPE;//二级商户类别名称 @property (copy, nonatomic) NSString *TRADECODE;//交易类型代码001 @property (copy, nonatomic) NSString *TRADENAME;//交易类型名称 @property (copy, nonatomic) NSString *SMEPROTYPE;//商品类别代码1 @property (copy, nonatomic) NSString *PRONAME;//商品类别名称 @property (copy, nonatomic) NSString *THIRDAPPINFO; //客户端标识 @property (copy, nonatomic) NSString *TIMEOUT;//订单超时时间例:20161028101226 @property (copy, nonatomic) NSString *ISSINSCODE;//银行代码ICBC
另外还有一个特殊字段:THIRDAPPINFO,该字段有值的情况下,系统会优先调用app进行支付,在app未安装的情况下才会进行H5页面支付,将该字段值设置为你的应用程序的URL Schemes,否则支付成功后返回不到你的APP。
@property (copy, nonatomic) NSString *THIRDAPPINFO; //客户端标识
以上均是必须参与摘要的字段,将以上字段进行拼接得到需加密字符串String。打印如下:
MERCHANTID=123456789&POSID=000000000&BRANCHID=110000000&ORDERID=19991101234&PAYMENT=0.01&CURCODE=01&TXCODE=520100&REMARK1=&REMARK2=&TYPE=1&GATEWAY=&CLIENTIP=172.0.0.1®INFO=%u5C0F%u98DE%u4FA0&PROINFO=%u5145%u503C%u5361&REFERER=nihao
最后来说下MAC字段:MAC是由对String进行MD5加密得到;
//MD5加密 NSString *MAC = [MD5 MD5:String];
最后进行拼接完整字符串:在String后添加MAC字段值:如下:
https://ibsbjstar.ccb.com.cn/CCBIS/ccbMain?MERCHANTID=123456789&POSID=000000000&BRANCHID=110000000&ORDERID=19991101234&PAYMENT=0.01&CURCODE=01&TXCODE=520100&REMARK1=&REMARK2=&TYPE=1&GATEWAY=&CLIENTIP=®INFO=%u5C0F%u98DE%u4FA0&PROINFO=%u5145%u503C%u5361&REFERER=nihao&MAC=得到的加密值
在plist中进行配置
URL types:设置URL Schemes
webView发起支付请求:
- (void)loadWithUrlStr:(NSString*)urlStr { if (urlStr.length > 0) { dispatch_async(dispatch_get_main_queue(), ^{ NSURLRequest *webRequest = [NSURLRequest requestWithURL:[NSURL URLWithString:urlStr] cachePolicy:NSURLRequestReturnCacheDataElseLoad timeoutInterval:30]; [self.webView loadRequest:webRequest]; }); } } #pragma mark ============== webview相关 回调及加载 ============== - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType { NSLog(@"%@",request.URL.absoluteString); //简单的请求拦截处理 NSString *strM = request.URL.absoluteString; if ([strM containsString:@"mbspay"]) { [[UIApplication sharedApplication]openURL:[NSURL URLWithString:strM] options:@{} completionHandler:nil]; return NO; } return YES; }
使用上面的H5支付方式,出现了一些设备调不出建行APP进行支付,建行又给了新的解决方案:使用SDK文档。
请求参数跟上面的一样,不再进行说明:
第一步:
把 iOS 包中的压缩文件中以下文件(CCBNetPaySDK.framework,libWeChatSDK.a)拷贝到项目文件夹下,并导入到项目工程中(图 1)。并检查是否引用CCBNetPaySDK、libWeChatSDK.a (图 2)(如果项目中已有引用微信的 libWeChatSDK.a,则无需再导入 libWeChatSDK.a 文件,项目中也不用导入 WXApi.h 和 WXApiObject.h 文件,直接应用 CCBNetPaySDK.framework 中的 WXApi.h 和 WXApiObject.h 文件即可,如图 3)如需调用微信支付,则需另外配置 scheme (从微信开发平台注册 app 得到的 APPID),配置 APP 跳转后返回 scheme(商品参数THIRDAPPINFO,如图4)
图1:
图2:
图3:
第二步:调用SDK支付接口
首先,在需要调用 CCBNetPaySDK 的文件中,增加头文件引用。
然后选择相应的支付方法
支付方法列表:CCBNetPay.h 类接口主要为商户提供订单龙支付支付功能。
第三步:支付结果获取及处理
二、建行支付常见问题汇总
1、SDK 不能跳转至手机银行。
2、支付完成不能跳转回APP
3、支付完成能跳转回 APP,但是收不到返回信息。
4、Code=-1002 "unsupported URL"
5、ERRORCODE = 0130Z110C100
提示:密钥有问题,请检查密钥。
6、支付成功后点击完成返回结果 code = -1
提示:
是否为一订单号支付成功后在短时间内再次支付。