1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > vue.js将本地文件上传到ftp服务器 vue项目使用FTP传输部署项目服务器 node命令编写...

vue.js将本地文件上传到ftp服务器 vue项目使用FTP传输部署项目服务器 node命令编写...

时间:2021-04-28 19:18:56

相关推荐

vue.js将本地文件上传到ftp服务器 vue项目使用FTP传输部署项目服务器 node命令编写...

#!/usr/bin/env node

var fs = require('fs'); // 引入需要模块

var vinylFs = require( 'vinyl-fs' );

var ftp = require( 'vinyl-ftp' );

var vueConfig= require('../vue.config') //这里是为了抓取打包文件名称

var env = process.argv[2]?process.argv[2].replace('--', "").toLowerCase():null; //抓取命令行的环境变量

var envHot = process.argv[3]?process.argv[3].replace('--', "").toLowerCase():null;

// 需要了解process.argv的文章末尾有链接

var deployInfo={//这是是判断身测试环境还是生产环境

staging:{

"ftpDir":vueConfig.publicPath.substring(0, vueConfig.publicPath.lastIndexOf('/')), // 抓取的打包文件夹名字

"ftpAd": "***.**.***.**", //服务器ip

"user": "admin", //ftp账号

"password": "123456" // 密码

},

production:{

"ftpDir": vueConfig.publicPath.substring(0, vueConfig.publicPath.lastIndexOf('/')),

"ftpAd": "***.**.***.**", //服务器ip

"user": "admin", //ftp账号

"password": "123456" // 密码

}

}

var deployConfig=null

switch(env) // 判断抓取的字段

{

case 'stag':

deployConfig=deployInfo.staging;

break;

case 'pro':

deployConfig=deployInfo.production;

break;

}

var conn = new ftp( { // 创建实例

host: deployConfig.ftpAd,

user: deployConfig.user,

password: deployConfig.password,

parallel: 3,// 并行传输数,默认为3

idleTimeout:500, // 保持空闲FTP连接的时间(毫秒),默认值为100

log:console.log // 日志功能,默认为null

} );

switch(envHot) { // 看看有没有清除指令,便于执行不同的命令

case "clean":

deployClean();

break;

default:

deploy();

}

function deployClean()

{

conn.rmdir( deployConfig.ftpDir,function(){

console.log(deployConfig.ftpAd+" "+deployConfig.ftpDir+" deploy clean done!");

});

}

function deploy()

{

if(fs.existsSync("./dist")) // 抓取 打包dist文件

{

vinylFs.src( ["./dist/**"], { buffer: false } )

.pipe(conn.dest( deployConfig.ftpDir))

.on('end', function(){ console.log(deployConfig.ftpDir+' project dist folder deploy end'); });

}else

{

console.log("本地需部署文件夹 "+deployConfig.localDir+" 不存在");

}

}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。