澳门通(MPay) iOS集成

澳门通(MPay)


最近公司做了个项目 投放市场在澳门,澳门那边的支付环境主要使用澳门通(以下使用MPay代替),所以在做支付功能的时候,就有了MPay集成需求。初听到这个消息的时候,作为一名工作积极份子,立马开始了一顿猛如虎的操作——百度、谷歌、简书、GitHub等各大平台各种搜索,结果无奈的发现,均没有关于iOS MPay集成这方面的资料,可能是因为比较小众的缘故,咱忍了。

一脸懵逼

最后与MPay及澳方工作人员沟通,拿到了一份《澳門通線上收單支付接入規範v1.0.2》,洋洋洒洒 75 个Page,抱着诚恳与学习的态度,花了近1个小时才拜读完,看完之后,发现上面对于iOS MPay集成的可用信息几乎为零,顿时心中策马奔腾。

因为在澳门通集成过程中几经波折,也碰到过些坑,在完成之后,回头发现本来很简单的事情,因为不熟悉,以及在与澳方沟通过程花费了大量时间,所以将自己的血泪历程与MPay集成方法,以及碰到的坑,分享给大家,希望大家在开发过程中能节省点宝贵的时间及少趟点坑,权当抛砖引玉。

\color{red}{吁...停车!别再往下拉了,再拉你可能会错过可爱的我😊}

MPay 在打包静态库的时候,已经将 微信 打包进了SDK,所以如果项目在调用 微信 的时候,只能使用 MPay内部集成的 微信 支付,如果外界想要单独调用 微信支付的时候,在导入 微信 SDK的时候,就会报 重复导入 的错误。这是一个坑,要留意一下!

所以,以下分为三个步骤来说明 MPAy 支付,MPay调用 支付宝 ,MPay调用微信 。

\color{red}{先谈一下 MPay 的交互模式}
澳门通与商户之间通过交换报文与资料档案来交换业务资讯、实现业务流程、控制业务规则。双方的交互模式可以归纳为请求-应答、单向通知、文档上传与文档下载这四种模式,实际业务中可能会将各种交互模式结合起来使用。下文将介绍这四种交互模式适用的场景与实现方式。

1、请求(Request)-应答(Response)模式:

在请求-应答模式下,一方作为服务提供者,另一方作为服务使用者。由服 务使用者主动向服务提供者发起请求并等待应答,服务提供者接受请求,完成 处理,并向服务使用者应答处理结果,服务使用者收到处理结果之后进行后续 处理。

请求-应答模式适用于服务使用者需要根据服务提供者的服务应答才能进行 正确的后续处理的场景。 本文中,服务使用者指商户的系统设施及服务,服务提供者指澳门通及其相应 的系统设施及服务。


请求(Request)-应答(Response)模式
2、单向通知模式:

在单向通知模式下,一方作为通知发送者,一方作为通知接收者。发送者发送通知,并保证接收者收到通知。通知接收者在收到通知之后,立即返回发送者通知已收到。通知送达之后,发送方与接收方可以独立地进行后续业务处理。如果对方进行业务处理所需的时间不可预知时,采用单向通知模式。单向通知模式可以单独使用,也可以作为其它交互模式的一部分使用,因此,单向模式适用于澳门通主动通知商户交易处理成功。

单向通知模式


一:MPaySDK支付集成流程

1:由MPay iOS端提供的 MPaySDK.framework静态库引入到工程项目中(目前不支持Cocopods);
MPaySDK.framework

在需要支付的类中导入 #import <MPaySDK/MPaySDK.h> 文件路径

2:Command+B 编译一下,报错导入以下类:

libsqlite3.tbd

libc++.tbd

libz.tbd

libc.tbd

CoreMotion.framework

CFNetwork.framework

SystemConfiguration.framework

CoreTelephony.framework

QuartzCore.framework

CoreText.framework

CoreGraphics.framework

Foundation.framework

UIKit.framework

编译,完美通过

3:Target - info -URL Types 配置URL Types 设置自己项目的URL Schems,以便调用SDK方法的时候使用
URL Schemes

因为UAT测试环境,生产环境服务器的https应用层不
支持ATS设置,如果应用程式基于9.0编译,由于iOS9.0中https应用程序传输安全(ATS)的限制,我们需要设置:NSAppTransportSecurity 的 Allow Arbitrary Loads 为 YES

4、支付环境设置

在MPaySDK.h文件中可以查看环境变量的枚举值

0:MPay_SIT 代表MPay SIT 环境

1: MPay_UAT 代表MPay UAT环境

2:MPay_Prod 代表MPay 生产环境

通过实例方法进行UAT环境配置
例:[[MPaySDKsharedInstance] setEnvironmentType:MPay_UAT];

5、支付方法调用
/**
 商戶使用(MPay)
 
 @param params 商戶簽名后的订單數據
 @param schema 商戶APP的url schema
 @param sender  當前控制器
 @param delegate 實現協議方法的代理對象
 */
-(void)MPayWithParams:(NSDictionary *)params withSchema:(NSString *)schema WithSender:(id)sender withDelegate:(id<MPaySDKDelegate>)delegate;
6、params 参数说明
参数 类型 是否必填 最大长度 描述 示例值
app_id String 必须 32 MacauPay分配给开发者的应用ID 2014072300007148
api_name String 必须 30 接口名称 preCreate
biz_api_code String 必须 30 接口功能 100020007
data_type String 可选 40 仅支持JSON JSON
charset String 必须 10 请求使用的编码格式,如utf-8,gbk,gb2312等 utf-8
sign_type String 必须 10 商户生成签名字符串所使用的签名算法类型,目前支持RSA RSA
sign String 必须 256 商户请求参数的签名串,详见签名 详见示例,6.4.私钥生成请求签名章节
timestamp String 必须 19 发送请求的时间,格式"yyyy-MM-dd HH:mm:ss" 2014-07-24 03:07:50
version String 必须 3 调用的接口版本,固定为:1.0 1.0
biz_content String 必须 - 请求参数的集合,最大长度不限,除公共参数外所有请求参数都必须放在这个参数中传递,具体参照各产品快速接入文档 参考下面

● biz_content 说明

参数 类型 是否必填 最大长度 描述 示例值
out_trade_no String 必须 64 商户订单号,64个字符以内、只能包含字母、数字、下划线;需保证在商户端不重复 20150320010101001
total_amount Price 必须 9 订单总金额,单位为元,精确到小数点后两位,取值范围[0.01,100000000] 88.88
subject String 必须 256 订单标题 Iphone6 16G
trade_mode String 必须 10 0001担保支付,0002即时到账,默认:0002 0002即时到账
body String 可选 128 对交易或商品的描述 Iphone6 16G
buyer_logon_id String 可选 100 买家MacauPay账号,和 buyer_user_id不能同时为空 15901825620
buyer_user_id String 可选 28 买家在MacauPay的用户id 2088101117955611
operator_id String 可选 28 商户操作员编号 Yx_001
store_id String 可选 32 商户门店编号 NJ_001
terminal_id String 可选 32 商户机具终端编号 NJ_T_001
timeout_express String 可选 6 该笔订单允许的最晚付款时间,逾期将关闭交易。取值范围:1m~15d。m-分钟,h-小时,d-天,1c-当天(1c-当天的情况下,无论交易何时创建,都在0点关闭)。该参数数值不接受小数点,如 1.5h,可转换为 90m。默认90m 90m
submerchant_id String 可选 32 二级商户号,与MacauPay约定按照MCC收手续费时使用 2016041400077000000003314986
currency String 可选 6 默认MOP MOP
notify_url String 可选 256 MacauPay服务器主动異步通知商户服务器里指定的页面http/https路径。 http://api.test.net/atinterface/receive_n
return_url String 可选 256 MacauPay服务器主动同步通知商户服务器里指定的页面http/https路径。 http://api.test.net/atinterface/receive_n
goods_detail GoodsDetail [] 可选 - 订单包含的商品列表信息.Json格式. 其它说明详见:“商品明细说明” [{"order_no":"201604141231231231231222","goods_id":"apple-01","goods_name":"ipad","goods_category":"7788230","price":"2000.00","quantity":"1"}]
order_no String 必填 64 商品明细订单号 2016041400077000000003
goods_id String 必填 32 商品的编号 apple-01
goods_name String 必填 256 商品名称 ipad
quantity Number 必填 10 商品数量 1
price Price 必填 9 商品单价,单位为元 2000
body String 可选 1000 商品描述信息 特价手机
show_url String 可选 400 商品的图片地址 http://www.alipay.com/xxx.jpg
7、方法具体实现:
//签名地址    - 要改成贵公司服务器 api 地址

NSString*signUrl =  @"xxxx";

//签完名之后拿到服务器返回的NSDictionary类型数据,作为参数

//調起支付

        if(params) {

            [[MPaySDK sharedInstance]MPayWithParams:params withSchema:@"macaupayF2823" WithSender:self withDelegate:self];

        }
8、在响应事件 控制器中遵循代理协议
@interface ViewController ()<MPaySDKDelegate>

实现代理方法
//实现支付完成或者取消之后的回调结果(注意兼容ios8的方法)
//在需要处理结果的地方实现MPaySDKDelegate协议方法 处理展示结果逻辑

/**

 支付成功回调

@paramstatus 支付狀態標誌 true成功 false 失敗

@paramorder 訂單信息

 */

-(void)MPaySDK_WithPayStatus:(bool)status WithOrder:(NSDictionary*)order;

/**

 支付失败回调

@paramerrorInfo 錯誤信息

@paramerrorCode 錯誤碼

 */

-(void)MPaySDK_WithFailed:(NSString*)errorInfo withErrorCode:(NSString*)errorCode;
9、支付回调及响应状态

在项目AppDelegate.m里面的回调方法

-(BOOL)application:(UIApplication*)app openURL:(NSURL*)url options:(NSDictionary *)options{

   //里面调用

    [[MPaySDK sharedInstance]ProcessOrderWithPaymentResult:url];

    return true;

}

