集成银联3.3.0

简介:

项目最近需要集成银联,在网上搜了一下发现都并不是最新版的银联集成教程,自己摸索了一下,总结写了下来。

附上3.3.0的下载网址 https://open.unionpay.com/upload/download/手机控件支付开发包(IOS版)3.3.3.rar 文件解压后在 /app开发包/控件使用指南/ 可以得到官方写的开发文档, /app开发包/控件开发包/ 下可以得到demo和SDK,个人感觉官方文档写的很详细了……大家也可以自己结合文档和Demo自己试下。

一:环境配置 1、3.3.0的银联SDK和之前发生了变化,之前是UPPayPlugin.h UPPayPluginDelegate.h libUPPayPlugin.a一共三个文件,现在精简成UPPaymentControl.h libPaymentControl.a两个文件,当然方法也会有改变。新建工程的话直接将payment control文件夹导入。

_//顺便说一句,我下的Demo会报错的,原因是SDK并没有导入,大家遇到同样的问题可以将 /app开发包/控件开发包/upmpiphone/paymentcontrol 文件夹直接加到Demo里。

导入之后要在Build Settings --> Library Search Paths里对 libPaymentControl.a 路径设置,可以参考 demo,$(PROJECTDIR)/(这里写libs的上层文件夹,所有的==)/libs

2、添加:CFNetwork.framework、SystemConfiguration.framework 、lib系统框架到工程中;

3、 在工程info.plist设置中添加一个URL Types回调协议,用于在支付完成后返回商户客户端;

4、 在Xcode7.0之后的版本中进行开发,需要在工程对应的plist文件中,添加LSApplicationQueriesSchemes Array并加入uppaysdk、uppaywallet、uppayx1、uppayx2、uppayx3五个item。

        <key>LSApplicationQueriesSchemes</key>
             <array>
          <string>uppaysdk</string>
          <string>uppaywallet</string>
          <string>uppayx1</string>
          <string>uppayx2</string>
          <string>uppayx3</string>
             </array>

5、如果工程的compile source as 选项的值不是Objective–C++,则引用此头文件的文件类型都要改为.mm

二、支付方法: 1、- (BOOL)isPaymentAppInstalled 判断设备上是否安装了银联客户端。

2、 - (BOOL)startPay:(NSString)tn fromScheme:(NSString)schemeStr mode:(NSString)mode viewController:(UIViewController)viewController tn是交易流水号,从商户后台得到,商户把用户的订单信息提交给银联,银联返回交易流水号,我们只要从后台得到流水好,调用方法就行; schemeStr:完成支付后,返回自己的应用,在info里的URL types里设置; mode:固定字符串,测试环境@"01",正式软件版本@"00"; viewController:一般self就行。

3、- (void)handlePaymentResult:(NSURL*)url completeBlock:(UPPaymentResultBlock)completionBlock; 支付过程结束后在AppDelegate里使用,具体见Demo; code:字符串,success,cancel,fail简单易懂; data:用来校验签名。

  • (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"]) {
    
        //判断签名数据是否存在
        if(data == nil){
            //如果没有签名数据,建议商户app后台查询交易结果
            return;
        }
    
        //数据从NSDictionary转换为NSString
        NSData *signData = [NSJSONSerialization dataWithJSONObject:data
                                                           options:0
                                                             error:nil];
        NSString *sign = [[NSString alloc] initWithData:signData encoding:NSUTF8StringEncoding];
    
        //验签证书同后台验签证书
        //此处的verify,商户需送去商户后台做验签
        if([self verify:sign]) {
            //支付成功且验签成功,展示支付成功提示
        }
        else {
            //验签失败,交易结果数据被篡改,商户app后台查询交易结果
        }
    }
    else if([code isEqualToString:@"fail"]) {
        //交易失败
    }
    else if([code isEqualToString:@"cancel"]) {
        //交易取消
    }

    }];

    return YES; }

开发文档还提供了试用卡号、手机号等信息(此类信息仅供测试使用,不会发生真实交易)

招商银行借记卡:6226090000000048 手机号:18100000000 密码:111101 短信验证码:123456(先点获取验证码之后再输入) 证件类型:01身份证 证件号:510265790128303 姓名:张三 华夏银行贷记卡:6226388000000095 手机号:18100000000 CVN2:248 有效期:1219 短信验证码:123456(先点获取验证码之后再输入) 证件类型:01身份证 证件号:510265790128303 姓名:张三 以上就是银联的集成,很简单。

水平所限,有错误求指正。


