微信小程序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"
相关推荐
tjsoft6 小时前
unigui开发微信小程序
微信小程序·小程序
m0_462803881 天前
“趣味运动会记分”功能教学指南
小程序
网络安全学习库1 天前
很喜欢Vue,但还是选择了React: AI时代的新考量
vue.js·人工智能·react.js·小程序·aigc·产品经理·ai编程
叱咤少帅(少帅)1 天前
Uniapp开发pc端,小程序和APK
小程序·uni-app
2501_915918412 天前
iOS性能测试工具 Instruments、Keymob的使用方法 不局限 FPS
android·ios·小程序·https·uni-app·iphone·webview
Chengbei112 天前
利用 LibreNMS snmpget 配置篡改实现 RCE 的完整攻击链
人工智能·web安全·网络安全·小程序·系统安全
苏灵凯2 天前
智能环境监测终端全栈设计:从单片机到微信小程序,手把手搞定!
单片机·嵌入式硬件·mcu·物联网·微信小程序·小程序·蓝牙模块
nhc0882 天前
贵阳纳海川科技有限公司・货运物流行业解决方案
科技·微信小程序·小程序·软件开发·小程序开发
admin and root2 天前
AWS S3 对象存储攻防&云安全之OSS存储桶漏洞
微信小程序·小程序·渗透测试·云计算·aws·src·攻防演练
取码网2 天前
新版点微同城主题源码34.7+全套插件+小程序前后端 源文件
小程序