10行代码实现微信小程序支付功能,使用小程序云开发实现小程序支付功能(含源码)

版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qiushi_1990/article/details/99347580

前面给大家讲过一个借助小程序云开发实现微信支付的,但是那个操作稍微有点繁琐,并且还会经常出现问题,今天就给大家讲一个简单的,并且借助官方支付api实现小程序支付功能。

传送门
借助小程序云开发实现小程序支付功能

老规矩,先看本节效果图

我们实现这个支付功能完全是借助小程序云开发实现的,不用搭建自己的服务器,不用买域名,不用备案域名,不用支持https。只需要一个简单的云函数,就可以轻松的实现微信小程序支付功能。
核心代码就下面这些

一,创建一个云开发小程序

关于如何创建云开发小程序,这里我就不再做具体讲解。不知道怎么创建云开发小程序的同学,可以去翻看我之前的文章,或者看下我录制的视频:https://edu.csdn.net/course/play/9604/204528

创建云开发小程序有几点注意的

1,一定不要忘记在app.js里初始化云开发环境。

2,创建完云函数后,一定要记得上传

二, 创建支付的云函数

1,创建云函数pay

三,引入三方依赖tenpay

我们这里引入三方依赖的目的,是创建我们支付时需要的一些参数。我们安装依赖是使用里npm 而npm必须安装node,关于如何安装node,我这里不做讲解,百度一下,网上一大堆。

1,首先右键pay,然后选择在终端中打开

2,我们使用npm来安装这个依赖。

在命令行里执行 npm i tenpay



安装完成后,我们的pay云函数会多出一个package.json 文件

到这里我们的tenpay依赖就安装好了。

四,编写云函数pay


完整代码如下

//云开发实现支付
const cloud = require('wx-server-sdk')
cloud.init()

//1,引入支付的三方依赖
const tenpay = require('tenpay');
//2,配置支付信息
const config = {
  appid: '你的小程序appid', 
  mchid: '你的微信商户号',
  partnerKey: '微信支付安全密钥', 
  notify_url: '支付回调网址,这里可以先随意填一个网址', 
  spbill_create_ip: '127.0.0.1' //这里填这个就可以
};

exports.main = async(event, context) => {
  const wxContext = cloud.getWXContext()
  let {
    orderid,
    money
  } = event;
  //3,初始化支付
  const api = tenpay.init(config);

  let result = await api.getPayParams({
    out_trade_no: orderid,
    body: '商品简单描述',
    total_fee: money, //订单金额(分),
    openid: wxContext.OPENID //付款用户的openid
  });
  return result;
}

一定要注意把appid,mchid,partnerKey换成你自己的。

到这里我们获取小程序支付所需参数的云函数代码就编写完成了。
不要忘记上传这个云函数。

出现下图就代表上传成功

五,写一个简单的页面,用来提交订单,调用pay云函数。


这个页面很简单,
1,自己随便编写一个订单号(这个订单号要大于6位)
2,自己随便填写一个订单价(单位是分)
3,点击按钮,调用pay云函数。获取支付所需参数。

下图是官方支付api所需要的一些必须参数。

下图是我们调用pay云函数获取的参数,和上图所需要的是不是一样。
[图片上传中...(WechatIMG9.jpeg-82c1c2-1565617669894-0)]

六,调用wx.requestPayment实现支付

下图是官方的示例代码

这里不在做具体讲解了,把完整代码给大家贴出来

// pages/pay/pay.js
Page({
  //提交订单
  formSubmit: function(e) {
    let that = this;
    let formData = e.detail.value
    console.log('form发生了submit事件,携带数据为:', formData)
    wx.cloud.callFunction({
      name: "pay",
      data: {
        orderid: "" + formData.orderid,
        money: formData.money
      },
      success(res) {
        console.log("提交成功", res.result)
        that.pay(res.result)
      },
      fail(res) {
        console.log("提交失败", res)
      }
    })
  },

  //实现小程序支付
  pay(payData) {
    //官方标准的支付方法
    wx.requestPayment({
      timeStamp: payData.timeStamp,
      nonceStr: payData.nonceStr,
      package: payData.package, //统一下单接口返回的 prepay_id 格式如:prepay_id=***
      signType: 'MD5',
      paySign: payData.paySign, //签名
      success(res) {
        console.log("支付成功", res)
      },
      fail(res) {
        console.log("支付失败", res)
      },
      complete(res) {
        console.log("支付完成", res)
      }
    })
  }
})

