使用Charles,在mac环境下对android app抓包

本文详细介绍了如何使用Charles抓包工具进行HTTP和HTTPS抓包,包括安装Charles、配置安卓手机代理、解决中文乱码问题及HTTPS抓包的具体步骤。

HTTP包:

1.安装抓包工具 Charles , 到官网http://www.charlesproxy.com/可下载到最新版本

 

2.用安装了charles的电脑,代理待抓包anroid手机的网络连接:

     首先查看pc的网络IP地址;打开手机设置,进入当前wifi连接,设置代理为手动,将服务器填为上一步中获得的IP,端口默认为8888(在charles的proxy setting中可以改这个端口号)。这时Charles弹出确认框,点击Allow按钮即可

 

3.中文乱码问题解决

    在charles的content/info.plist 中 的vmoption 添加-Dfile.encoding=UTF-8

HTTPS抓包:

  1. 下载Charles证书http://www.charlesproxy.com/ssl.zip,解压后导入到手机中,然后设置->安全->凭据存储->从存储设备安装,选中证书。
  2. 在Charles的工具栏上点击设置按钮,选择Proxy Settings;切换到SSL选项卡,选中Enable SSL Proxying,选项卡的Locations表单可以填写要抓包的域名和端口,点击Add按钮,在弹出的表单中Host填写域名,比如填api.instagram.com,Port填443。默认的..表示应用于所有地址
附:
http://blog.youkuaiyun.com/jiangwei0910410003/article/details/19806999
Mac电脑上使用Charles抓包Android手机App,可按以下步骤操作: 1. **获取Mac的本地IP地址**:打开Mac的终端,输入`ifconfig | grep "inet "`,找到当前WiFi的IP(如192.168.x.x)[^2]。 2. **安卓手机配置** - **连接同一WiFi**:确保手机和Mac连接到同一个局域网[^2]。 - **设置手动代理**:进入手机WiFi设置>长按当前网络>修改网络。选择手动代理,输入主机名(Mac的本地IP,如192.168.x.x)和端口(Charles的代理端口,默认8888),然后保存设置[^2]。 - **安装Charles证书(必须)**:用手机浏览器访问`http://chls.pro/ssl`,下载并安装证书。需开启Charles,这里涉及接口转发。安卓7+需额外配置,进入设置>安全>加密与凭据>安装证书>CA证书,选择下载的证书(一定要进CA下载,这样凭证才能受信任)[^2]。 3. **Charles抓包设置**:虽然引用未详细说明此步骤的具体内容,但完成前面步骤后,打开Charles,在Charles中进行相应的抓包操作即可开始抓取Android手机App的网络请求 [^1][^2]。 4. **文件及配置检查**:若抓包显示Unknown,需在manifest文件里进行配置,如以下示例: ```xml <application android:name="myproject" android:allowBackup="@bool/allow_backup" android:icon="@mipmap/ic_launcher" android:label="@string/app_label" android:networkSecurityConfig="@xml/network_security_config" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme" android:allowNativeHeapPointerTagging="false" tools:replace="android:name,android:allowBackup,android:label,android:networkSecurityConfig"> ``` 此配置可解决部分抓包显示异常的问题 [^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值