无法在这个位置找到: head2.htm
当前位置: 建站首页 > 新闻动态 > 行业新闻 >

浏览器跑微信小程序_微信小程序云开发 生成带参

时间:2021-01-07 13:42来源:浏览器跑微信小程序 作者:jianzhan 点击:
手机微信微信小程序云开发设计 转化成带参微信小程序视频比特率程 本文关键为大伙儿详尽详细介绍了手机微信微信小程序云开发设计,转化成带参微信小程序码,云涵数互联网
微信小程序云开发 生成带参小程序码流程       这篇文章主要为大家详细介绍了微信小程序云开发,生成带参小程序码,云函数网络请求,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了小程序生成带参小程序码的具体步骤,供大家参考,具体内容如下

生成带参小程序码流程

1、小程序端上传生成二维码所需的参数到云函数
ess_token
ess_token + 小程序端上传的参数生成二维码
4、云函数将生成的二维码返回到小程序端(或者存到数据库返回fileID,小程序端用fileID进行获取,后续生成先在数据库查找,数据库没有再执行生成操作,防止重复生成小程序码文件)

小程序端上传小程序码所需的参数

wx.cloud.callFunction({
 name: 'getImage', // 云函数名称
 data: { // 小程序码所需的参数
 page: "pages/xxxx/xxxx",
 id: id,
 complete: res = {
 console.log('callFunction test result: ', res)
 this.setData({ // 获取返回的小程序码
 xcxCodeImageData: res.result,
})

创建云函数getImage,并在对应云函数目录中导入request 、request-promise、axios框架(用于数据请求),

npm install --save request // request框架
npm install --save request-promise // request框架promise风格
npm install --save axios // 数据请求框架,可将返回的数据类型设置为流`stream`
# 备注:install 可以简写为 i ;save 作用是将这个库添加到package.json里面

云函数文件中导入框架

const cloud = require('wx-server-sdk')
const axios = require('axios')
var rp = require('request-promise');
const fs = require('fs');
var stream = require('stream');
# 不需要全部导入,根据实际下面实际使用情况酌情导入

请求获取 access_token

// request框架promise风格
rp('cgi-bin/token grant_type=client_credential appid=secret=appSecret'
 .then(function(resultValue) {
 console.log("ess:")
 console.log(JSON.parse(resultValue))
 .catch(function(err) {});
// Nodejs原生写法
const http = require("htt凡科抠图") 
const url = "cgi-bin/token grant_type=client_credential appid=secret=appSecret" 
http.get(url,(res)= {
 var resultValue = ""
 res.on("data",(data)= {
 resultValue+=data
 res.on("end",()= {
 console.log(resultValue)
 }).on("error",(e)= {
 console.log(`获取数据失败: ${e.message}`)
})

获取小程序码

 var options = {
 method: 'POST',
 url: 'wxa/getwxacodeunlimit access_token=' + access_token',
 body: {
 page: "pages/xxx/xxx
 scene: "id=xxx"
 json: true
 rp(options)
 .then(function(parsedBody) {
 console.log(parsedBody) //小程序码图片数据
 .catch(function(err) {});

服务端完整代码一

var rp = require('request-promise');
const fs = require('fs');
var stream = require('stream');
// ess_token
 rp('cgi-bin/token grant_type=client_credential appid=appid secret=secret')
.then(function(resultValue) {
console.log("ess:" + resultValue)
console.log(JSON.parse(resultValue).access_token)
// 请求小程序码
var http = require("http"),
data = {
 // 小程序码参数
 "page": "pages/CardDetail/CardDetail",
 "width": 300,
 "scene": "id=W6MIjlJhFW5Pec-Y",
data = JSON.stringify(data);
var options = {
 method: "POST",
 host: "api.",
 path: "/wxa/getwxacodeunlimit access_token=" + JSON.parse(resultValue).access_token,
 headers: {
 "Content-Type": "application/json",
 "Content-Length": data.length
 var req = http.request(options, function (res) {
 res.setEncoding("binary");
 var imgData = '';
 res.on('data', function (chunk) {
 imgData += chunk;
 res.on("end", function () {
 // 将返回的图片数据转化成uploadFile方法fileContent参数所需的文件流形式,且本地输出数据正常,可以试着用此方法执行uploadFile进行获取小程序码,作者采用了方法二
 var bufferStream = new stream.PassThrough();
 bufferStream.end(new Buffer(imgData));
 console.log('uploadFile方法fileContent参数所需的文件流----')
 console.log(bufferStream)
 // Sublime Text可以运行输出到本地,且可以打开二维码
 // 本地存放路径
 var path = 'public/'+ Date.now() +'.png';
 fs.writeFile(path, imgData, "binary", function (err) {
 if (err) {
 console.log("down fail");
 console.log("ess");
 req.write(data);
 req.end();
.catch(function(err) {});

服务端完整代码二(可直接粘贴使用)

const cloud = require('wx-server-sdk')
const axios = require('axios')
var rp = require('request-promise');
cloud.init()
// 云函数入口函数
exports.main = async (event, context) = {
 console.log(event)
 try {
const resultValue = await rp('cgi-bin/token grant_type=client_credential appid=appid secret=secret')
const token = JSON.parse(resultValue).access_token;
console.log('------ TOKEN:', token);
const response = await axios({
 method: 'post',
 url: 'wxa/getwxacodeunlimit',
 responseType: 'stream',
 params: {
 access_token: token,
 data: {
 page: event.page,
 width: 300,
 scene: "id=" + event.id,
return await cloud.uploadFile({
 cloudPath: 'xcxcodeimages/' + Date.now() + '.png',
 fileContent: response.data,
 } catch (err) {
console.log(' ERROR:', err)
}

点击查看:

点击查看:

点击查看:

点击查看:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持凡科。


(责任编辑:admin)
织梦二维码生成器
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
无法在这个位置找到: ajaxfeedback.htm
栏目列表
推荐内容


扫描二维码分享到微信