前言:这个东西坑死我了 业务需求要生成小程序码 然后我找了两天的资料 运行 生成一堆的乱码 死活就是不能生成 最后看了一遍博客 套用了一下 自己又简单的改了一下  nodejs 我是刚刚接触  有很多都是不明白 request-promise  开始我用这个框架获得“access_token

” 然后我就想 这个可以发送请求  那生成小程序码是不是也可以用这个  答案是错误的  里面少了一个设置responseType: 'arraybuffer'  也许里面有 但是我不知道  最后 我请求access_token 的时候用的是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');
cloud.init() // 云函数入口函数
exports.main = async (event, context) => {
console.log(event)
try {
const resultValue = await rp('https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=' + event.userInfo.appId + '&secret=' + event.appSectet)
const token = JSON.parse(resultValue).access_token;
console.log('------ TOKEN:', token); //const response = await axios({
return await axios({
method: 'post',
url: 'https://api.weixin.qq.com/wxa/getwxacode',
//responseType: 'stream',
responseType: 'arraybuffer',
params: {
access_token: token,
},
data: {
//access_token: token,
path: "pages/index/index",
width: 300,
//scene: "id=12"
},
}).then(function (response){
return response.data;
})
} catch (err) {
console.log('>>>>>> ERROR:', err)
}
}

再生成完小程序码数据后

在调用函数里需要转base64格式 然后图片就生成了

wx.cloud.callFunction({
name: 'getImage',
data: {
appSectet: app.globalData.appSectet
}
}).then(res => { var imgUrl = wx.arrayBufferToBase64(res.result); //res.result
imgUrl = ("data:image/png;base64," + imgUrl);
console.log(imgUrl)
thisData.setData({
captchaImage1: imgUrl
}) })

如果你不想转base64 的话  可以直接上传到七牛  然后拿到路径

那就直接在云函数里 加代码就可以  上传的到七牛 用流的形式上传到七牛

**********注意 是在云函数加代码呀    在上面的云函数代码里  就不能直接返回了  把.then后面的东西注释掉  把这个response 变量打开   然后要引入七牛的框架


const qiniu = require('qiniu')  //引入的七牛
 
 
var options = {
scope: "你的空间",
};
var accessKey = "你的accessKey ";
var secretKey = "你的secretKey ";
var mac = new qiniu.auth.digest.Mac(accessKey, secretKey);
var options = {
scope: "bwt-portrait",
};
var putPolicy = new qiniu.rs.PutPolicy(options);
var uploadToken = putPolicy.uploadToken(mac);
console.log(uploadToken, "--------------")
var config = new qiniu.conf.Config();
// 空间对应的机房
config.zone = qiniu.zone.Zone_z0 var key = 'image10.png';
return await new Promise(res => {
var formUploader = new qiniu.form_up.FormUploader(config);
var putExtra = new qiniu.form_up.PutExtra();
var readableStream = response.data;
formUploader.put(uploadToken, key, readableStream, putExtra, function (respErr,
respBody, respInfo) {
console.log("代码走了");
if (respErr) {
throw respErr;
}
if (respInfo.statusCode == 200) {
console.log(respBody);
res(respBody)
} else {
console.log(respInfo.statusCode);
console.log(respBody);
res(respInfo.statusCode)
}
});
})

大体就是这样 业务需求的不同 实现的也是不同的  可以自行更改

最后我把我看的博客地址连上

https://blog.csdn.net/feng2qing/article/details/82914505?utm_source=blogxgwz5

