微信小程序支付功能的实现

微信小程序支付功能的实现前言最近需要在微信小程序中用到在线支付功能 于是看了一下官方的文档 发现要在小程序里实现微信支付还是很方便的 如果你以前开发过服务号下的微信支付 那么你会发现其实小程序里的微信支付和服务号里的开发过程如出一辙 下面我就具体说一下小程序里微信支付的开发流程和注意点 开始第一步 开通微信支付和微信商户号第二步 获得用户的 openid 首页我们需要在小程序的客户端 js 中获取当前用户的 openid 通过调用 wx login 方法可以得到用户的 code wx login success func

前言

最近需要在微信小程序中用到在线支付功能,于是看了一下官方的文档,发现要在小程序里实现微信支付还是很方便的,如果你以前开发过服务号下的微信支付,那么你会发现其实小程序里的微信支付和服务号里的开发过程如出一辙,下面我就具体说一下小程序里微信支付的开发流程和注意点。

开始

第一步:开通微信支付和微信商户号

在这里插入图片描述

第二步,获得用户的openid

首页我们需要在小程序的客户端js中获取当前用户的openid,通过调用wx.login方法可以得到用户的code.

wx.login({ 
    success: function(res) { 
    if (res.code) { 
    //发起网络请求 wx.request({ 
    url: 'https://yourwebsit/onLogin', method: 'POST', data: { 
    code: res.code }, success: function(res) { 
    var openid = res.data.openid; }, fail: function(err) { 
    console.log(err) } }) } else { 
    console.log('获取用户登录态失败!' + res.errMsg) } } }); 

然后开发者服务器使用登录凭证 code 获取 openid。

var code = req.param("code"); request({ 
    url: "https://api.weixin..com/sns/jscode2session?appid="+appid+"&secret="+secret+"&js_code="+code+"&grant_type=authorization_code", method: 'GET' }, function(err, response, body) { 
    if (!err && response.statusCode == 200) { 
    res.json(JSON.parse(body)); } }); 

第三步:获取prepay_id和支付签名验证paySign

这一步的过程就和服务号里的微信支付过程一样,分为客户端和服务器端

首先来看一下客户端js

在服务号里,我们是通过如下的代码来调起支付功能

function jsApiCall() { 
    WeixinJSBridge.invoke( 'getBrandWCPayRequest', { 
    "appId":"", //公众号名称,由商户传入  "timeStamp":"", //时间戳,自1970年以来的秒数  "nonceStr":"", //随机串  "package":"prepay_id=<%=prepay_id%>", "signType":"MD5", //微信签名方式:  "paySign":"<%=_paySignjs%>" //微信签名 }, function(res){ 
    WeixinJSBridge.log(res.err_msg); if( res.err_msg =="get_brand_wcpay_request:ok"){ 
    alert("支付成功!"); }else{ 
    alert("支付失败!"); } } ); } 

在小程序里,我们是通过wx.requestPayment方法来调起支付功能,当然在这之前,我们先要获取prepay_id。

wx.request({ 
    url: 'https://yourwebsit/service/getPay', method: 'POST', data: { 
    bookingNo:bookingNo, /*订单号*/ total_fee:total_fee, /*订单金额*/ openid:openid }, header: { 
    'content-type': 'application/json' }, success: function(res) { 
    wx.requestPayment({ 
    //时间戳 'timeStamp':timeStamp, 'nonceStr': nonceStr, //随机串 'package': 'prepay_id='+res.data.prepay_id, //配置支付id值 'signType': 'MD5',//微信签名方式 'paySign': res.data._paySignjs, //微信签名 //成功后 'success':function(res){ 
    console.log(res); }, 'fail':function(res){ 
    console.log('fail:'+JSON.stringify(res)); } }) }, fail: function(err) { 
    console.log(err) } }) 

那在服务器端主要要实现的是prepay_id的获取和签名paySign

var bookingNo = req.param("bookingNo"); var total_fee = req.param("total_fee"); var openid = req.param("openid"); var body = "费用说明"; var url = "https://api.mch.weixin..com/pay/unifiedorder"; var formData = " 
   
     " 
   ; formData += " 
   
     appid 
   "; //appid formData += " 
   
     test 
   "; formData += " "  + body + ""; formData += " 
   
     mch_id 
   "; //商户号 formData += " 
   
     nonce_str 
   "; formData += " 
   
     notify_url 
   "; formData += " 
   
     " 
    + openid + ""; formData += " 
   
     " 
    + bookingNo + ""; formData += " 
   
     spbill_create_ip 
   "; formData += " 
   
     " 
    + total_fee + ""; formData += " 
   
     JSAPI 
   "; formData += " 
   
     " 
    + paysignjsapi(appid, attach, body, mch_id, nonce_str, notify_url, openid, bookingNo, spbill_create_ip, total_fee, 'JSAPI') + ""; formData += ""; request({ 
    url: url, method: 'POST', body: formData }, function(err, response, body) { 
    if(!err && response.statusCode == 200) { 
    var prepay_id = getXMLNodeValue('prepay_id', body.toString("utf-8")); var tmp = prepay_id.split('['); var tmp1 = tmp[2].split(']'); //签名 var _paySignjs = paysignjs(appid, mch_id, 'prepay_id=' + tmp1[0], 'MD5',timeStamp); var o = { 
    prepay_id: tmp1[0], _paySignjs: _paySignjs } res.send(o); } }); 

