当前位置: 首页 > news >正文

爬虫逆向学习(三):Hook让你快速定位网站逆向疑难杂症

Hook保姆级教程

  • Hook定义
  • hook的目的
  • Hook使用步骤
  • Hook函数公式
  • 常用Hook方式
    • 对象中属性
    • eval/Function
    • Cookie
    • header 参数
    • 关闭alert
    • url
    • JSON.stringify
    • JSON.parse
    • Function
    • LocalStorage
    • 对象操作

Hook定义

Hook 技术又叫做钩子函数,在系统没有调用该函数之前,钩子程序就先捕获该消息,钩子函数先得到控制权,这时钩子函数既可以加工处理(改变)该函数的执行行为,还可以强制结束消息的传递。简单来说,就是把系统的程序拉出来变成我们自己执行代码片段。

hook的目的

现在很多网站js都使用了混淆,我们没法直接通过查找的方式定位参数生成位置,js hook能帮助我们找到函数入口以及一些参数变化,便于分析js逻辑,对于爬虫只借助其寻找函数入口。

Hook使用步骤

  1. 明确要定位的参数类型
  2. 编写hook逻辑
  3. 调试代码确定hook成功

Hook函数公式

old_func=funcfunc=function(argument){mytask;returnold_func.apply(argument)}func.prototype.....=.......// func :要hook的函数

常用Hook方式

对象中属性

