访问我的博客

前言

通过上一篇文章,想必你已经掌握了如何正确安装抓包神器 Charles,如果还是抓不了包,可以再看看。

今天要做是抓包实战,因为我在做网络文学的公司就职,所以就拿网络文学的 APP 掌阅开刀好了,以下进入抓包实战,体会 Charles 的强大之处!。

掌握了下面的抓包技巧,对于某些校验并不是十分严格的 APP 来说,破解他们的接口实在是轻而易举。比如修改个 isVip 参数为 true,就变身超级 VIP等;之前用这套抓包技巧,找了一个网校随便修改,发现要价上千至上万的课程竟然可以跳过校验直接被我播放下载,也是醉了。

希望大家掌握了抓包不要干违法的事情,本文目的在于让技术人员了解漏洞,加固校验,不被他人有机可乘,以免造成公司损失。

测试环境

环境:

  • Windows
  • Charles
  • iphone 7
  • 掌阅 APP 7.4.2

前提:手机已经连接 Charles 代理,并可以抓取 HTTPS 数据包。

一、Charles 的断点功能 Breakpoints 实战

首先登录掌阅 APP ,清空Charles 的抓包列表,以防止干扰实验,然后进入 APP 的个人中心,可以看到图中圈出的数值,这里我们对其数值进行修改。

此时看到 Charles 的请求列表中出现了 APP 的请求。

通过简单分析,可以知道个人中心的那些数据是从这个请求中获取到的,那么我们便修改这个请求,右键这个请求,选择 Breakpoints,这样就给这个请求加上了断点。此时切换 App 到 书架再切换回个人中心,会再次发送该请求,Charles 会弹出请求的断点,因为这里不需要修改请求参数,直接放行即可,选择 Execute;放行后,会再次弹出断点,此时就是响应返回的断点了,选择 Edit Response, 底部选择 JSON text 可以修改返回值,

我这里把 2 修改成了 2222,修改完之后,点击Execute,回到 App 发现已经更改了。

测试中发现,掌阅 App 的请求时间如果过长,修改之后也会不生效。
这就需要使用 Charles 的下一个牛 X 的功能了,Map 映射,让 Charles 自动返回我们想要的返回值。

二、Charles 的映射功能 Map 实战

上一个实验进行的时候,如果请求的响应时间过长,掌阅的 App 就会抛弃本次请求的结果,不对数据进行修改,因此我们需要更快的去修改返回值。

以前用 Fiddler 对于这种响应时间有要求的 App,反正我是束手无策的,APP 总是提示网络异常,响应超时等。如果是更改一两个返回值还可以,如果是多个,是真没辙了,所以 Charles 的 Map 功能是很强大的。

重复上一步,抓到个人中心的数据包,就是这个请求。

右键选择 Save Response 到一个文件当中去。

再次右键,选择该请求,为了不干扰实验,取消勾选上一步中的Breakpoints,然后再右键该请求,选择最下方 Map Local,选择刚才保存的文件。

注意这里的 Query,因为掌阅 APP 在请求时,附带了签名时间戳等参数,这里设置为 * 之后,就会忽略这些参数。
设置完成后,修改刚才保存的文件,使用 NotePad++ 等编辑器打卡,修改里面的 JSON 内容。
我改了部分数据,重新进入个人中心,查看 Charles 的请求内容,发现已经修改了

同时看 App 的个人中心也已经修改了,可以改很大的值,然后向不懂的人炫耀炫耀了哈哈哈~

三、Charles 的 Rewrite 实战

Rewrite 是对于 map 功能的一个补充,可以设置较为复杂的规则,下面演示替换 Body 内的用户名称

选择菜单栏 Tools -> Rewrite,选择开启 Rewrite, 并添加一条规则。替换 Body 体内的 We Jan 为 CCTV

APP再次发起请求,响应如下

参考

其实日常中,我们需要用到的地方基本以上三个都可以包含到了,其他深入学习的,可以参考下面的链接。

  • http://www.heyuan110.com/2015/08/15/Charles%E8%BE%85%E5%8A%A9%E8%B0%83%E8%AF%95%E6%8E%A5%E5%8F%A3/
  • http://blog.devtang.com/2015/11/14/charles-introduction/

转载于:https://www.cnblogs.com/vcmq/p/9484416.html