到这里,云开发实现小程序支付的功能就完整实现了。

实现效果

1,调起支付键盘

2,支付完成

3,log日志,可以看出不同支付状态的回调


上图是支付成功的回调,我们可以在支付成功回调时,改变订单支付状态。

下图是支付失败的回调,

下图是支付完成的状态。

到这里我们就轻松的实现了微信小程序的支付功能了。是不是很简单啊。
如果感觉图文不是很好理解,我后面会录制视频讲解。

视频讲解

https://edu.csdn.net/course/detail/25701

源码地址:

https://github.com/qiushi123/xiaochengxu_demos

014云开发实现小程序支付,就是我们的源码,如果你导入源码或者学习过程中有任何问题,都可以留言或者私信我。大家一起学习,一起进步。

展开阅读全文

10分钟实现微信程序支付功能

08-13

<p style="color:#2F2F2F;">n 老规矩,先看本节效果图n</p>n<div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-fce2f4ffa8f92d99.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/418/format/webp" alt="" /></div>n </div>n</div>n<br /><p style="color:#2F2F2F;">n 我们实现这个支付功能完全是借助小程序云开发实现的,不用搭建自己的服务器,不用买域名,不用备案域名,不用支持https。只需要一个简单的云函数,就可以轻松的实现微信小程序支付功能。<br />n核心代码就下面这些n</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-7433fba3b792bb28.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/922/format/webp" alt="" /></div>n </div>n</div>nn 一,创建一个云开发小程序nn<p style="color:#2F2F2F;">n 关于如何创建云开发小程序,这里我就不再做具体讲解。不知道怎么创建云开发小程序的同学,可以去翻看我之前的文章,或者看下我录制的视频:<a href="https://links.jianshu.com/go?to=https%3A%2F%2Fedu.csdn.net%2Fcourse%2Fplay%2F9604%2F204528">https://edu.csdn.net/course/play/9604/204528</a>n</p>nn 创建云开发小程序有几点注意的nn<p style="color:#2F2F2F;">n 1,一定不要忘记在app.js里初始化云开发环境。n</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-c436567c3368ac74.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>n<br /><p style="color:#2F2F2F;">n 2,创建完云函数后,一定要记得上传n</p>nn 二, 创建支付的云函数nn<p style="color:#2F2F2F;">n 1,创建云函数payn</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-32302ade305b8a18.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/564/format/webp" alt="" /></div>n </div>n</div>n<div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-8ea47ffa0b4cffca.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/708/format/webp" alt="" /></div>n </div>n</div>nn 三,引入三方依赖tenpaynn<p style="color:#2F2F2F;">n 我们这里引入三方依赖的目的,是创建我们支付时需要的一些参数。我们安装依赖是使用里npm 而npm必须安装node,关于如何安装node,我这里不做讲解,百度一下,网上一大堆。n</p>nn 1,首先右键pay,然后选择在终端中打开nn<div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-8881030499ebe5ce.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>nn 2,我们使用npm来安装这个依赖。nn<p style="color:#2F2F2F;">n 在命令行里执行 npm i tenpayn</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-c61cb1cb5880c475.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/684/format/webp" alt="" /></div>n </div>n</div>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-cd34c63e39e6427f.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-768712337485bf67.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>n<br /><p style="color:#2F2F2F;">n 安装完成后,我们的pay云函数会多出一个package.json 文件n</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-7e9236d8983ebb21.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/682/format/webp" alt="" /></div>n </div>n</div>n<br /><span style="color:#2F2F2F;">到这里我们的tenpay依赖就安装好了。</span>nn 四,编写云函数paynn<div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-cd36f9084fada492.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>n<br /><p style="color:#2F2F2F;">n 完整代码如下n</p>n<span style="color:#929292;">//云开发实现支付</span> <span style="color:#C678DD;">const</span> cloud = <span style="color:#E6C07B;">require</span>(<span style="color:#98C379;">'wx-server-sdk'</span>)ncloud.init() <span style="color:#929292;">//1,引入支付的三方依赖</span> <span style="color:#C678DD;">const</span> tenpay = <span style="color:#E6C07B;">require</span>(<span style="color:#98C379;">'tenpay'</span>); <span style="color:#929292;">//2,配置支付信息</span> <span style="color:#C678DD;">const</span> config = { <span style="color:#D19A66;">appid</span>: <span style="color:#98C379;">'你的小程序appid'</span>, <span style="color:#D19A66;">mchid</span>: <span style="color:#98C379;">'你的微信商户号'</span>, <span style="color:#D19A66;">partnerKey</span>: <span style="color:#98C379;">'微信支付安全密钥'</span>, <span style="color:#D19A66;">notify_url</span>: <span style="color:#98C379;">'支付回调网址,这里可以先随意填一个网址'</span>, <span style="color:#D19A66;">spbill_create_ip</span>: <span style="color:#98C379;">'127.0.0.1'</span> <span style="color:#929292;">//这里填这个就可以</span> };nnexports.main = <span style="color:#C678DD;">async</span>(event, context) =&gt; { <span style="color:#C678DD;">const</span> wxContext = cloud.getWXContext() <span style="color:#C678DD;">let</span> {n orderid,n moneyn } = event; <span style="color:#929292;">//3,初始化支付</span> <span style="color:#C678DD;">const</span> api = tenpay.init(config); <span style="color:#C678DD;">let</span> result = <span style="color:#C678DD;">await</span> api.getPayParams({ <span style="color:#D19A66;">out_trade_no</span>: orderid, <span style="color:#D19A66;">body</span>: <span style="color:#98C379;">'商品简单描述'</span>, <span style="color:#D19A66;">total_fee</span>: money, <span style="color:#929292;">//订单金额(分),</span> openid: wxContext.OPENID <span style="color:#929292;">//付款用户的openid</span> }); <span style="color:#C678DD;">return</span> result;n}nn 一定要注意把appid,mchid,partnerKey换成你自己的。nn<p style="color:#2F2F2F;">n 到这里我们获取小程序支付所需参数的云函数代码就编写完成了。<br />n不要忘记上传这个云函数。n</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-ba99ca6fe33401ec.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/992/format/webp" alt="" /></div>n </div>n</div>n<br /><p style="color:#2F2F2F;">n 出现下图就代表上传成功n</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-6133d61bc300dac4.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/626/format/webp" alt="" /></div>n </div>n</div>nn 五,写一个简单的页面,用来提交订单,调用pay云函数。nn<div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-ee974aecada48f7c.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>n<br /><p style="color:#2F2F2F;">n 这个页面很简单,<br />n1,自己随便编写一个订单号(这个订单号要大于6位)<br />n2,自己随便填写一个订单价(单位是分)<br />n3,点击按钮,调用pay云函数。获取支付所需参数。n</p>n<p style="color:#2F2F2F;">n 下图是官方支付api所需要的一些必须参数。n</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-2708b7475409199b.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>n<br /><p style="color:#2F2F2F;">n 下图是我们调用pay云函数获取的参数,和上图所需要的是不是一样。n</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-d94c566dd744f128.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>nn 六,调用wx.requestPayment实现支付nn<p style="color:#2F2F2F;">n 下图是官方的示例代码n</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-00e9315590e4e14c.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>n<br /><p style="color:#2F2F2F;">n 这里不在做具体讲解了,完整的可以看视频。n</p>nn 实现效果nnn 1,调起支付键盘nn<div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-b20becb49e6fd26e.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/234/format/webp" alt="" /></div>n </div>n</div>nn 2,支付完成nn<div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-b2a8266fdc83edc3.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/270/format/webp" alt="" /></div>n </div>n</div>nn 3,log日志,可以看出不同支付状态的回调nn<div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-3a1fca73b650742e.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>n<br /><p style="color:#2F2F2F;">n 上图是支付成功的回调,我们可以在支付成功回调时,改变订单支付状态。n</p>n<p style="color:#2F2F2F;">n 下图是支付失败的回调,n</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-1b306a9b35b292e0.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>n<p style="color:#2F2F2F;">n 下图是支付完成的状态。n</p>n<br /><div style="text-align:center;color:#2F2F2F;">n <div style="background-color:transparent;">n <div>n </div>n <div>n <img src="https://upload-images.jianshu.io/upload_images/6273713-906f64407be62c4c.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1000/format/webp" alt="" /></div>n </div>n</div>n<p style="color:#2F2F2F;">n 到这里我们就轻松的实现了微信小程序的支付功能了。是不是很简单啊,完整的讲解可以看视频。n</p>

没有更多推荐了,返回首页