old_attr=obj.attrObject.defineProperty(obj,'attr',{get:function(){console.log(cookie_cache);returnold_attr},set:function(val){return......}

eval/Function

# eval/Function window.__cr_eval=window.eval ​// 捕捉到debugger位置varmyeval=function(src){console.log("============ eval begin: length="+src.length+",caller="+(myeval.caller&&myeval.caller.name)+" ===============")console.log(">>>>>>>>>>>> eval injected: "+document.location+" <<<<<<<<<<<<<<<<")console.log(src);console.log("============ eval end =============")returnwindow.__cr_eval(src)}// 会有一些反爬会识别是不是本机代码,这个地方是小花招本招,防止被识别var_myeval=myeval.bind(null)_myeval.toString=window.__cr_eval.toString Object.defineProperty(window,'eval',{value:myeval})

Cookie

// 捕捉window参数写入位置(function(){//document 为要hook的对象 这里是hook的cookievarcookieTemp="";Object.defineProperty(document,'cookie',{//hook set方法也就是赋值的方法set:function(val){//这样就可以快速给下面这个代码行下断点//从而快速定位设置cookie的代码console.log('Hook捕获到cookie设置->',val);cookieTemp=val;debugger;returnval;},//hook get方法也就是取值的方法get:function(){returncookieTemp;}});})();

header 参数

//方式一:varcode=function(){varorg=window.XMLHttpRequest.prototype.setRequestHeader;window.XMLHttpRequest.prototype.setRequestHeader=function(key,value){if(key=='Authorization'){debugger;}returnorg.apply(this,arguments);}}varscript=document.createElement('script');script.textContent='('+code+')()';(document.head||document.documentElement).appendChild(script);script.parentNode.removeChild(script);// 方式二(function(){varorg=window.XMLHttpRequest.prototype.setRequestHeader;window.XMLHttpRequest.prototype.setRequestHeader=function(key,value){if(key=='Authorization'){debugger;}returnorg.apply(this,arguments);};})();

关闭alert

var_alert=window.alert window.alert=function(){returntrue;}

url

(function(){varopen=window.XMLHttpRequest.prototype.open;window.XMLHttpRequest.prototype.open=function(method,url,async){if(url.indexOf("login")!=-1){debugger;}returnopen.apply(this,arguments);};})();(function(){constoriAppend=URLSearchParams.prototype.append;URLSearchParams.prototype.append=function(k,v){if(k==="a_bogus"){console.log("【a_bogus生成+拼接】值:",v);console.trace("a_bogus生成函数位置");}returnoriAppend.call(this,k,v);}})();

JSON.stringify

(function(){varstringify=JSON.stringify;JSON.stringify=function(params){console.log("Hook JSON.stringify ——> ",params);debugger;returnstringify(params);}})();

JSON.parse

(function(){varparse=JSON.parse;JSON.parse=function(params){console.log("Hook JSON.parse ——> ",params);debugger;returnparse(params);}})();

Function

(function(){// 保存原始方法window.__cr_fun=window.Function;// 重写 functionvarmyfun=function(){varargs=Array.prototype.slice.call(arguments,0,-1).join(","),src=arguments[arguments.length-1];console.log(src);console.log("=============== Function end ===============");debugger;returnwindow.__cr_fun.apply(this,arguments);}// 屏蔽js中对原生函数native属性的检测myfun.toString=function(){returnwindow.__cr_fun+""}Object.defineProperty(window,'Function',{value:myfun});})();

LocalStorage

(function(){vartmp_getItem=localStorage.getItem;localStorage.getItem=function(params){console.log("Hook localStorage.getItem ——> ",params);debugger;returntmp_getItem(params);}vartmp_setItem=localStorage.setItem;localStorage.setItem=function(params){console.log("Hook localStorage.setItem ——> ",params);debugger;returntmp_setItem(params);}})();

对象操作

如果想动态操作某个对象,可以参考下面这种方式
用途:将值与a对象的href进行网址动态拼接

a={'href':""}varjoin_url;Object.defineProperty(a,'href',{set:function(val){if(val.startsWith('http')){join_url=val;}else{letbaseURL=newURL('');baseURL.pathname=val;join_url=baseURL.toString();}returnjoin_url;},get:function(){returnjoin_url;}});

不拦截 send 执行,让 send 完整跑完 BDMS 加密拿到 a_bogus,在请求即将发往内核的最后一步直接 abort 取消请求,Network 不会出现已发送请求。

asyncfunctiongetABogus(url){returnnewPromise(resolve=>{constoriSend=XMLHttpRequest.prototype.send;constoriAppend=URLSearchParams.prototype.append;letbogusVal=null;// 1、监听a_bogus拼接URLSearchParams.prototype.append=function(k,v){if(k==='a_bogus')bogusVal=v;returnoriAppend.call(this,k,v);}// 2、send正常执行加密,加密完立刻终止请求XMLHttpRequest.prototype.send=function(...args){oriSend.call(this,...args);// 加密完成、参数拼接完毕,直接中断请求setTimeout(()=>{this.abort();// 关键:终止网络发送,Network无真实请求// 恢复原生方法XMLHttpRequest.prototype.send=oriSend;URLSearchParams.prototype.append=oriAppend;resolve(bogusVal);},10)}constx=newXMLHttpRequest();x.open('GET',url);x.send();})}// 使用getABogus("目标接口url").then(v=>console.log(v))
http://www.gsyq.cn/news/1459993.html

相关文章:

  • Opentelemetry在Java中的实践
  • 终极Steam成就管理指南:如何使用开源工具轻松解锁游戏成就 [特殊字符]
  • MATLAB指纹识别全流程实践包:从图像预处理到GUI比对可视化
  • 别被压价!2026长沙回收黄金机构盘点 + 靠谱商家清单 - 奢侈品交易观察员
  • 2026 莆田防水修缮|滨海盐雾腐蚀 + 兴化湾潮汐渗潮 + 3-6 月超长梅雨返潮 + 7-9 月台风灌漏 + 仙游山地岩缝渗水|苏易修缮莆田全域仪器免费测漏 - 苏易修缮
  • 2026 年 6 月天津搬家实测|和平河西南开老破小优选,顺通搬家专攻学区步梯房 - 幸福生活序曲
  • 永和县26年最新专业手表包包回收权威店铺推荐,TOP排行榜 - 莘州文化
  • 2026年有实力的风口风阀厂家及行业应用解析 - 品牌排行榜
  • FreeCAD完全指南:5个实用场景教你掌握开源3D建模软件
  • 2017年全国铁路线与客运站矢量数据包(WGS84坐标,含站名/等级/所属线路属性)
  • 3分钟上手:iFakeLocation让你的iOS设备自由穿梭全球位置
  • 白水县26年最新专业手表包包回收权威店铺推荐,TOP排行榜 - 莘州文化
  • 抖音批量下载助手:你的个人视频收藏管家
  • 3步快速部署:VdhCoApp在Mac系统上的完整安装与配置指南
  • 宝藏眼油推荐,养眼超厉害,这5款宝藏眼油淡纹提亮绝了 - 全网最美
  • 教育部新规下,论文抽检更严了!8款AI查重降重工具真诚评析,这款绝对是你的菜。 - 逢君学术-AI论文写作
  • 北京黄金回收认准这五家,本地老店零差评不压价 - 奢侈品回收测评
  • 2026西宁本地甄选黄金白银铂金彩金回收靠谱商家TOP榜单及联系号码汇总 - 余生黄金回收
  • Mermaid Live Editor终极指南:3分钟从代码小白到图表高手
  • 25+初老必备3款眼油,平细纹清爽不黏超安心 - 全网最美
  • 沁源县26年最新专业手表包包回收权威店铺推荐,TOP排行榜 - 莘州文化
  • 榆社县26年最新专业手表包包回收权威店铺推荐,TOP排行榜 - 莘州文化
  • AI音频分离技术深度解析:Ultimate Vocal Remover核心原理与实战应用
  • 告别I2C中断烦恼:手把手教你用I3C第二主机实现多主控与高效带内中断
  • 2026重庆名表回收甄选榜单,精准控损,守住腕表巅峰价值 - 奢侈品回收测评
  • Autosar NXP S32K3xx系列 基于EB Tresos 配置复杂驱动MCAL 工程导入关联 技术分享
  • 通达信数据接口终极指南:5步构建你的量化交易数据源
  • 山西大同经济开发区26年最新专业手表包包回收权威店铺推荐,TOP排行榜 - 莘州文化
  • MATLAB太阳角度计算工具包:输入经纬度和时间,直接输出天顶角、方位角与高度角
  • GD32E230 ADC注入通道实战:用定时器2触发,1ms精准采样电机相电流