0.3.0 • Published 10 years ago
paypalm v0.3.0
pp钱包支付SDK
pp钱包支付回调
异步回调是get请求。
成功支付的同步回调是post请求,以表单形式。
支付失败的同步回调是post请求,以表单形式。
pp钱包支付回调有一个坑:wap的回调数据与native SDK回调的数据不一样,数据格式也不一样(native SDK回调的数据格式为xml)
pp钱包支付分两步:
- 订单入库->获取pp钱包支付平台的订单号
- 订单支付请求->通过第一步获取的订单号,加上商户支付信息组装成一条支付url(地址)
截止作者写SDK时,pp钱包支付的Native SDK只有Android
安装
npm install paypalm
API
获取pp钱包支付url,异步方法
var paypalm = require('paypalm');
var config = {
'MER_ID': "",//pp钱包商户号
'KEY': "",//商户秘钥
'WAP_KEY': "",//预制密钥->wap获取支付链接时,需要使用该密钥进行实名信息加密
"PAY_API_URL":"https://www.paypalm.cn/bfsmob/http"//订单入库以及支付地址
}
var paypalmObj = new paypalm(config);
var data = {
merUserId:"",//用户在商户系统的用户id
merOrderNo:'',//商户订单号
payAmt:1,//支付金额,分为单位
orderDesc:'',//订单描述
returnUrl:'http://navy.test.com',//同步回调地址
notifyUrl:'http://navy.test.com',//异步回调地址
userId:"",//用户在商户系统的注册手机号
phone:"",//银行预留手机号
cardNum:"",//用户银行卡号
idCard:"",//用户身份证
accName:""//用户姓名
}
paypalmObj.getPayUrl(data,
function(err,url){
if(!err){
console.log(url);//url为去pp钱包支付的地址
}
}
)
验证支付是否成功(已对数据进行验签),异步方法
//wap异步回调数据
var wapNotifyData = {
merId: '',
merOrderNo: 'navy_test-1438580789182',
merUserId: '',
orderNo: '',
orderStatus: '1',
payAmt: '1',
resultInfo: 'success',
tranResult: '000000',
transTime: '20150803134548',
remark: 'undefined',
sign: ''
}
paypalmObj.paySuccess(wapNotifyData,function(err,data){
if(!err && data.code === 0){
//已完成支付可执行订单更新或者发货了
}
});
//Native SDK 异步回调数据(截止作者写SDK时,pp钱包支付的Native SDK只有Android)
var nativeNotifyData = {
merId: '2014123015',
version: 'v1.0',
encode: 'UTF-8',
encType: '1',
signType: '1',
zipType: '0',
transData:''//transData为需要进行解密以及验签的加密数据
}
paypalmObj.paySuccess(nativeNotifyData,function(err,data){
if(!err && data.code === 0){
//已完成支付可执行订单更新或者发货了
//对于Native SDK的支付,可以从data获取回调后的解密数据
//data解析后的数据结构:
<!-- {
merId: '',
merOrderNo: '55bf24e573b942b35bbaaa1a',
orderNo: '',
payAmt: '1',
remark: 'SDK2.0',
userId: '',
transTime: '20150803162548',
bankId: '',
bankName: '建设银行',
orderStatus: '1',
errorCode: '000000',
errorMsg: 'success',
merUserId: '1438590186170',
bindId: ''
} -->
//respone to paypalm paypalmObj.getStopNotifyData()
}
});
获取终止pp钱包异步回调的相应字符串
注:当向pp钱包相应此字符串时,代表商户已经成功处理回调,pp钱包将终止异步回调。
//wap异步回调数据
res.send(paypalmObj.getStopNotifyData());
认证信息是否正确(未被篡改),返回boolean值或者字符串,同步方法
注:wap支付回调时验签返回boolean,Native回调验签成功时返回xml字符串,失败返回boolean: false
//wap异步回调数据
var wapNotifyData = {
merId: '',
merOrderNo: 'navy_test-1438580789182',
merUserId: '',
orderNo: '',
orderStatus: '1',
payAmt: '1',
resultInfo: 'success',
tranResult: '000000',
transTime: '20150803134548',
remark: 'undefined',
sign: ''
}
if(paypalmObj.verify(wapNotifyData)){
//验签通过,数据未被篡改
}
//Native SDK 异步回调数据(截止作者写SDK时,pp钱包支付的Native SDK只有Android)
var nativeNotifyData = {
merId: '2014123015',
version: 'v1.0',
encode: 'UTF-8',
encType: '1',
signType: '1',
zipType: '0',
transData:''//transData为需要进行解密以及验签的加密数据
}
if(paypalmObj.verify(nativeNotifyData)){
//验签通过,数据未被篡改
}