node实现自动上传文件

basic-ftp

basic-ftp是一个用于在Node.js中进行FTP文件传输的模块。它提供了一组简单易用的API,使得在程序中实现FTP上传、下载、删除等操作变得容易。

使用basic-ftp,您可以:

  1. 建立FTP连接:通过调用ftp.connect()方法,可以与FTP服务器建立连接。

  2. 上传文件:使用ftp.upload()方法可以将本地文件上传到FTP服务器。

  3. 下载文件:使用ftp.download()方法可以将FTP服务器上的文件下载到本地。

  4. 删除文件:通过ftp.remove()方法可以删除FTP服务器上的文件。

  5. 列出目录:使用ftp.list()方法可以列出FTP服务器上指定目录的文件和子目录。

  6. 创建目录:通过ftp.mkdir()方法可以在FTP服务器上创建新的目录。

  7. 重命名文件或目录:使用ftp.rename()方法可以对FTP服务器上的文件或目录进行重命名。

  8. 断开连接:通过ftp.end()方法可以主动断开与FTP服务器的连接。

basic-ftp提供了事件和回调函数,可以监听FTP操作的进展和处理额外的逻辑。它还支持FTP服务器的多种认证方式(如用户名密码、匿名等)以及TLS/SSL加密传输。

基于这些功能,您可以在Node.js中使用basic-ftp进行FTP文件传输和管理,实现诸如自动化文件备份、资源同步、远程部署等功能。

自动上传文件脚本

上传文件到远程ftp服务器

// 将压缩后的test-web.war上传到ftp
const fs = require('fs')
const ftp = require('basic-ftp')

async function uploadFileToInternalFtp() {
  const client = new ftp.Client()
  client.ftp.verbose = true

  try {
    // 使用实际的 FTP 服务器信息替换以下占位符
    const FTP_HOST = 'xxx' // 内网 FTP 服务器 IP 地址
    const FTP_USER = 'xxx' // 账号
    const FTP_PASSWORD = 'xxx.' // 密码
    const localFilePath = 'D:/test-web.war' // 本地文件路径
    const remoteFolderPath = '/xx' // 远程服务器路径
    const remoteFilePath = `${remoteFolderPath}/dist.war`

    await client.access({
      host: FTP_HOST,
      user: FTP_USER,
      password: FTP_PASSWORD
    })

    // 确保远程目录存在,如果不存在则创建
    await client.ensureDir(remoteFolderPath)

    // 上传本地文件到指定远程目录
    const readStream = fs.createReadStream(localFilePath)
    await client.uploadFrom(readStream, remoteFilePath)

    console.log('File uploaded successfully to the internal FTP server!')
  } catch (err) {
    console.error('Error occurred:', err)
  }

  client.close()
}

uploadFileToInternalFtp()
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容