当前位置: 首页 > 工具软件 > vinyl-ftp > 使用案例 >

vue项目使用FTP传输部署项目服务器,node命令编写

宦高岑
2023-12-01

前端小菜鸡一枚,总结项目中发现的小技巧,有什么不对和错误希望各位指出和补充,谢谢大家观看!
·························································································································
     最近项目中,要求用ftp协议直接将打包后部署到服务器,于是查了查资料,发现使用npm中vinyl-ftp模块很方便,模块文档 vinyl-ftp模块介绍

     话不多说,我们上代码

#!/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+" 不存在");
        }
}

至此代码基本完成,然后在package.json 的文件中,scripts下加入

    "deploy": "node ./extra_scripts/deploy.js --pro"  //我的deploy.js放置目录,--后面是环境变量

执行 npm run build 后继续执行 npm run deploy 即可发布~

有什么不对缺少的地方欢迎指出和补充,一起继续学习~~

process.argv介绍链接

 类似资料: