神奇的抓包工具-Charles

前言

  1. 有时候我们需要在线上debugger的时候,可能萌生的几个解决方案
  • 如果你的环境部署了生产log日志功能,那么恭喜你,这样我们可以快速定位报错的位置,比如Sentry
  • 此外,如果作为一个前端开发人员,除了在页面source面板,rewrite可以解决这个问题
  • 或许我们可以借助一些抓包工具快速便捷的解决这些问题

charles魔法

某一天你的同事突然拿着你的电脑,他想通过百度去搜索一些东西,可是他会很好奇,为什么每次打开www.baidu.com 的时候总是会link到一个奇怪的链接,那么可能会是这样

其实这就是我们今天所说的一个关于charles常用的功能,那就是map-remote,通过配置不同domain去映射做到了重定向

map-remote

我这里写一个测试一个小demo,比如我们线上地址是http://47.103.9.52/charles-tutorial/ 当然这是我自己部署的一个小项目,某一次线上项目出现一个小问题,本地关联的代码

那么我想远端直接关联到我本地,那么我可以先通过执行下面shell命令

shell 复制代码
pnpm install
pnpm run build:dev
pnpm run preview

此时本地应该跑了一个静态访问地址,像这样

此时我们做一个charles map-remote

此时再次访问 http://47.103.9.52/charles-tutorial/ 你会发现本地charles代理到了本地4173这个端口上

为了验证是否生效 那么我加了一行代码,看图示

紧接着执行pnpm run build:dev,我们再次刷新页面,果然页面改动了,那么此时你可以愉快的定位到需要修改的代码进行debugger

map-local为了解决什么呢

如果我们频繁的去build整个页面就会显得效率比较低下,可不可以只是定向的修改部分代码,只重定向我们本地的已知代码呢?

  • 答案是当然可以,

我们现在只是想快速替换现有的bundle.js, 此时我们改变了一点内容,请参照shop/index.js

重新执行pnpm run build:shop, 此时我们刷新页面

rewrite 使用技巧

新加一个按钮触发请求

1. 那么rewrite到底能干嘛呢

  • 首先啊 可以修改请求相关的;包括请求头、请求体等
  • 可以远程映射domain访问

我们这里只讲一个修改请求方面的

那么这么设置我们希望给https://www.fastmock.site/mock/3277f26b72e3b8aa6de012d30c06ce3f/api/api/getTargetDevice 增加一个请求参数 ?author=chrisworkalx

试着重新点击这个按钮

试着看下我们的network面板

的确是增加了这个参数

总结

  1. 这些只是charles的冰山一角
  2. 其实还有一些请求阻断,转发都可以通过charles代理实现
  3. 包括一些更高级的更复杂的功能
  4. 这里是源码链接,更多的问题欢迎交流源码链接
相关推荐
烬头882124 分钟前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas13627 分钟前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠36 分钟前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
2601_9498333940 分钟前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter
珑墨1 小时前
【Turbo】使用介绍
前端
军军君012 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
xiaoqi9223 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
打小就很皮...3 小时前
Tesseract.js OCR 中文识别
前端·react.js·ocr
qq_177767373 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
2603_949462103 小时前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter