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代码调用

相关推荐
_果果然1 小时前
你真的懂递归吗?没那么复杂,但也没那么简单
前端·javascript
菜泡泡@2 小时前
仓库地图vue-grid-layout
前端·javascript·vue.js
u***u6854 小时前
React环境
前端·react.js·前端框架
X***E4634 小时前
前端数据分析应用
前端·数据挖掘·数据分析
4***14904 小时前
React社区
前端·react.js·前端框架
LFly_ice4 小时前
学习React-24-路由传参
前端·学习·react.js
Lhuu(重开版5 小时前
CSS:动效布局动画
前端·css
Q***K555 小时前
前端构建工具
前端
laocooon5238578865 小时前
创建了一个带悬停效果的“我的个人主页“按钮
前端