举报 https://scriptcat.org/zh-CN/script-show-page/1338/
他在initSet上设置了动态引入
data:image/s3,"s3://crabby-images/29fda/29fda8107d481ae62817e6eb9052bde743f87a7f" alt=""
data:image/s3,"s3://crabby-images/81205/812053b0c991f80ee1c067557ed787296c196082" alt="图片.png"
但是找不到任何设置的代码
我们可以头部下劫持
const originSetValue=GM_setValue
GM_setValue=(a,b)=>{
debugger
originSetValue(a,b)
}
发现什么都没劫持到
但是换个思路想,window是由油猴proxy代理出来的变量,也挂在了GM函数
所以可以下断点
const originSetValue=GM_setValue
window.GM_setValue=(a,b)=>{
debugger
originSetValue(a,b)
}
发现断出来initSet的设置代码了
文件地址在https://tcb-w644nfbyxrttaih-2cpr71dbf4b7-1304481250.tcloudbaseapp.com/static/js/pages-index-list.b35c5d5a.js
通过window.mainProcedure.xm_window.GM_setValue
首先该代码将window巧妙地设置到this上,然后隐蔽的将this设置到原网页的mainProcedure上
data:image/s3,"s3://crabby-images/73924/73924c10ab5a4e5a6ceef5844c4941426338dfcc" alt="Q(X1B%J(4B9LTOLQGA~59WX.png"
再利用原网页的ui引入代码来执行GM_setValue以及GM_XHR行为
从而实现动态引入!