webpack实战

仅用作学习研究

网址:

复制代码
aHR0cHM6Ly93d3cuY2xzLmNuL3RlbGVncmFwaA==

关键字搜索sign: 定位加密位置d

核心加密位置:

javascript 复制代码
sign: p(a({}, r))

在控制台输出一下r 和**a({}, r)**发现一样,

核心就是p函数,即p(r)

p函数如下:

javascript 复制代码
e.exports = function(e) {
            var t = e && s(u(e).map((function(t) {
                return c(t, e[t])
            }
            )));
            return t = r.sync(t),
            t = o(t)
        }

核心加密关键函数在于这里

javascript 复制代码
return t = r.sync(t),
t = o(t)

这里的t就是没有sign的荷载然后序列化

javascript 复制代码
{
    "rn": 20,
    "lastTime": 1764062635,
    "subscribedColumnIds": "",
    "hasFirstVipArticle": "1",
    "os": "web",
    "sv": "8.4.6",
    "app": "CailianpressWeb"
}
javascript 复制代码
app=CailianpressWeb&hasFirstVipArticle=1&lastTime=1764062635&os=web&rn=20&subscribedColumnIds=&sv=8.4.6

关键加密函数

r往上找就能找到

javascript 复制代码
var r = n("KjvB")
  , o = n("aCH8")

很明显这种形式就是webpack

自执行需要刷新整个网页才能断点;

方法太多,在控制台中输入n;点击函数跳转

跳转后的js代码;可以看到很明显的webpack格式

javascript 复制代码
数组参数
function(形参){加载器}([模块1,模块2,...])
键值对(字典)参数
function(形参){加载器}({"k1":"模块1","k2":"模块2"})

把它折叠复制到本地js

很明显它调用的是object格式

所以把[]改为{};把关键加密位置代码(r,o)也拿下来

因为不能在函数外部调用内部的函数n(加载器)

我们把它设置为全局,找到加载器位置,函数名为a;

用任意一个方法把它传递出来

javascript 复制代码
window.gu=a;

然后下面调用改为

javascript 复制代码
var r =window.gu("KjvB");
o = window.gu("aCH8");

然后把模块补齐;

找到加载器核心调用位置;一般是:

javascript 复制代码
e[r].call(t.exports, t, t.exports, a)

在前面打印一下索引r;看一下它都调用了哪些模块,然后进行补全。

一个一个输出,进行补全;如下:

加上核心加密位置代码;构建加密完成

构建一个generate_sign函数,用python代码调用

相关推荐
Hi_kenyon7 小时前
VUE3套用组件库快速开发(以Element Plus为例)二
开发语言·前端·javascript·vue.js
起名时在学Aiifox7 小时前
Vue 3 响应式缓存策略:从页面状态追踪到智能数据管理
前端·vue.js·缓存
李剑一8 小时前
uni-app实现本地MQTT连接
前端·trae
EndingCoder8 小时前
Any、Unknown 和 Void:特殊类型的用法
前端·javascript·typescript
oden8 小时前
代码高亮、数学公式、流程图... Astro 博客进阶全指南
前端
GIS之路8 小时前
GDAL 实现空间分析
前端
JosieBook9 小时前
【Vue】09 Vue技术——JavaScript 数据代理的实现与应用
前端·javascript·vue.js
pusheng20259 小时前
算力时代的隐形防线:数据中心氢气安全挑战与技术突破
前端·安全
起名时在学Aiifox9 小时前
前端文件下载功能深度解析:从基础实现到企业级方案
前端·vue.js·typescript