第四步 调用这个函数

function paysignjs(appid, nonceStr, package, signType, timeStamp) { 
    var ret = { 
    appId: appid, nonceStr: nonceStr, package: package, signType: signType, timeStamp: timeStamp }; var string = raw1(ret); string = string + '&key='+key; console.log(string); var crypto = require('crypto'); return crypto.createHash('md5').update(string, 'utf8').digest('hex'); }; function raw1(args) { 
    var keys = Object.keys(args); keys = keys.sort() var newArgs = { 
   }; keys.forEach(function(key) { 
    newArgs[key] = args[key]; }); var string = ''; for(var k in newArgs) { 
    string += '&' + k + '=' + newArgs[k]; } string = string.substr(1); return string; }; function paysignjsapi(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); string = string + '&key='+key; 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; }; function getXMLNodeValue(node_name, xml) { 
    var tmp = xml.split("<" + node_name + ">"); var _tmp = tmp[1].split(" 
    + node_name + ">"); return _tmp[0]; } 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/198791.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月26日 下午2:28
下一篇 2026年3月26日 下午2:28


相关推荐

  • odrive教程(处理器2O11接口)

    输入接口在开发自定义ODrive控制代码时,建议您的电动机可以自由连续旋转,并且不与行程有限的传动系统连接ODrive可以通过各种端口和协议进行控制。如果您对嵌入式熟悉的话也可以直接在ODrive上运行自定义代码。请参考ODrive固件开发指南。文章目录输入接口引脚说明引脚功能优先级模拟输入霍尔信号反馈引脚native协议Python其它编程语言ASCII协议ArduinoStep/…

    2022年4月14日
    212
  • 纯HTML/CSS实现简易超帅的登录界面【提供完整代码】[通俗易懂]

    纯HTML/CSS实现简易超帅的登录界面【提供完整代码】[通俗易懂]前言 ❤️我独自走过苍苍茫茫,与你同行才有了光❤️

    2022年5月2日
    98
  • 正定矩阵与半正定矩阵定义性质与理解

    正定矩阵与半正定矩阵定义性质与理解正定矩阵在线性代数里 正定矩阵 positivedefi 有时会简称为正定阵 定义 AA 是 n 阶方阵 如果对任何非零向量 xx 都有 xTAx0x TAx0 其中 xTx T 表示 xx 的转置 就称 AA 正定矩阵 性质 正定矩阵的行列式恒为正 实对称矩阵 AA 正定当且仅当 AA 与单位矩阵合同 两个正定矩阵的和是正定矩阵 正实数与正定矩阵的乘积是正定矩阵

    2026年3月18日
    3
  • freemarker 教程_freemarker自定义标签

    freemarker 教程_freemarker自定义标签FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与Web容器无关,即在Web运行时,它并不知道Servlet或HTTP。它不仅可以用作表现层的实现技术,而且还可以用于生成XML,JSP或Java等。页面的静态化有的较多中的注释都是以#号表示的第一个项目结构代码的实现[java…

    2022年10月6日
    7
  • 【教程】2026年OpenClaw(Clawdbot)零基础10分钟安装集成Skill喂奶级方法

    【教程】2026年OpenClaw(Clawdbot)零基础10分钟安装集成Skill喂奶级方法

    2026年3月14日
    3
  • Android中ActivityManager学习笔记(1)-MemoryInfo「建议收藏」

    Android中ActivityManager学习笔记(1)-MemoryInfo「建议收藏」ActivityManager       与系统中所有的Activity进行交互的类。官网一句话解释了这个东西,但是有点随意了。ActivityManager的作用很多,我们通过它获得内存信息,进程信息,还可以终止某个进程。当然啦,只能终止用户的进程,系统的进程是杀死不了的。下面我通过实例,一步一步学习它的具体作用,我也是刚学,不能从宏观的角度给大家解释清楚它的具体作用。希望通过程序一

    2025年9月26日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号