2022-05-25-🐓🥚 HBuilderX uni-app

2022-05-25  本文已影响0人  沐深

背景:

uni-app h5端,需要打包成文件上传到服务器,由于系统隔离原因,代码平台无法使用自身的构建工具,只能自己写一个了。

流程图

架构图

uni-app提供了两套机制,HBuilderX,GUI方式和vue-cli,团队选择了GUI。
可视化的方式比较简单,HBuilderX内置相关环境,开箱即用,无需配置nodejs。

客户端

项目文件夹
HBuilderX本地静态资源构建

HBuilderX可以在界面构建也可以使用命令行构建方式:

$ cli publish --platform h5 --project <projectName>

打包文件夹地址
/unpackage/dist/build/h5/

压缩静态文件

安装 compressing

$ npm i  compressing -s

使用compressing对静态文件压缩,生成h5.zip
compressDir.js

var compressing = require("compressing");
let fs = require("fs");

const options = {
  targetPath: "/unpackage/dist/build/h5/",
  outPut: "/unpackage/dist/build/h5.zip",
};

let pathout = process.cwd() + options.targetPath;
let outPath = process.cwd() + "/" + options.outPut;

compressing.zip
  .compressDir(pathout, outPath)
  .then(() => {
    console.log("compress h5 folder done...");
  })
  .catch((err) => {
    console.error("unzip");
  });

上传到服务器
上传静态资源h5.zip

安装 needle

$ npm i needle -S

服务端,needle上传到服务器
needle.js

const needle = require("needle");
const fs = require("fs");
var colors = require("colors");

colors.setTheme({
  custom: ["white", "bgGreen"],
  error: ["white", "bgBlue"],
});
let pwd = process.cwd();
const buffer = fs.readFileSync(pwd + "/unpackage/dist/build/h5.zip");

// 服务器地址两个
let url = [
  "http://xxx/file/uploading",
  "http://xxx/file/uploading",
];
const data = {
  file: {
    buffer: buffer,
    filename: "mypackage.zip",
    content_type: "application/octet-stream",
  },
};

// the callback is optional, and needle returns a `readableStream` object
// that triggers a 'done' event when the request/response process is complete.
url.forEach((item) => {
  const site = item.replace("/file/uploading", "");
  console.log(`service ${site} uploading...`.error);

  needle.post(item, data, { multipart: true }, function (err, resp, body) {
    err && console.error(err);
    console.log(`service ${site} upload done...`.custom);
  });
});

服务端

在服务器上部署node服务传输文件
app.js,在linux上,1000端口起一个服务,接受的时候打上时间标签,便于回滚。

const express = require('express');
const compressing = require("compressing");
const app = express();
const multiparty = require('multiparty');
const fs = require('fs');
const { timestampToFile } = require("./until");

const path = require('path');
const rootPath = path.resolve(__dirname, './public');


/* 上传接口 */
app.post('/file/uploading', (req, res, next) => {
  /* 生成multiparty对象,并配置上传目标路径 */
  const form = new multiparty.Form();
  /* 设置编辑 */
  form.encoding = 'utf-8';
  // 设置文件存储路劲
  form.uploadDir = rootPath;
  // 设置文件大小限制

  // form.maxFields = 1000;   //设置所有文件的大小总和//上传后处理
  form.parse(req, (err, fields, files) => {
  
      const inputFile = files.file[0];
      const uploadedPath = inputFile.path;
    // nginx 静态资源指向目录
    const dstPath = uploadDirPath + "/" + "h5-" + timestampToFile() + ".zip";
      // 重命名为真实文件名
      fs.rename(uploadedPath, dstPath, (err) => {
        if (err) {
          console.log('rename error:' + err);
        } else {
          console.log('rename ok');
        }
      });
    }
    res.writeHead(200, { 'content-type': 'text/plain;charset=utf-8' });
    res.write('200');
    res.end();
  });
});
app.listen(1000);

一键发布

最后命令放在package.json中

 "scripts": {
    //发布
    "pub:prod": "cli publish --platform h5 --project xxx && npm run compress && npm run uploadToService",
    "compress": "node ./upload-script/compressDir.js",
    "uploadToService": "node ./upload-script/needle.js "  
    // 回滚
    "backTrace": "node ./upload-script/backTrace.js 
  },
$ npm run pub:prod

版本回滚

node-ssh可以远程登录服务器,并进行文件操作,把上传的zip复制到nginx静态目录里,替换到当前的。

$ npm i  node-ssh -S

traceBack.js

const { NodeSSH } = require("node-ssh");
const arg = process.argv.splice(2)
const ssh = new NodeSSH();
const outPath = "/usr/local/nginx/node-upload/public/list";
ssh
  .connect({
    host: "xxx.xxx",
    username: "root",
    password: "xxxxxxx",
  })

  .then(function () {
    // 列进所有部署包
    if (`${arg}` === "ls") {
        ssh.execCommand(`ls`, { cwd: `${outPath}` }).then(function (result) {
          if (result.stderr) {
            console.error(result.stderr);
            return;
          }
          console.log(result.stdout);
        });
        return;
    }
     // 复制文件到 nginx 静态目录下
    ssh
      .execCommand(`cp ${arg} /usr/local/nginx/html`, {
        cwd: `${outPath}`,
      })
      .then(function (result) {
        if (result.stderr) {
          console.error(result.stderr);
          return;
        }
      });
  // 解压相关zip
    ssh
      .execCommand(`unzip -o ${arg}`, {
        cwd: `/usr/local/nginx/html`,
      })
      .then(function (result) {
        if (result.stderr) {
          console.error(result.stderr);
          return;
        }
        console.log(result.stdout);
      });
  });

列举所有可用版本

$ npm backTrace ls

使用你要回滚的版本
$ npm backTrace h5-2022-5-25-17:49:43.zip

项目代码地址

上一篇 下一篇

猜你喜欢

热点阅读