美文网首页程序员
node.js实现微信公众号支付(统一下单+回调通知)

node.js实现微信公众号支付(统一下单+回调通知)

作者: 飘渺阿天 | 来源:发表于2018-03-23 16:58 被阅读929次

前言:公司业务逻辑,前后端分离,node.js负责处理一些支付逻辑;

配置那些这里就不讲了(因为不是我配置的)直接从吊起支付开始,上流程图,微信商户平台>开发文档>公众号支付>业务流程

流程.png

从第4步开始,首先创建你自己公司的订单,存到数据库里,上代码

var coll_name = 't_board';//数据库表名
var api_uri = '/' + coll_name + '/0';
var cur_timestamp = Math.floor((new Date()).getTime() / 1000);
var body_str = JSON.stringify(req.body);
var token = utils.generateAccessToken(
    module_db_crud_request_headers.ApiCalleeId
    , module_db_crud_request_headers.ApiAccessKey
    , cur_timestamp, api_uri, body_str, SECRET_KEY
);
module_db_crud_request_headers.ApiTimestamp = cur_timestamp;
module_db_crud_request_headers.ApiToken = token;
request({
     //主要是发这个请求,具体参数都是公司内部的API调用的要求
    uri: CONFIG.API_ADDRESS + module_db_crud_request_headers.ApiCalleeId + api_uri,
    method: 'POST',
    timeout: 5000,
    followRedirect: false,
    headers: module_db_crud_request_headers,
    body: body_str,
}, function(error, response, body) {
    if (error) {
        console.log(error);
        return next(utils.new_err(response.statusCode, body));
    }
    if (response.statusCode != 200) {
        return next(utils.new_err(response.statusCode, body));
      }
      try {
        var jdata = JSON.parse(body);

        res.dp_result = jdata;

        next();下一步
        // go next ===>
    } catch (e) {
        return next(utils.new_err(500, 'JSON.parse exception'));
    }
});

别慌到这里,你们公司的订单已经完成,基本的订单信息,都应该会返回回来的。接下来调起微信支付

接下来是重点!

1.ip的获取。

2.订单的id,公众号的id。

3.参数的拼接和发送。

1.ip的获取

百度上一堆,由于我们公司用的中间件来管理API所以这个,得需要前端来拿到用户的IP地址,这里需要的实际的IP地址

2.订单的id,公众号的id。

订单的id在你创建完公司的内部订单就直接可以拿到,公众号的id,这个也是前端拿的。。。

网站应用.png
微信官方传送门

3.参数的拼接和发送。

这个对于细心的认真的朋友并不难,为了防止你们出现意外,直接赋值粘贴,并点个赞,给个星(要求不过分吧。。。)上马!

var pay_parameter = {
    'appid' :CONFIG.WECHAT_APPID,
    'mch_id' : CONFIG.WECHAT_MCH_ID,
    'nonce_str' : Math.random().toString(36).substr(2, 15),
    'body' : '大屏自助广告投放-购买位置',
    'out_trade_no' : sp_id_string,
    'total_fee' : req.body.price,
    'spbill_create_ip' : req.body.ip,
    'notify_url' : CONFIG.WECHAT_NOTIFY_URL,
    'scene_info' : JSON.stringify({"h5_info": {"type":"Wap","wap_url": "","wap_name": "充值"}}),
    'trade_type' : 'JSAPI',
    'openid' : req.body.owner,
    };
var ASCII_String = 'appid='+ pay_parameter.appid + '&'
    + 'body=' + pay_parameter.body +'&'
    + 'mch_id=' + pay_parameter.mch_id +'&'
    + 'nonce_str=' + pay_parameter.nonce_str +'&'
    + 'notify_url=' + pay_parameter.notify_url +'&'
    + 'openid=' + pay_parameter.openid + '&'
    + 'out_trade_no=' + pay_parameter.out_trade_no +'&'
    + 'scene_info=' + pay_parameter.scene_info +'&'
    + 'spbill_create_ip=' + pay_parameter.spbill_create_ip +'&'
    + 'total_fee=' + pay_parameter.total_fee +'&'
    + 'trade_type=' + pay_parameter.trade_type ;