nodejs + 小程序云函数 生成小程序码的更多相关文章

  1. 如何使用微信小程序云函数发送短信验证码

    其实微信小程序前端和云端都是可以调用短信平台接口发送短信的,使用云端云函数的好处是无需配置域名,也没有个数限制. 本文使用的是榛子云短信平台(http://smsow.zhenzikj.com) ,S ...

  2. 微信小程序云函数 添加数据到数据库

    1.新建小程序,建立云开发快速启动模板 这里和普通小程序的区别有三点 一是 project.config.json写上云函数所在目录"cloudfunctionRoot": &qu ...

  3. 【Serverless】云函数微信小程序

    简介 什么是AppGallery Connect云函数 云函数是一项Serverless计算服务,提供FaaS(Function as a Service)能力,可以帮助开发者大幅简化应用开发与运维相 ...

  4. 微信小程序云函数Windows下安装wx-server-sdk

    第一次上传部署云函数时,会提示这个,建议在这之前先安装一下node.js. https://nodejs.org/en/ 下载nodejs,然后直接安装,在cmd控制台输入node -v和npm -v ...

  5. 小程序云函数,解决接口https问题

    本实例只是简单记录http请求 1,云函数如下 // 云函数入口函数 exports.main = async (event, context) => { let req = await got ...

  6. Http API触发小程序云函数案例

    1.创建云函数 在云开发中创建云函数(sum,调用需要两个参数:a.b): 2.invokeCloudFunction触发云函数 const request = require('request'); ...

  7. 微信小程序云函数中有以下未安装的依赖,如果未安装即全量上传

    云函数中有以下未安装的依赖,如果未安装即全量上传 在新建的云函数,右击终端打开->cmd,安装依赖 npm install --production 依赖安装成功之后,文件里面会出现 packa ...

  8. 微信小程序-云函数、云存储

    云函数是运行在服务器端的 创建一个目录cloud project.config.json配置云函数目录 cloud目录有个云朵.代表云函数 初始化成功了 新建一个云函数 cloud目录右击 新建一个N ...

  9. 微信小程序云开发之云函数创建

    云函数 云函数是一段运行在云端的代码,无需管理服务器,在开发工具内编写.一键上传部署即可运行后端代码. 小程序内提供了专门用于云函数调用的 API.开发者可以在云函数内使用 wx-server-sdk ...

随机推荐

  1. springboot配置swagger

    1,添加配置类 @Configuration @EnableSwagger2 @Profile({"default", "dev-online", " ...

  2. c# System.Console

    System.Console类公开了和操作控制台相关的有用的静态字段和静态方法.下面是System.Console中一些较为重要的方法. public static void Beep()该方法播放蜂 ...

  3. IDE 设备(磁盘/CD-ROM)配置不正确。“ide1:1”上具有一个 IDE 从设备,但没有主设备。此配置在虚拟机中无法正常运行。请使用配置编辑器将磁盘/CD-ROM 从“ide1:1”移到“ide1:0”。

    开启vmware报这个错: IDE 设备(磁盘/CD-ROM)配置不正确.“ide1:1”上具有一个 IDE 从设备,但没有主设备.此配置在虚拟机中无法正常运行.请使用配置编辑器将磁盘/CD-ROM ...

  4. vue中less文件全局引用

    1.先安装sass-resources-loader   npm install sass-resources-loader 2.然后在build->utils.js修改less配置 在less ...

  5. python中文件处理--判断文件读取结束方法

    一.readline函数 按行遍历读取文件的方法,通过这个方法,readline() 每次只读取一行,通常比 .readlines() 慢得多.仅当没有足够内存可以一次读取整个文件时,才应该使用 .r ...

  6. Linux 基本使用

    1.mkdir 创建文件夹 mkdir filename; 2.touch 创建文件 touch file.txt; 3.chmod 变更文件或目录的权限 chmod -R u+x ./;

  7. python数据类型及其详解

    一.数据类型介绍 1.字符串(string) 三种类型:单引号,双引号,三引号 a = 'jam' b = "JamHsiao" c = '''JAMHSIAO''' print( ...

  8. 新学python画一个爱心

    from turtle import * def curvemove(): for i in range(200): right(1) forward(1) color('yellow','red') ...

  9. CSS中的字体描边

    兴趣使然,突然看见网上的一些带有描边的字体,觉得有点意思,便尝试去做了下 不是什么很厉害的技巧,当然也有参考张鑫旭大神写的文章 只能感叹,css的世界还很大,很广阔 直入主题: 对于文字的描边,一般都 ...

  10. Connection failed Flowsocketconnector Failed to connect to target addressWindows error10061:由于目标计算机积极拒绝,无法连接

    使用bitbise时报上面错误   : 解决方法 :卸载软件并删除相关的文件 (包含bitvise 及注册表中的文件)重新安装后能连接