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

在 Mac 上配置 Charles,抓取 iOS 手机端接口请求

工具官网:https://www.charlesproxy.com/

一、简介

Charles 是一款强大的网络抓包工具,支持 HTTP 和 HTTPS 协议,适用于调试手机 App、微信小程序、H5 页面等网络请求。

它能作为代理服务器,转发并记录本机及其他设备发出的请求,方便开发人员查看请求/响应的详细信息,甚至进行参数修改与调试。

本教程将介绍如何在 Mac 上配置 Charles,实现对 iOS 设备网络请求的抓取,适用于接口联调、排查问题等场景。

二、前提条件

  1. 一台 Mac,并已安装 Charles;
  2. 一部 iOS 设备(如 iPhone);
  3. iOS 设备和 Mac 必须在 同一个局域网(例如连接同一个 Wi-Fi);
  4. 推荐 iOS 版本在 iOS 10.3 以上(证书信任操作不同);

三、Mac 上配置 Charles

1. 启用 Mac 的 HTTP 代理监听

打开 Charles,依次点击:

Proxy > macOS Proxy

✅ 勾选此项后,Charles 将作为本机的代理服务器,监听网络请求。

在这里插入图片描述

2. 启用 SOCKS 代理(可选)

如需支持 SSH 、代理等场景,可启用 SOCKS:

Proxy > Proxy Settings > SOCKS
  • 勾选 “Enable SOCKS proxy”
  • 端口默认是 8889,可自定义

⚠️ 若无特定需求,建议跳过此配置。

在这里插入图片描述
在这里插入图片描述
3. 配置 HTTPS 抓包(SSL Proxying)

Charles 默认 不会抓取 HTTPS 请求,需要手动配置监听域名。

推荐方式:全局抓取

打开 Charles:

Proxy > SSL Proxying Settings

点击【Add】,添加以下配置:

  • Host:*
  • Port:443

此设置会抓取所有 HTTPS 请求,适用于开发环境。

⚠️ 正式环境请谨慎使用“全局抓取”,避免敏感数据泄露。

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

四、获取 Mac 的 IP 地址

在 Charles 中:

Help - Local IP Address

或在终端执行命令:

ipconfig getifaddr en0

📌 注意:请确认你使用的是连接 Wi-Fi 的网卡,如 en0、en1 不同机型可能不同。

在这里插入图片描述
在这里插入图片描述

五、配置 iOS 代理

  1. iPhone 与 Mac 保持连接同一个 Wi-Fi;
  2. 打开 iPhone【设置】>【无线局域网】;
  3. 点击当前连接的 Wi-Fi 网络;
  4. 下滑到【HTTP 代理 - 配置代理】> 设置为“手动”;
  5. 服务器填写:Mac 的 IP 地址
  6. 端口填写:8888(Charles 默认端口)
    在这里插入图片描述

六、安装 Charles 根证书(Mac端)

打开 Charles:

Help > SSL Proxying > Install Charles Root Certificate

此操作会在 Mac 上安装并信任 Charles 的根证书,确保抓取 HTTPS 请求正常工作。
在这里插入图片描述

在这里插入图片描述

七、安装 Charles 证书(iOS端)

打开 Charles:

Help > SSL Proxying > Install Charles Root Certificate on a Mobile Device or Remote Browser

Charles 会弹出提示框,显示一个供手机访问的地址
在这里插入图片描述
步骤如下

  1. 使用 iPhone 的 Safari 浏览器 打开:chls.pro/ssl
    http://charlesproxy.com/getssl
  2. 点击“允许”下载配置描述文件;
  3. 安装证书:设置 > 已下载描述文件 > 安装
  4. 信任证书:设置 > 通用 > 关于本机 > 证书信任设置 > 打开 Charles Root Certificate 开关

⚠️ 一定要用 Safari 打开链接并安装!
否则无法触发描述文件安装流程,HTTPS 抓包将失败。

八、抓包验证

  1. 确保 Charles 已启动;
  2. iPhone 访问任意网络接口(App 或浏览器);
  3. 首次连接 Charles 会弹出提示,点击“Allow”允许连接;
  4. 成功后 Charles 中会显示 iOS 的请求流量;

九、建议与拓展

  • 抓包完毕后记得关闭手机代理和证书信任,避免影响正常网络;
  • Charles 支持 Map Local、Breakpoints、Throttle 等高级功能,适合接口联调和前后端 Mock;
  • 可与 iOS 模拟器、安卓真机等多平台联调使用;
http://www.lryc.cn/news/572366.html

相关文章:

  • wordpress小语种网站模板
  • MOS管和比较器
  • IMU介绍
  • openKylin高校沙龙 | 走进成都高校,推动开源技术交流与人才培养
  • 远程调试,以及Debug与info的区别
  • OpenCV——直方图与匹配
  • OpenGL ES 设置光效效果
  • 输入url之后发生了什么
  • c++ STL---vector使用
  • 为什么 C++ 11 引入了 `nullptr`
  • day037-openssh服务与http协议
  • 2025实时数据同步:多平台商品信息接口的高效更新技术解析
  • jquery 赋值时不触发change事件解决——仙盟创梦IDE
  • Python——PyQt5初体验
  • LVS 负载均衡群集
  • LeetCode | 二分法题型详解+图解
  • bos_token; eos_token; pad_token是什么
  • QSqlDatabase: QSQLITE driver not loaded
  • infinisynapse 使用清华源有问题的暂时解决方法:换回阿里云源并安装配置PPA
  • LoRA 浅析
  • Python Beautiful Soup 4【HTML/XML解析库】 简介
  • StableDiffusion实战-手机壁纸制作 第一篇:从零基础到生成艺术品的第一步!
  • Hexo 个人博客配置记录(GitHub Pages + Butterfly 主题 + Waline 评论 + 自动部署)
  • Kernel K-means:让K-means在非线性空间“大显身手”
  • 职坐标IT培训:嵌入式AI物联网开源项目精选
  • 基于大模型的急性结石性胆囊炎全流程预测与诊疗方案研究
  • 【图像处理入门】11. 深度学习初探:从CNN到GAN的视觉智能之旅
  • 跟着AI学习C# Day22
  • 实时输出subprocess.Popen运行程序的日志
  • 永磁同步电机无速度算法--基于正切函数锁相环的滑模观测器