Charles抓包实战详解相关推荐

  1. Charles 抓包工具详解

    前言 不管是移动开发者还是测试者,于抓包工具对于我们的工作都是非常有帮助的,而Charles是一款非常优秀的抓包工具 Charles不仅可以帮助我们抓取服务器返回的数据,还可以修改请求参数,修改响应体 ...

  2. 正所谓:抓包抓的好,牢饭吃的饱,银白手铐准备好、抓包工具-fiddler/charles抓包工具详解

    目录 简介: Charles的基本功能使用 手机端使用charles进行抓包: 第二步,把手机按照charles的IP和端口进行配置:(手机和电脑网络在同一个wifi) 第三步,手机配对成功后,cha ...

  3. 浏览器实现抓包过程详解

    浏览器实现抓包过程详解 几乎所有浏览器都提供了抓取数据包的功能,因为浏览器为抓包提供了一个专门的操作界面,因此这种抓包方式也被称为"控制台抓包".本节以 Chrome 浏览器为例进 ...

  4. HTTP协议版本介绍以及使用Wireshark工具针对HTTP进行抓包分析详解

    一.http协议版本介绍 http:Hyper Text Transfer Protocol 超文本传输协议,是互联网应用最为广泛的一种网络协议,主要用于Web服务.通过计算机处理文本信息,格式为HT ...

  5. Charles微信小程序抓包(详解)

    一.Charles官网下载安装包 https://www.charlesproxy.com/download/latest-release/ 官网下载不了的可去百度网盘获取 链接:https://pa ...

  6. TCP Dump 抓包工具详解

    tcpdump使用技巧 作者: 潜水大叔 一般情况下,非HTTP协议的网络分析,在服务器端用tcpdump比较多,在客户端用wireshark比较多,两个抓包软件的语法是一样的. 一.基本语法 1.1 ...

  7. html 调用tcpdump,抓包工具:tcpdump抓包命令详解

    简介: tcpdump全称:dump the traffic on a network,根据使用者的定义对网络上的数据包进行截获的包分析工具. tcpdump可以将网络中传送的数据包的"头& ...

  8. 抓包工具:tcpdump抓包命令详解

    简介: tcpdump全称:dump the traffic on a network,根据使用者的定义对网络上的数据包进行截获的包分析工具. tcpdump可以将网络中传送的数据包的"头& ...

  9. wireshark怎么抓apk 包_图解如何抓取手机的数据封包「手机抓包技术详解」

    通常我们主要抓取手机等移动设备的三种数据封包:TCP.HTTP.HTTPS.本文我们主要通过图文详细讲解使用wireshark抓取手机的tcp数据包,使用Fiddler抓取手机的HTTP.HTTPS数 ...

最新文章

  1. [转贴]超过80%的80后大学生不知道自己将来要干什么
  2. css 浏览器调试中不可见_前端入门必会的初级调试技巧
  3. TPC-C中跑赢Oracle的OceanBase,最近有何惊艳?
  4. eclipse安装Android模拟器genymotion及其插件
  5. 如何在没有域的环境中搭建AlwaysOn(二)
  6. 大巴山计算机教育中心那所学校,大巴山计算机教育中心
  7. 《Lua程序设计》第7章 迭代器与泛型for 学习笔记
  8. 转:Kafka、RabbitMQ、RocketMQ消息中间件的对比 —— 消息发送性能 (阿里中间件团队博客)...
  9. Android--Menus
  10. python 如果你的年龄大于18_02Python基础
  11. 基于JSP的图书管理系统
  12. python查看汉字的编码_python汉字编码
  13. Linux发行版简介
  14. 外国某高校的中国歷史科目期末考试题
  15. 高德地图基本开发流程
  16. [sdx62]使用diff工具给开源软件包dnsmasq打patch操作方法
  17. 用FreeBSD10搭建基于ZFS的iSCSI服务
  18. 计算机行业各种职业技能树
  19. 01背包问题 图解+详细解析 (转载)
  20. 快速傅立叶变换(FFT)

热门文章

  1. Quickhit快速击键
  2. phpMyAdmin FTP iptables Selinux
  3. 使用Maven管理Java项目
  4. android java.lang.IllegalArgumentException: Comparison method violates its general contract! 问题
  5. JFinal 源码导读第八天(1) Db.tx 事物
  6. android ndk怎样加载o文件_JNI初探之NDK 开发环境配置
  7. 被大众群体吹的神乎其神的Python到底都能干什么
  8. Python基础编程——字典
  9. python websocket异步高并发_Python3.5异步和多个websocket服务器
  10. mysql 二级什么意思_MySQL二级等级考试归纳——PHP篇