IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue scp2 webpack gulp 前端自动化部署并将打包文件压缩成zip文件 发送到ftp服务器 解放双手 -> 正文阅读

[JavaScript知识库]vue scp2 webpack gulp 前端自动化部署并将打包文件压缩成zip文件 发送到ftp服务器 解放双手

1、下载scp2到项目当中npm install scp2 --save-dev
2、配置package.json的执行命令

"scripts": {
    "dev": "vue-cli-service serve",
    "build:prod": "vue-cli-service build && node ftp.js",//生产环境
    "build:stage": "vue-cli-service build --mode staging && node ftp.js",//测试环境
    "preview": "node build/index.js --preview",
    "lint": "eslint --ext .js,.vue src"
  }

3、配置webpack打包将生成的dist文件打包成dist.zip文件

npm install filemanager-webpack-plugin --save-dev
const FileManagerPlugin = require('filemanager-webpack-plugin')
configureWebpack: {
    name: name,
    resolve: {
      alias: {
        '@': resolve('src')
      }
    },
    plugins: [
      new FileManagerPlugin({
        events: {
          onEnd: {
            delete: [
              './dist.zip',
            ],
            archive: [
              { source: './dist', destination: './dist.zip' },
            ]
          }
        }
      })
    ]
  },

4、我是在项目根目录下建了一个ftp.js

var client = require('scp2')

console.log('\x1B[32m┌───────────────────────────────────────────────────────────────────────────────┐');
console.log('\x1B[37m')
console.log('\x1B[32m 预发布中... ');
console.log('\x1B[37m')
console.log('\x1B[32m└───────────────────────────────────────────────────────────────────────────────┘');

client.scp('dist.zip', {
  host: '', //服务器ip
  port: '',//服务器端口
  username: '',//用户名
  password: '',//密码
  path: ''//放置服务器位置
}, function (err) {
  if (!err) {
    console.log('\x1B[32m┌─────────────────────────────────────────────────────────────────────────────────────────┐');
    console.log('\x1B[37m')
    console.log('\x1B[32m  预发布成功');
    console.log('\x1B[37m')
    console.log('\x1B[32m  前往Jenkins发布', 'Jenkins发布代码地址*************');
    console.log('\x1B[37m')
    console.log('\x1B[32m└─────────────────────────────────────────────────────────────────────────────────────────┘');
    console.log('\x1B[37m')
  } else {
    console.error(err)
  }
}) 

可以配置Jenkins自动化将ftp压缩文件发布到NGINX等服务器上


优化一下打包发布的时候控制台的提醒 利用官方的提示可能会更醒目一点,之前是自己瞎写的提示

var client = require('scp2')
// 下面三个插件是部署的时候控制台美化所用 可有可无
const ora = require('ora');
const chalk = require('chalk');
const spinner = ora(chalk.green('正在发布到服务器...'));
spinner.start();

client.scp('dist.zip', {
  host: '', //服务器ip
  port: '',//服务器端口
  username: '',//用户名
  password: '',//密码
  path: ''//放置服务器位置
}, function (err) {
spinner.stop();
  if (!err) {
    console.log('\x1B[32m┌─────────────────────────────────────────────────────────────────────────────────────────┐');
    console.log('\x1B[37m')
    console.log('\x1B[32m  预发布成功');
    console.log('\x1B[37m')
    console.log('\x1B[32m  前往Jenkins发布', 'Jenkins发布代码地址*************');
    console.log('\x1B[37m')
    console.log('\x1B[32m└─────────────────────────────────────────────────────────────────────────────────────────┘');
    console.log('\x1B[37m')
  } else {
    console.error(err)
  }
}) 

朋友问这块的方法,顺便记录一下之前自己一直使用的自动化部署前端脚本



再补充一种在这之前使用的一种自己感觉相对啰嗦的方法吧
将build、打包生成的dist文件夹压缩成zip以及将zip文件发送到ftp服务器中都交给gulp,贴配置

var gulp = require('gulp');
var $    = require('gulp-load-plugins')();
var path = require('path');
var del = require('del');
var zip = require('gulp-zip')
var ftp = require('gulp-ftp')

var distPath    = path.resolve('./dist');
var version     = ''; // 版本号
var versionPath = ''; // 版本号路径
var env = process.env.npm_config_qa ? 'qa' : process.env.npm_config_uat ? 'uat' : 'prod'; // 运行环境