-(BOOL)application:(UIApplication*)application openURL:(NSURL*)url sourceApplication:(NSString*)sourceApplication annotation:(id)annotation

{

    //回调方法,必調

    [[MPaySDK sharedInstance] ProcessOrderWithPaymentResult:url];

    return true;

}
10、支付状态码
Code ResultMsg
9000 订单支付成功
6002 网络连接出错
6001 用户中途取消
5000 支付异常
4044 訂單金額無效
4004 无效订單
4000 订单支付失败
1000 簽名失敗
0001 手續費大於交易金額
1002 數據格式錯誤

二:AliPaySDK支付集成流程


AliPay 和 MPay 前期配置相同,导入MPaySDK.framework静态库,并且需要导入AliPaySDK 包文件,只不过支付方法和 上传参数,这里只说明有区别的点,其它参考 上面 MPay,AliPaySDK支付状态码参考同MPaySDK支付状态码

1、支付方法调用
  /**

      商户使用(支付宝)

      @paramparams 商戶簽名后的訂單數據

      @paramScheme 商戶APP的url schema

      @paramdelegate 實現協議方法的代理對象

      */
-(void)AliPayWithParams:(NSDictionary*)params withScheme:(NSString*)Scheme with:(id)delegate;
2、params参数说明
参数 类型 是否必填 最大长度 描述 示例值
app_id String 必须 32 MacauPay分配给开发者的应用ID 2014072300007148
api_name String 必须 30 接口名称 aliNoAccPay
biz_api_code String 必须 30 接口功能 100020008
data_type String 可选 40 仅支持JSON JSON
charset String 必须 10 请求使用的编码格式,如utf-8,gbk,gb2312等 utf-8
sign_type String 必须 10 商户生成签名字符串所使用的签名算法类型,目前支持RSA RSA
sign String 必须 256 商户请求参数的签名串,详见签名 详见示例,6.4.私钥生成请求签名章节
timestamp String 必须 19 发送请求的时间,格式"yyyy-MM-dd HH:mm:ss" 2014-07-24 03:07:50
version String 必须 3 调用的接口版本,固定为:1.0 1.0
biz_content String 必须 - 请求参数的集合,最大长度不限,除公共参数外所有请求参数都必须放在这个参数中传递,具体参照各产品快速接入文档 参考下面

● biz_content 说明
参考macauPay的参数说明

3、方法具体实现:
//a、签名地址    - 要改成贵公司服务器 api 地址

NSString*signUrl =  @"xxxx";

//b、签完名之后拿到服务器返回的NSDictionary类型数据,作为参数

//調起支付

        if(params) {

            [[MPaySDK sharedInstance] AliPayWithParams:params withScheme:@"macaupayF2823" with:self];

        }

三:WechatPaySDK支付集成流程


由MPay iOS端提供的sdk文件,MPaySDK.framework 静态库引用到工程项目中(如果已经引入,无需重复引入):并且需要导入WechatPay支付所需要的文件和静态库:libWeChatSDK.a, WechatAuthSDK.h, WXApi.h, WXApiObject.当已经再开放平台已经注册应用并且报备之后,再项目工程里面的AppDelegate.h文件中导入的WXApi.h ,并且在didFinishLaunchingWithOptions 方法中向微信发起注册:

例:[WXApi registerApp:@"xxxx" enableMTA:NO];

在需要支付的类中导入MPaySDK.h文件路径即可。

1、支付方法调用
/**

 商户使用(微信)

 @paramparams 商戶簽名后的訂單數據

 @paramScheme 商戶APP在開放平台註冊的appid

 @paramdelegate 實現協議方法的代理對象

 */

-(void)WeChatPayWithParams:(NSDictionary*)params withScheme:(NSString*)Scheme with:(id)delegate;
2、params参数说明
参数 类型 是否必填 最大长度 描述 示例值
appid String 必须 32 微信分配给开发者的应用ID wxb4ba3c02aa476ea1
partnerid String 必须 32 商户号 1900000109
package String 必须 128 扩展字段 Sign=WXPay
noncestr String 可选 32 随机字符串 5K8264ILTKCH16CQ2502SI8ZNMTM67VS
timestamp String 必须 10 时间戳 1412000000
prepayid String 必须 32 预支付交易会话ID 微信返回的支付交易会话ID
sign String 必须 32 签名 C380BEC2BFD727A4B6845133519F3AD6
3、方法具体实现:
//a、签名地址    - 要改成贵公司服务器 api 地址

NSString*signUrl =  @"xxxx";

//b、签完名之后拿到服务器返回的NSDictionary类型数据,作为参数

//調起支付

        if(params) {

            [[MPaySDK sharedInstance] WeChatPayWithParams:params withScheme:@"macaupayF2823" with:self];

        }
4、支付回调及响应状态

参考同MPaySDK支付回调及响应状态

5、支付状态码
ResultStatus Result
9000 訂單支付成功
6001 用戶中途取消
6005 微信支付:簽名錯誤、未註冊APPID、項目設置APPID不正確、註冊的APPID與設置的不匹配、其他異常等.

以上就是 MPay iOS端集成的全部过程,如有疑问欢迎留言指正。😀


©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容