跳到主要内容

简介

欢迎查阅 QFPay 开放API文档平台. 首先, 请阅读以下开发人员接入规范.

如果您想要在Postman快速测试支付功能, 我们提供了一套生成签名的预请求脚本, 您可以从这里下载该文件.

开发人员接入规范

备注

如果已经被提供 mchid , 除特殊情况下在呼叫API时必须提交 mchid. 换而言之, 如果并未被提供 mchid, 商户无需在API请求中传递参数 mchid.

为了使用QFPay 常用API, 您必须拥有已激活的API证书, 包括一个app_code以及client_key. 如遇到技术问题,请联系technical.support@qfpay.com.

对于应用程序的测试,我们提供了测试, 开发以及生产运行环境.

请注意:在沙盒环境进行的测试交易不会被结算. 因此请务必使用小笔金额测试并在原始交易日当天使用退款终端或是商户APP进行退款.

每个商户将会被提供一系列有或没有 mchidapp_codeclient_key , 拥有多个分支的商家通常会同时拥有 app_code , client_keymchid.经过哈希编码 (Hash encoded) 的 mchid 被用作辨别商店和网店.除此之外只有 app_codeclient_key 会被提供.

编码机制

所有从API返回的参数如无特别说明将使用 UTF-8 编码.

开发环境

注意

请谨记立即将在测试环境进行的交易退款

API环境

下表描述了对接每个环境的基本URL.

环境名称环境对应URL
沙盒环境 (只用于模拟信用卡)https://openapi-int.qfapi.com
线上测试环境https://test-openapi-hk.qfapi.com
生产环境https://openapi-hk.qfapi.com

签名机制

提示

如无特别要求,在HTTP头部一定要在 X-QF-SIGN 中提交签名

步骤1: 根据参数名称升序排序所有参数

参数列表: abc=value1 bcd=value2 bad=value3 排序结果: abc=value1 bad=value3 bcd=value2

步骤2: 以&作为分隔符拼接所有参数,获得用于签名的字符串

abc=value1&bad=value3&bcd=value2

步骤3: 在字符串的末尾拼接QFPay 的client_key.

abc=value1&bad=value3&bcd=value2Key

步骤4: 使用 MD5 或 SHA256 加密第三步得到的字符串, 推荐使用 SHA256.

MD5(abc=value1&bad=value3&bcd=value2Key) HASH(“SHA256”, abc=value1&bad=value3&bcd=value2Key)

步骤5: 使用签名请求API

将签名结果(密文)保存到http请求头部的X-QF-SIGN字段中;

For code instructions select Python, Java, Node.js or PHP with the tabs below.
# Create signature
def make_req_sign(data, key):
keys = list(data.keys())
keys.sort()
p = []
for k in keys:
v = data[k]
p.append('%s=%s'%(k,v))
unsign_str = ('&'.join(p) + key).encode("utf-8")
s = hashlib.md5(unsign_str).hexdigest()
return s.upper()


# Body payload
txamt = '10' # In USD,EUR,etc. Cent. Suggest value > 200 to avoid risk control
txcurrcd = 'HKD'
pay_type = '800101' # Alipay CPM = 800108 , MPM = 800101
auth_code='283854702356157409' #CPM only
out_trade_no = random_string
txdtm = current_time
goods_name = 'test1'
auth_code = '280438849930815813'
key = client_key
mchid = 'ZaMVg*****' # ID is provided during merchant onboarding


#data ={'txamt': txamt, 'txcurrcd': txcurrcd, 'pay_type': pay_type, 'out_trade_no': out_trade_no, 'txdtm': txdtm, 'goods_name': goods_name, 'udid': udid, 'auth_code': auth_code, 'mchid': mchid}
data ={'txamt': txamt, 'txcurrcd': txcurrcd, 'pay_type': pay_type, 'out_trade_no': out_trade_no, 'txdtm': txdtm, 'goods_name': goods_name, 'mchid': mchid}


r = requests.post(environment+"/trade/v1/payment",data=data,headers={'X-QF-APPCODE':app_code,'X-QF-SIGN':make_req_sign(data, key)})

print(make_req_sign(data, key))

上述指令会返回结构如下的JSON代码:

{
"B3B251B202801388BE4AC8E5537B81B1"
}

请求描述

备注

API将会返回JSON格式的响应内容.我们推荐开发者验证响应头部的签名以确保消息的完整性

名称描述
CharacterUTF-8
MethodPOST/ GET (视实际API功能而定)
Content-typeapplication/x-www-form-urlencoded

在请求API时HTTP头部所需的参数配置

名称是否必须描述
X-QF-APPCODE分配给开发者的app_code
X-QF-SIGN按照签名算法生成的签名
X-QF-SIGNTYPE生成签名的算法. 如果使用了 SHA256 , 开发者必须传SHA256,为空默认MD5.