这几天在弄nodejs和微信支付的对接,弄了好几天终于接通了,最大的问题就是签名参数的大小写问题,支持公众号支付和扫码支付两种方式
扫码支付
1.先通过POST请求微信支付的统一下单接口
https://api.mch.weixin.qq.com/pay/unifiedorder
exports.pay = function (req, res)
{
var url = "https://api.mch.weixin.qq.com/pay/unifiedorder";
var appid = _appid;
var mch_id = _mch_id;
var notify_url = _notify_url;
var out_trade_no = _out_trade_no;
var total_fee = _total_fee;
var attach = _attach;
var body = _body;
var nonce_str = _nonce_str;
var formData = "<xml>";
formData += "<appid>"+appid+"</appid>"; //appid
formData += "<attach>"+attach+"</attach>"; //附加数据
formData += "<body>"+body+"</body>"; //商品或支付单简要描述
formData += "<mch_id>"+mch_id+"</mch_id>"; //商户号
formData += "<nonce_str>"+nonce_str+"</nonce_str>"; //随机字符串,不长于32位
formData += "<notify_url>"+notify_url+"</notify_url>"; //支付成功后微信服务器通过POST请求通知这个地址
formData += "<openid></openid>"; //扫码支付这个参数不是必须的
formData += "<out_trade_no>"+out_trade_no+"</out_trade_no>"; //订单号
formData += "<spbill_create_ip></spbill_create_ip>"; //不是必须的
formData += "<total_fee>"+total_fee+"</total_fee>"; //金额
formData += "<trade_type>NATIVE</trade_type>"; //NATIVE会返回code_url ,JSAPI不会返回
formData += "<sign>" + paysign(appid,attach,body,out_trade_no,nonce_str,notify_url, '', out_trade_no,'', total_fee, 'NATIVE') + "</sign>";
formData += "</xml>";
request(
{
url : url,
method : 'POST',
body : formData
}, function (err, response, body)
{
if (!err && response.statusCode == 200)
{
console.log(body);
var prepay_id = getXMLNodeValue('prepay_id', body.toString("utf-8"));
var tmp = prepay_id.split('[');
var tmp1 = tmp[2].split(']');
var code_url = getXMLNodeValue('code_url', body.toString("utf-8"));
var tmp = code_url.split('[');
var tmp3 = tmp[2].split(']');
res.render('pay',
{
prepay_id : tmp1[0],
code_url : tmp3[0]
}
);
}
}
);
}
签名加密算法
function paysign(appid,attach,body,mch_id,nonce_str,notify_url,openid,out_trade_no,spbill_create_ip,total_fee,trade_type) {
var ret = {
appid: appid,
attach: attach,
body: body,
mch_id: mch_id,
nonce_str: nonce_str,
notify_url:notify_url,
openid:openid,
out_trade_no:out_trade_no,
spbill_create_ip:spbill_create_ip,
total_fee:total_fee,
trade_type:trade_type
};
var string = raw(ret);
var key = _key;
string = string + '&key='+key; //key为在微信商户平台(pay.weixin.qq.com)-->账户设置-->API安全-->密钥设置
var crypto = require('crypto');
return crypto.createHash('md5').update(string,'utf8').digest('hex');
};
function raw(args) {
var keys = Object.keys(args);
keys = keys.sort()
var newArgs = {};
keys.forEach(function (key) {
newArgs[key.toLowerCase()] = args[key];
});
var string = '';
for (var k in newArgs) {
string += '&' + k + '=' + newArgs[k];
}
string = string.substr(1);
return string;
};
2.通过返回回来的XML解析出code_url,就可以通过js生成二维码图片在PC端,用户使用微信扫一扫即可完成付款,完成付款后,微信服务器会发送一个POST请求到notify_url的地址,然后通过返回的xml来判断是否付款成功
网友评论