微信小程序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"
相关推荐
维双云2 小时前
商城小程序在线收款怎么做:收款链路、订单流转和后台处理怎么接
小程序
Geek_Vison2 小时前
APP集成了50多个小程序后,如何搭建一个小程序管理平台来管理这些小程序~
小程序·uni-app·apache·mpaas·小程序容器
万岳科技系统开发2 小时前
教育培训小程序搭建中的AI题库功能解析
人工智能·小程序
前端 贾公子2 小时前
小程序蓝牙打印探索与实践 (最终章)
前端·微信小程序·小程序
小羊Yveesss4 小时前
2026年个人能做微信小程序吗?
微信小程序·小程序
kidding7234 小时前
BMI 健康测量仪工具类小程序
前端·微信小程序·小程序
云迈科技-软件定制开发4 小时前
智慧物业小程序完整技术功能清单(业主端+管理后台+硬件联动|可直接落地)
小程序
不如摸鱼去21 小时前
Wot UI 2.1.0 发布:ConfigProvider 全局配置能力升级
ui·小程序·uni-app
这是个栗子1 天前
微信小程序开发(九)- uni-app微信小程序商城
微信小程序·小程序·uni-app·vue·vuex
TuCoder1 天前
景区导览小程序功能选型指南:刚需配置、增值功能与技术避坑要点
小程序