console.log('#1.对参数按照key=value的格式,并按照参数名ASCII字典序排序生成字符串',ASCII_String);
var stringSignTemp = JSON.stringify(ASCII_String + '&key=' + CONFIG.WECHAT_KEY);
console.log('#2.连接商户key',stringSignTemp);
var sign = utils.md5(JSON.parse(stringSignTemp)).toUpperCase();
console.log('#3.生成sign并转成大写',sign);

参数值pay_parameter对象里面的东西改成你想要的对应的就可以了,有一些公司保密信息我直接删掉了,这些直接粘贴就好

下一步

把你的参数由JSON转成XML

  var parseString = require('xml2js').parseString;//npm
  var oa = Object.keys(pay_parameter).sort();
  var on = {};
  for(var i=0;i<oa.length;i++){
      on[oa[i]] = pay_parameter[oa[i]]
  }
  on.sign = sign;
  var xml_parmeter = utils.jsonToxml(on);

然后,向微信统一下单API发起POST请求,返回给你的是XML转不转JSON看你心情

request({
    uri: CONFIG.API_ADDRESS + wechat_unifiedorder.ApiCalleeId ,
    method: 'POST',
    timeout: 10000,
    followRedirect: false,
    headers: wechat_unifiedorder,
    body: body_xml,
}, function(error, response, body) {
    parseString(body,{ explicitArray : false, ignoreAttrs : true }, function (err, result) {
        res.dp_result = result
    });
    return next(null, process_list.indexOf(responseResultContent));
    // go next ===>
});

下单成功会有一个回调,通知,你需要有一个对外网的API(内网可收不到)收到的应该是XML你需要在APP.JS添加一段代码,添加完你收到的就是JSON了。

  var bodyParser = require('body-parser');
  require('body-parser-xml')(bodyParser);

OK至此下单加回调已经完成,有没弄懂的地方底下评论,我先去弄到github上面。

相关文章

  • node.js实现微信公众号支付(统一下单+回调通知)

    前言:公司业务逻辑,前后端分离,node.js负责处理一些支付逻辑; 配置那些这里就不讲了(因为不是我配置的)直接...

  • 微信公众号支付

    微信公众号支付使用的是JSAPI支付,后端调用微信支付demo中统一下单的接口获取支付参数返回给前端,在公众号中直...

  • 微信支付 - JSAPI(Python)

    微信支付最核心的两个功能就是 微信支付 和 支付回调通知 1.准备 配置信息appid进入微信公众号里面的 开发>...

  • Java微信订单查询

    Java 通过统一下单 API 进行订单支付后,除等待微信通过 notify_url 进行回调通知外,还可以主动查...

  • xxe 呈现,验证,解决

    起因 微信支付接口安全提醒通知尊敬的微信支付商户: 您的系统在接受微信支付XML格式的商户回调通知(支付成功通知、...

  • 微信支付APIV3

    准备工作 1.统一下单 2.微信支付相关处理类 WxUtils.java 3.支付回调 4.接收回调参数类 Not...

  • httpclient请求报错

    今天做的线上微信支付出了问题,微信公众号支付--(统一下单失败) 查看原因,在做验证签名的时候报错: java.l...

  • 浅析微信支付:支付结果通知

    本文是【浅析微信支付】系列文章的第六篇,主要讲解支付成功后,微信回调商户支付结果通知的处理。 浅析微信支付系列已经...

  • 微信H5支付流程

    1、用户在商户侧完成下单,使用微信支付进行支付 2、由商户后台向微信支付发起下单请求(调用统一下单接口[https...

  • 微信支付简书的参考代码文档

    1、去微信下单 https://www.jianshu.com/p/10bd4d1d4390 2、接收微信支付回调...

网友评论

    本文标题:node.js实现微信公众号支付(统一下单+回调通知)

    本文链接:https://www.haomeiwen.com/subject/vnjxcftx.html