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

Python3 网络爬虫开发实战

JavaScript逆向爬虫

JavaScript接口加密技术,JavaScript有以下两个特点:

  1. JS代码运行在客户端,所以它必须在用户浏览器加载并运行
  2. JS代码公开透明,所以浏览器可以直接获取到正在运行的JS源码。

所以JS代码不安全,任何人都可以读、分析、复制、盗用甚至篡改。
所以JS接口加密是很容易被找到或模拟的,那么为了防止这种情况,可以对JS代码压缩、混淆、加密。

浏览器调试

通过对浏览器的调试,比如Ajax请求,可以对Ajax请求添加断点,当浏览器运行到断点时,通过调用堆栈寻找上层方法,在上层方法中即可以找出JS接口的加密逻辑。
同时通过开发者工具当中的Override来改写JS文件。
改写JS文件有以下作用等:

  • 发现 JavaScript 文件中包含很多阻挠调试的代码或者无效代码、干扰代码,想要将其删除。
  • 调试到某处,想要加一行 console.log 输出一些内容,以便观察某个变量或方法在页面加载过程中的调用情况。在某些情况下,这种方法比打断点调试更方便。
  • 调试过程遇到某个局部变量或方法,想要把它赋值给 window 对象以便全局可以访问或调用。
  • 在调试的时候,得到的某个变量中可能包含一些关键的结果,想要加一些逻辑将这些结果转发到对应的目标服务器。

HooK技术

HooK技术就是将某个方法在他执行前,提前获取到,所以也叫钩子函数。获取到后,我们可以很快速定位到加密入口的位置,非常方便。
在 JavaScript 逆向的时候,我们经常需要追踪某些方法的堆栈调用情况。但在很多情况下,一些 JavaScript 的变量或者方法名经过混淆之后是非常难以捕捉的,这个时候就可以利用到HooK技术。
结合Tampermonkey插件可以很方便的执行JS代码。

http://www.lryc.cn/news/112823.html

相关文章:

  • docker: CMD和ENTRYPOINT的区别
  • DC电源模块对于定制的要求主要有这几点
  • Kubernetes高可用集群二进制部署(六)Kubernetes集群节点添加
  • 网关 GateWay 的使用详解、路由、过滤器、跨域配置
  • vsocde里面远程连接服务器报could not esatablish connection xxxx
  • Hi3798MV200 恩兔N2 NS-1 (二): HiNAS海纳思使用和修改
  • 无涯教程-Perl - foreach 语句函数
  • easyWechat 5.x 复写代码 获取企业微信授权用户敏感信息
  • 医疗器械研发中的可用性工程实践(一)
  • LNMP搭建
  • 软件测试分类总结
  • 模糊PID(三角隶属度函数模糊化CODESYS ST代码)
  • 探索人工智能 | 计算机视觉 让计算机打开新灵之窗
  • 7.物联网操作系统互斥信号量
  • Vue - Element el-form 表单对象多层嵌套校验
  • elementUI全屏loading的使用(白屏的解决方案)
  • flutter开发实战-flutter_spinkit实现多种风格进度指示器
  • 检测文本是否由AI生成,GPT、文心一言等均能被检测
  • 【3D机甲】捏造型功能
  • 设计模式之五:单例模式
  • MATLAB的设置路径
  • Hyperledger Fabric 使用 CouchDB 和复杂智能合约开发
  • 这应该是最全的,Fiddler手机App抓包详解,看完还不会来找我...
  • 使用ubuntu-base制作根文件系统
  • springboot-mybatis的分页查询的接口
  • 网络音频终端音频编码解码终端
  • cordova 12 编译失败Could not find method compile() for arguments [com....]
  • 快速开发平台 WebBuilder 9 发布
  • GPT-5出世,需5万张H100!英伟达GPU陷短缺风暴
  • Jmeter学习和一个关于jmeter获取X-XSRF-TOKEN时的坑