// 清除dist distzip文件夹
gulp.task('clean:dist', function () {
  return del(['dist/**/*', './distzip/**/*'])
});


// 创建版本号(年月日时分)
(function () {
  var d = new Date();
  var yy = d.getFullYear();
  var MM = d.getMonth() + 1 >= 10 ? (d.getMonth() + 1) : '0' + (d.getMonth() + 1);
  var DD = d.getDate() >= 10 ? d.getDate() : '0' + d.getDate();
  var h  = d.getHours() >= 10 ? d.getHours() : '0' + d.getHours();
  var mm = d.getMinutes() >= 10 ? d.getMinutes() : '0' + d.getMinutes();
  version = yy + MM + DD + h + mm;
  versionPath = distPath + '/' + version;
})();

// 编译
gulp.task('build', $.shell.task([ 'node build/build.js' ]));

// 创建版本号目录
gulp.task('create:versionCatalog', function () {
  return gulp.src(`${distPath}/static/**/*`)
    .pipe(gulp.dest(`${versionPath}/static/`))
});

// 替换${versionPath}/static/js/manifest.js window.SITE_CONFIG.cdnUrl占位变量
gulp.task('replace:cdnUrl', function () {
  return gulp.src(`${versionPath}/static/js/manifest.js`)
    .pipe($.replace(new RegExp(`"${require('./config').build.assetsPublicPath}"`, 'g'), 'window.SITE_CONFIG.cdnUrl + "/"'))
    .pipe(gulp.dest(`${versionPath}/static/js/`))
});

// 替换${versionPath}/static/config/index-${env}.js window.SITE_CONFIG['version']配置变量
gulp.task('replace:version', function () {
  return gulp.src(`${versionPath}/static/config/index-${env}.js`)
    .pipe($.replace(/window.SITE_CONFIG\['version'\] = '.*'/g, `window.SITE_CONFIG['version'] = '${version}'`))
    .pipe(gulp.dest(`${versionPath}/static/config/`))
});

// 合并${versionPath}/static/config/[index-${env}, init].js 至 ${distPath}/config/index.js
gulp.task('concat:config', function () {
  return gulp.src([`${versionPath}/static/config/index-${env}.js`, `${versionPath}/static/config/init.js`])
    .pipe($.concat('index.js'))
    .pipe(gulp.dest(`${distPath}/config/`))
});

// 替换${versionPath}/static/css/app.css 中的icon资源路径
gulp.task('replace:iconsrc', function () {
  return gulp.src(`${versionPath}/static/css/app.css`)
    .pipe($.replace(/static\/fonts\/element-icons/g, "../fonts/element-icons"))
    .pipe(gulp.dest(`${versionPath}/static/css/`))
});


//清除, 编译 / 处理项目中产生的文件
gulp.task('cleanBuild', function () {
  return del([`${distPath}/static`, `${versionPath}/static/config`])
});
// 清空
gulp.task('clean', function () {
  return del([versionPath])
});

// 把dist包移动到 distzip/ 下 要不然Jenkins发布解压有问题
gulp.task('move:dist', function () {
  return gulp.src('./dist/**/*').pipe(gulp.dest('./distzip/dist/'))
})

// 打包成zip包
gulp.task('build:zip', function () {
  return gulp.src('./distzip/**/*').pipe(zip('dist.zip')).pipe(gulp.dest('./distzip'))
})

// 发送至207服务器的pzfw目录下
gulp.task('push:ftp', function () {
  return gulp.src('./distzip/dist.zip').pipe(ftp({
    host: '',
    port: '',
    user: '',
    pass: '',
    remotePath: '/pzfw/'
  }))
})

gulp.task('open:jenkins')

//gulp.series|4.0 依赖
//gulp.parallel|4.0 多个依赖嵌套
gulp.task('default', gulp.series(gulp.series('clean:dist', 'build', 'create:versionCatalog', 'replace:cdnUrl', 'replace:version', 'concat:config', 'replace:iconsrc', 'cleanBuild', 'move:dist', 'build:zip', 'push:ftp')));

其实gulp的配置和功能更多,也挺好用的,都能满足我们自动化部署前端代码,因为项目大多用vue-cli搭建就直接打包什么的都习惯用webpack了,加个filemanager-webpack-plugin和scp2完全满足并且更加配置会清晰一点(两种方法个人都使用过都很nice,用哪个看个人习惯吧)。


  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-28 11:44:26  更:2022-04-28 11:44:34 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 2:34:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码