vue反编译dist包到源码

最近由于公司老项目上的问题,由于项目很老,之前交接的源码包中缺少了很大一部分模块,但是现在线上的环境和dist包是正常运行的,领导希望能够手动将这部分补全,由于前期项目的不规范,缺少接口文档以及原型图,因此无法知道到底该如何补全,因此,我想着能不能通过dist包去反编译源码包呢,经过多方面探索发现是可行的,但是只能编译出vue文件,但是也满足基本需要了。

1.如何反编译

1.首先需要在管理员模式下打开cmd

2.找到需要编译的dist/static/js的目录下 执行完成后在该目录会看到目录下存在下面的文件名:0.7ab7d1434ffcc747c1ca.js.map,这里以0.7ab7d1434ffcc747c1ca.js.map为例,如下图:

3.全局安装reverse-sourcemap资源

npm install --global reverse-sourcemap

4.反编译 执行:reverse-sourcemap --output-dir source 0.7ab7d1434ffcc747c1ca.js.map

2.脚本反编译

上面的方式执行完毕,确实在source中会出现源码,那么有没有可能用脚本去执行呢,通过node的child_process模块中的exec方式便可以执行reverse-sourcemap --output-dir source这个命令,那么只需要拿到当前文件夹中包含.map文件即可,那么可以借助node中fs模块,递归读取文件名,并使用正则将所有.map的文件提取出来放在一个集合或数组中,在对数组进行递归循环执行reverse-sourcemap --output-dir source这个命令

2.1根据child_process模块编写执行函数

js 复制代码
function executeReverseSourceMap(outputDir) {
    // 构建 reverse-sourcemap 命令
    const command = `reverse-sourcemap --output-dir source ${outputDir}`;
    
    // 执行命令
    exec(command, (error, stdout, stderr) => {
      if (error) {
        console.error(`执行命令时出错:${error.message}`);
        return;
      }
      if (stderr) {
        console.error(`命令输出错误:${stderr}`);
        return;
      }
      console.log(`命令输出结果:${stdout}`);
    });
  }

2.2读取文件并匹配文件

js 复制代码
// // 读取文件夹中的文件
fs.readdir(folderPath, (err, files) => {
  if (err) {
    console.error('读取文件夹时出错:', err);
    return;
  }
  // 遍历文件
  files.forEach(file => {
    // 使用正则表达式匹配特定格式的文件名
    const match = /^(\d+)\..+\.js\.map$/.exec(file);
    if (match) {
      // 如果匹配成功,将文件名存入数组
      targetFiles.push(match[0]);
    }
  });

  // 输出目标文件名数组
  targetFiles.forEach(file=>{
    executeReverseSourceMap(file)
  })
});

2.3完整的执行代码

js 复制代码
const fs = require('fs');
const path = require('path');
const { exec } = require('child_process');
// 文件夹路径
const folderPath = '../js';

// 存放目标文件名的数组
const targetFiles = [];
function executeReverseSourceMap(outputDir) {
    // 构建 reverse-sourcemap 命令
    const command = `reverse-sourcemap --output-dir source ${outputDir}`;
    
    // 执行命令
    exec(command, (error, stdout, stderr) => {
      if (error) {
        console.error(`执行命令时出错:${error.message}`);
        return;
      }
      if (stderr) {
        console.error(`命令输出错误:${stderr}`);
        return;
      }
      console.log(`命令输出结果:${stdout}`);
    });
  }
// // 读取文件夹中的文件
fs.readdir(folderPath, (err, files) => {
  if (err) {
    console.error('读取文件夹时出错:', err);
    return;
  }
  // 遍历文件
  files.forEach(file => {
    // 使用正则表达式匹配特定格式的文件名
    const match = /^(\d+)\..+\.js\.map$/.exec(file);
    if (match) {
      // 如果匹配成功,将文件名存入数组
      targetFiles.push(match[0]);
    }
  });

  // 输出目标文件名数组
  targetFiles.forEach(file=>{
    executeReverseSourceMap(file)
  })
});

3最终结果展示图

相关推荐
anOnion2 分钟前
构建无障碍组件之Alert Dialog Pattern
前端·html·交互设计
choke23310 分钟前
[特殊字符] Python 文件与路径操作
java·前端·javascript
云飞云共享云桌面13 分钟前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
Deng94520131425 分钟前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask
威迪斯特27 分钟前
Flask:轻量级Web框架的技术本质与工程实践
前端·数据库·后端·python·flask·开发框架·核心架构
wuhen_n1 小时前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
大鱼前端1 小时前
为什么我说CSS-in-JS是前端“最佳”的糟粕设计?
前端
不爱吃糖的程序媛1 小时前
Capacitor:跨平台Web原生应用开发利器,现已全面适配鸿蒙
前端·华为·harmonyos
AC赳赳老秦1 小时前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
CHU7290351 小时前
淘宝扭蛋机抽盒小程序前端功能解析:解锁趣味抽盒新体验
前端·小程序