basic-ftp
basic-ftp是一个用于在Node.js中进行FTP文件传输的模块。它提供了一组简单易用的API,使得在程序中实现FTP上传、下载、删除等操作变得容易。
使用basic-ftp,您可以:
建立FTP连接:通过调用ftp.connect()方法,可以与FTP服务器建立连接。
上传文件:使用ftp.upload()方法可以将本地文件上传到FTP服务器。
下载文件:使用ftp.download()方法可以将FTP服务器上的文件下载到本地。
删除文件:通过ftp.remove()方法可以删除FTP服务器上的文件。
列出目录:使用ftp.list()方法可以列出FTP服务器上指定目录的文件和子目录。
创建目录:通过ftp.mkdir()方法可以在FTP服务器上创建新的目录。
重命名文件或目录:使用ftp.rename()方法可以对FTP服务器上的文件或目录进行重命名。
断开连接:通过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()