前端打包后的文件上传到服务器


前言

  好久没写文章了,一直在忙,刚好今天有点时间,就想写点东西。废话不多说,直接进入正文吧。

准备工作

  需要用到scp2,这是基于ssh2实现的ftp上传工具。npm安装到开发依赖即可,也可全局安装。

npm install -D scp2

具体文档 https://www.npmjs.com/package/scp2。

本人的是angular项目开发的,其他框架也都一样。项目根目录新建文件publish.test.js,

代码如下:

"use strict"
const client = require('scp2');
const ssh2Cliend = require('ssh2').Client;
const conn = new ssh2Cliend();
const ora = require('ora');
const chalk = require('chalk');
const spinner = ora(chalk.green('正在发布到本地虚拟机服务器……'));

// 服务器配置
const serveConfig = {
    host: 'ip/域名',
    port: '22',  //端口默认22
    username: 'root',
    password: 'password',
    path: '/mydir/website/'
};
async function backup() {
    conn.exec(`mv -fu ${serveConfig.path} ${serveConfig.path}.backup`, (e, mv) => {
        mv.on('close', async() => {
            // tslint:disable-next-line:no-console
            console.log('备份完成……');
            // 开始上传
            await upload();
            conn.end();
        })
    })
}
async function upload() {
    spinner.start();
    client.scp('./dist/master/', {
        host: serveConfig.host,
        port: serveConfig.port,
        username: serveConfig.username,
        password: serveConfig.password,
        path: serveConfig.path
    }, fail => {
        spinner.stop();
        if (!fail) {
            // tslint:disable-next-line:no-console
            console.log('项目发布完成!');
        } else {
            // tslint:disable-next-line:no-console
            console.log('fail:', fail);
        }
    });
}
conn.on('ready', async() => {
    // 先备份原文件
    await backup();

}).connect({
    host: serveConfig.host,
    port: serveConfig.port,
    username: serveConfig.username,
    password: serveConfig.password
});

package.json配置命令:

 配置完成,运行 npm run publish:test,即可打包,发布到测试服务器。