V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
imba97
V2EX  ›  分享创造

前端自动打包上传推送钉钉工具

  •  
  •   imba97 ·
    imba97 · 2022-10-28 18:08:53 +08:00 · 2064 次点击
    这是一个创建于 813 天前的主题,其中的信息可能已经有所发展或是发生改变。

    介绍

    在一部分公司中,上线时前端需要打包后发给后端或运维同学,他们再放到服务器上

    但每次打包、压缩、发给别人这个过程太麻烦了,于是就有了这个小工具

    我们就可以简单配置一下,在打包结束后自动执行这个程序

    并且可以直接下载压缩包

    好了,现在只要把后端骗进群,压力一下子就来到了后端这边

    除了自动展示版本、压缩包大小、打包日期之外

    它还可以自动维护本地及线上的压缩包,每次执行时会检查非今天的文件,自动删除

    使用方法

    安装

    pnpm i -D simple-zip-upload
    

    导入

    import ZipUpload from 'simple-zip-upload'
    

    配置

    const ZipUpload = require('simple-zip-upload')
    const path = require('path')
    const fs = require('fs')
    
    const ZipUploadConfig = {
      sftpOptions: {
        // SFTP 连接信息
        connect: {
          host: '1.2.3.4',
          port: 22,
          username: 'root',
          privateKey: fs.readFileSync('C:\\Users\\imba97\\.ssh\\id_rsa')
        },
    
        // 必填,上传的远程目录
        remoteDir: '/www/download/upload'
      },
    
      // 应用名,唯一名称,会拼接在压缩文件名
      app: 'simple-zip-upload',
    
      // 版本号填充“0”的个数,可选,默认 2
      fill: 3,
    
      // 压缩目标文件夹
      zipTargetDir: 'dist',
    
      // 本地压缩文件存放目录
      zipFileDir: 'build',
    
      // 压缩文件下载连接,最后会与文件名拼接
      host: 'https://download.imba97.cn/upload/',
    
      // 钉钉推送卡片信息
      cardInfo: {
        title: '测试发布',
        subTitle: '没啥事就是测试一下',
    
        // 可选 默认是:
        // 版本 20221027005
        // 大小 1.00M
        // 打包日期 2022-10-27 23:57:31
        body(cardInfo) {
          return `
    自定义内容
    开头顶格写,不然会有空格
    版本 ${cardInfo.version}
    大小 ${cardInfo.size}
    打包日期 ${cardInfo.date}`
        }
    
        // 可以是字符串
        // body: '自定义内容'
      },
    
      // 钉钉连接 token 、secret
      dingTalk: {
        accessToken: '',
        secret: ''
      }
    }
    

    使用

    普通

    // 普通
    new ZipUpload(ZipUploadConfig).start()
    

    Webpack

    // ...
    {
      plugins: [new ZipUpload(ZipUploadConfig)]
    }
    

    vue.config.js

    // ...
    {
      // ...
      chainWebpack(config) {
        // 添加插件
        config
          .plugin('ZipUploadPlugin')
          .use(ZipUpload)
          .tap(() => [ZipUploadConfig])
      },
      // ...
    }
    

    更多详情

    Github

    14 条回复    2022-11-03 23:52:17 +08:00
    ss098
        1
    ss098  
       2022-10-28 18:10:15 +08:00
    ...

    虽然但是,应该推进自动部署到服务器上而不是发给后端。
    kunkunzhang
        2
    kunkunzhang  
       2022-10-28 18:11:11 +08:00
    写在 ci 里面或者 build 脚本或者 webpack 里面我感觉都可以 不一定要用这个包
    imba97
        3
    imba97  
    OP
       2022-10-28 18:21:01 +08:00
    @ss098 我们一般测试服务器是直接部署上去,正式服需要后端上。你说的自动部署工具也写过一个: https://www.v2ex.com/t/854392
    matzoh
        4
    matzoh  
       2022-10-28 18:21:36 +08:00
    感觉属于路子走偏了...
    imba97
        5
    imba97  
    OP
       2022-10-28 18:23:25 +08:00
    @kunkunzhang 原本就就是个打包后自动执行的脚本,只是又重写了一下发了个包共享一下
    imba97
        6
    imba97  
    OP
       2022-10-28 18:31:15 +08:00
    @matzoh 确实
    retrocode
        7
    retrocode  
       2022-10-28 18:44:57 +08:00
    @ss098 #1 部分国企权责问题, 明确禁止自动化, 发包只能把部署代码发给运维, 由运维手动备份上传
    masker
        8
    masker  
       2022-10-28 23:23:28 +08:00 via Android
    ci/cd 之前端人员的理解?
    imba97
        9
    imba97  
    OP
       2022-10-29 09:07:47 +08:00
    @masker CI/CD 还得看配置文件写法,就不如直接 JS 写一个了
    perfectlife
        10
    perfectlife  
       2022-11-01 11:56:04 +08:00
    这些不都是运维来实现的 cicd 的功能么,还能标准化
    Kinnice
        11
    Kinnice  
       2022-11-02 10:40:49 +08:00
    CI/CD 之前端理解 ,这些事情应该是 CI/CD 该干的事情,不论是之前的自动上传到服务器还是现在这个推送到钉钉。
    从工程上看不是一种好做法,但是对你现在的工作流程应该是有所助力的。
    imba97
        12
    imba97  
    OP
       2022-11-02 15:54:18 +08:00
    @perfectlife @Kinnice 我们甚至没有运维,基本是前后端兼职了,所以搞出来这么个东西方便自己的
    perfectlife
        13
    perfectlife  
       2022-11-02 16:15:59 +08:00
    @imba97 感觉你们前端项目应该没上容器吧
    imba97
        14
    imba97  
    OP
       2022-11-03 23:52:17 +08:00
    @perfectlife 是的,甚至还需要手动上传
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1107 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 38ms · UTC 18:54 · PVG 02:54 · LAX 10:54 · JFK 13:54
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.