微信小程序cli脚本预览上传

前提
  • 小程序后台 - 开发管理 - 小程序代码上传 - 生成密钥 - 下载
  • 配置IP白名单
目录结构
复制代码
projectRoot/
├── cli/
│   ├── index.js          # ci 脚本
│   ├── private.your_app_id.key  # 你的私钥文件
├── previews/             # 预览二维码存放目录
├── miniprogram/          # 小程序代码目录,这个根据 project.config.json 中 miniprogramRoot 配置来
├── app.json              # 小程序配置文件
├── project.config.json   # 小程序项目配置文件
├── ...                   # 其他小程序文件
cli脚本
js 复制代码
const path = require('path');
const fs = require('fs');
const ci = require('miniprogram-ci');

// cd projectRoot && node cli/index.js type=preview appId=your_app_id version=1.0.0 desc="your description"
const rootPath = path.resolve(__dirname, '..');  // cli/ 的上一级就是项目根目录
const argMap = {
  type: 'preview',
  appId: 'your_app_id',
  version: '1.0.0',
  desc: 'hello ci',
};

process.argv.slice(2).forEach(arg => {
  const [key, value] = arg.split('=');
  argMap[key] = value;
});

(async () => {
  console.log('ci with args:', argMap);
  const { type, appId, version, desc } = argMap;
  const privateKeyPath = path.join(__dirname, `private.${appId}.key`);
  // previews 目录需要存在,或者直接在根目录下也可以
  const qrcodeOutputDest = path.join(__dirname, `../previews/preview-${new Date().getTime()}.png`);
  const project = new ci.Project({
    appid: appId,  // 替换为你的实际AppID
    type: 'miniProgram',
    projectPath: rootPath,  // 指向项目根目录
    privateKeyPath,  // 私钥在cli目录下
    ignores: [
      'node_modules/**',
      '.git/**',
      'cli/**',
    ]  // 忽略cli目录
  });
  if (type === 'upload') {
    console.log('start upload')
    const uploadResult = await ci.upload({
      project,
      version,
      desc,
      setting: {
        es6: true,
      },
      onProgressUpdate: console.log,
    })
    console.log('done upload', uploadResult)
  } else {
    console.log('start preview')
    const previewResult = await ci.preview({
      project,
      desc, // 此备注将显示在"小程序助手"开发版列表中
      setting: {
        es6: true,
      },
      qrcodeFormat: 'image',
      qrcodeOutputDest,
      onProgressUpdate: console.log,
      // pagePath: 'pages/index/index', // 预览页面
      // searchQuery: 'a=1&b=2',  // 预览参数 [注意!]这里的`&`字符在命令行中应写成转义字符`\&`
    })
    console.log('done preview', previewResult)
  }
})()
执行
sh 复制代码
# your_app_id - 改为需要上传的appId
# type preview - 预览;upload - 上传(一旦设置为体验版,后续就是体验版)
cd projectRoot && node cli/index.js type=preview appId=your_app_id version=1.0.0 desc="your description"
相关推荐
嫂子开门我是_我哥1 小时前
从零开发微信小程序+若依后端项目:本地全流程开发,从环境搭建到前后端联调跑通
微信小程序·小程序·若依
Kingexpand_com20 小时前
物联网APP开发实战:如何打造用户真正愿意用的智能硬件伴侣
物联网·小程序·app·智能硬件·物联网app定制开发
CHU7290351 天前
家政同城服务APP前端功能玩法解析
前端·小程序
weixin_lynhgworld1 天前
硬核功能赋能运营,定制盲盒小程序解锁沉浸式抽盒体验
小程序
灵机一物1 天前
灵机一物AI智能电商小程序-ReAct驱动的虚拟试穿智能体产品方案
人工智能·小程序
CHU7290351 天前
剧本杀组车约玩小程序前端功能版块设计及玩法介绍
前端·小程序
chushiyunen1 天前
pycharm创建桌面时间控件小程序
ide·小程序·pycharm
宁夏雨科网1 天前
SaaS系统搭建宠物用品小程序可行吗
小程序·商城小程序·微信商城·制作小程序·宠物用品小程序·宠物用品商城
CHU7290351 天前
直播逛购新体验——直播商城APP前端功能详解
前端·小程序
云起SAAS2 天前
设备质保保修维修保质包换期查询H5抖音快手微信小程序看广告流量主开源
微信小程序·小程序