目录
相关文章
|
安全 Windows
windows11 永久关闭windows defender的方法
windows11 永久关闭windows defender的方法
3228 2
|
8月前
|
人工智能 IDE Java
AI Coding实践:CodeFuse + prompt 从系分到代码
在蚂蚁国际信贷业务系统建设过程中,技术团队始终面临双重考验:一方面需应对日益加速的需求迭代周期,满足严苛的代码质量规范与金融安全合规要求;另一方面,跨地域研发团队的协同效率与代码标准统一性,在传统开发模式下逐渐显现瓶颈。为突破效率制约、提升交付质量,我们积极探索人工智能辅助代码生成技术(AI Coding)的应用实践。本文基于蚂蚁国际信贷技术团队近期的实际项目经验,梳理AI辅助开发在金融级系统快速迭代场景中的实施要点并分享阶段性实践心得。
1934 25
AI Coding实践:CodeFuse + prompt 从系分到代码
|
人工智能 Java Serverless
阿里云函数计算助力AI大模型快速部署
随着人工智能技术的快速发展,AI大模型已经成为企业数字化转型的重要工具。然而,对于许多业务人员、开发者以及企业来说,探索和利用AI大模型仍然面临诸多挑战。业务人员可能缺乏编程技能,难以快速上手AI模型;开发者可能受限于GPU资源,无法高效构建和部署AI应用;企业则希望简化技术门槛,以更低的成本和更高的效率利用AI大模型。
925 12
|
7月前
|
机器学习/深度学习 人工智能 前端开发
终端里的 AI 编程助手:OpenCode 使用指南
OpenCode 是开源的终端 AI 编码助手,支持 Claude、GPT-4 等模型,可在命令行完成代码编写、Bug 修复、项目重构。提供原生终端界面和上下文感知能力,适合全栈开发者和终端用户使用。
54857 11
|
Linux Android开发 iOS开发
深入探索Android与iOS的多任务处理机制
在移动操作系统领域,Android和iOS各有千秋,尤其在多任务处理上展现出不同的设计理念和技术实现。本文将深入剖析两大平台在后台管理、资源分配及用户体验方面的策略差异,揭示它们如何平衡性能与电池寿命,为用户带来流畅而高效的操作体验。通过对比分析,我们不仅能够更好地理解各自系统的工作机制,还能为开发者优化应用提供参考。
|
Java 开发工具 Android开发
搭建大型源码阅读环境——使用 OpenGrok
RTFSC 是程序员成长的必修课,营造舒适的环境至关重要。本文介绍了阅读大型源码(如 AOSP)的工具选择,重点推荐了免费开源的 OpenGrok。OpenGrok 提供快速搜索、版本历史查看、语法高亮等功能,适用于特大型项目。文章还详细讲解了 OpenGrok 的安装和配置步骤,帮助读者高效阅读源码。
3307 6
|
机器学习/深度学习 人工智能 算法
Nature子刊:大脑学习也靠反向传播?Hinton等用新一代反向传播算法模拟神经网络
反向传播作为一种基本负反馈机制,极大地推动了深度学习神经网络的发展。那么,反向传播也存在于人脑的运行方式中吗?反向传播的发明者Geoffery Hinton发Nature子刊告诉我们:人脑中存在类似于反向传播的神经机制,我用一种新算法类比出来了!
1223 0
Nature子刊:大脑学习也靠反向传播?Hinton等用新一代反向传播算法模拟神经网络
|
存储 缓存 NoSQL
Redis与数据库同步指南:订阅Binlog实现数据一致性
本文由开发者小米分享,探讨分布式系统中的一致性问题,尤其是数据库和Redis一致性。文章介绍了全量缓存策略的优势,如高效读取和稳定性,但也指出其一致性挑战。为解决此问题,提出了通过订阅数据库的Binlog实现数据同步的方法,详细解释了工作原理和步骤,并分析了优缺点。此外,还提到了异步校准方案作为补充,以进一步保证数据一致性。最后,提醒在实际线上环境中需注意日志记录、逐步优化和监控报警。
1910 3
|
消息中间件 Shell 数据处理
rocket mq 查看消费进度,消息堆积,清除堆积数据命令
该内容是关于RocketMQ的消费进度管理和堆积数据处理的指导。首先,需进入RocketMQ的bin目录,然后使用`mqadmin consumerProgress`命令查看消费者或生产者的消费进度。`broker offset`和`consumer offset`的差值表示未消费消息。通过`resetOffsetByTime`命令可重置消费位点来清除堆积数据,未消费消息默认3天后会被丢弃。此外,`CONSUME_FROM WHERE`枚举类定义了消费起点选项,包括从最后、最开始或指定时间点消费。
4583 3