webpack打包上传SFTP

功能所需依赖 fs、glob、ssh2-sftp-clien

新建js文件,可放至build目录下

const fs = require('fs')

const glob = require('glob')

const Client = require('ssh2-sftp-client')

const sftp = new Client()

const pluginName = 'SftpPlugin'

class SftpPlugin {

  // dir 本地目录格式 path.join(__dirname, '..', 'dist/')

  constructor({ dir = '', url = '/', host = '192.168.*.*', port = '22', username = '', password = '', filterFile = null } = {}) { // constructor是一个构造方法,用来接收参数

    this.url = url

    this.dir = dir

    this.filterFile = filterFile

    this.config = {

      host: host, // 服务器地址

      port: port,

      username: username,

      password: password

    }

  }

  apply(compiler) {

    if (compiler) {

      compiler.hooks.done.tap(pluginName, compilation => {

        this.put()

      })

    } else {

      this.put()

    }

  }

  put() { // 自动上传到FTP服务器

    if (!this.dir) {

      console.error('无法上传SFTP,请检查参数')

      return

    }

    sftp.connect(this.config).then(() => { // 连接服务器

      sftp.list(this.url).then(list => {

        this.deleteServerFile(list).then(() => {

          this.globLocalFile()

        })

      }).catch(err => {

        this.exError(err)

      })

    }).catch(err => {

      this.exError('sftp连接失败' + err)

    })

  }

  async deleteServerFile(list) { // 删除服务器上文件(夹)

    for (const fileInfo of list) {

      const path = this.url + fileInfo.name

      if (fileInfo.type === '-') {

        await sftp.delete(path)

      } else {

        await sftp.rmdir(path, true)

      }

    }

    return new Promise(resovle => {

      resovle()

    })

  }

  globLocalFile() { // 获取本地路径所有文件

    glob(this.dir + '**', (er, files) => { // 本地目录下所有文件(夹)的路径

      files.splice(0, 1) // 删除路径../dist/

      if (this.filterFile && typeof this.filterFile === 'function') files = files.filter(x => this.filterFile(x))

      this.uploadFileToSftp(files)

    })

  }

  async uploadFileToSftp(files) { // 传输文件到服务器

    for (const localSrc of files) {

      const targetSrc = localSrc.replace(this.dir.replace(/\\/g, '/'), this.url)

      if (fs.lstatSync(localSrc).isDirectory()) { // 是文件夹

        await sftp.mkdir(targetSrc)

      } else {

        await sftp.put(localSrc, targetSrc)

      }

    }

    console.log('已上传至SFTP服务器!')

    sftp.end()

  }

  exError(err) { // 出错请调用此方法

    sftp.end()

    console.error('sftpError:', err)

  }

}

modules.export = SftpPlugin 

在 项目中的 build/webpack.prod.conf.js 引入

const SftpPlugin = require('./SftpPlugin')


在plugin中



new SftpPlugin({ dir: path.join(__dirname, '..', 'dist/'), url: '/soft/nginx/', host: '192.168.*.*' })

注意: url为sftp服务所对应的你想要上传的地址,根据实际情况修改

最后, npm run build 就可以自动部署到ftp服务器了

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • width: 65%;border: 1px solid #ddd;outline: 1300px solid #...
    邵胜奥阅读 10,416评论 0 1
  • 时间:2017-08-16 19:36:53来源:CSDN Hive 是基于Hadoop 构建的一套数据仓库分析系...
    majyer阅读 5,337评论 0 2
  • 还有很大的差距,三临还远远不够,唯有死去才能过来,一定要彻彻底底地死去,不然就是四不像!🤔🤔🤔 今日临帖正文如下:...
    秋鸿春梦阅读 3,959评论 2 9
  • 东汉末年,诸侯并起。 曹操挟天子以令不臣,气吞山河。 袁本初四世三公,号百万之众。 江东孙策,承继父业,亦有虎入山...
    帅凉阅读 3,954评论 0 0
  • 在才入学时总以为毕业遥遥无期,然而真当毕业时,才知道时间是那么的快。
    逗比丶是一种态度阅读 1,486评论 0 0

友情链接更多精彩内容