本文解决以下问题#

1. charles与shadowsocks共存#

  1. shadowsocks改为全局模式(PAC模式无效,必须使用全局模式)
    1. 全局模式下默认所有互联网请求全部走shadowsocks
    2. 此时如需访问内网地址
      1. 在Mac中打开 设置->网络->高级->代理,Bypass proxy settings for these Hosts & Domains:中填入内网IP
      2. 如图:
      3. 如有多个地址,可配为134...*
  2. 查看shadowsocks代理的本地http和https的端口(如上图)
    1. 一般为127.0.0.1:1087
  3. 在Charles菜单栏找到 proxy -> external proxy settings
    1. 在http和https中填入127.0.0.1:1087
    2. 如图:
    3. 如有多个地址,可配为134...*
  4. 此时即可正常抓包,如果域名为内网地址,此时会无法访问
    1. 在Charles菜单栏找到 proxy -> external proxy settings
    2. ByPass external proxies for the following hosts:中填入内网ip
  5. 此时已完美解决Charles和shadowsocks共存问题

2. 转发线上页面请求到本地工程#

  1. Charles菜单栏 -> proxy -> MacOs Proxy
  2. 右键请求列表中的url或包,选中Map Remote...
  3. 填入对应的URL相关信息即可

3. 截取MacOSHttps请求#

  1. “Help” -> “SSL Proxying” -> “Install Charles Root Certificate”
    • keychain处将新安装的证书设置为永久信任
  2. Preferences -> Proxy -> SSL Proxying Settings
    • Add -> 直接点击OK(截取所有https请求)

知识共享许可协议

本作品系原创,采用知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议进行许可,转载请注明出处。