How to capture and inspect HTTP(s) Traffic from your iOS (iPhone, iPad) using Proxyman for macOS
This mini-blog would demonstrate how to use Proxyman for macOS to capture and see HTTP/HTTPS Traffic from your iOS Devices.
This blog will cover the following:
- How to install & trust Proxyman Certificate on your iOS Devices
- How to inspect HTTP(s) Traffic from Unsplash app on your iOS (iPhone, iPad)
- See HTTPS Content Request/Response in plain text
- Open content with Editing tool
- Pin a domain to see all requests/responses of this domain
1. Configuration:
1.1/ Download the app
If you haven't downloaded the app, let download the latest version from Proxyman website https://proxyman.com/.
If you're a new Proxyman user, please follow Getting Started with Proxyman.
If you've done, you can see the HTTP/HTTPS Traffic from your macOS machine.
data:image/s3,"s3://crabby-images/3b410/3b41069ed538298379f9ef57f366c92bf0918aa5" alt="Capture HTTP(s) Traffic from your iOS Devices"
1.2/ Setup the Certificate for my iPhone
Please go to Certificate Menu -> Install Certificate on iOS -> Physic Devices.
data:image/s3,"s3://crabby-images/22519/22519c89505312bccbd47747d72c86334cf9e7cb" alt="Open Proxyman Setup Guide in Proxyman"
iOS Setup Guidline would show you all required steps:
data:image/s3,"s3://crabby-images/69f3b/69f3b890d9cb90905a6b04fe47e37cc39d12d1d7" alt="Proxyman Setup Guide for iOS"
1.3/ Config Wifi pointing to Proxyman
Get your iPhone device -> Go to Setting App -> Wifi -> (Select current Wifi) -> Configure Proxy -> Manual. Then I used the same Server and Port on Guideline to configure Proxy on my iPhone.
Please update the IP 192.168.0.103
to the IP, which is displayed in the iOS Guideline Windows.
data:image/s3,"s3://crabby-images/ea281/ea2810df0367abb55a22019ae7bd7a3bae877ea6" alt="Configure HTTP Proxy on iOS"
1.4/ Install Proxyman Profile
At this step, we can see all requests coming from my device on Proxyman app. However, in order to see content of Responses, I will need to install Proxyman Certificate.
You can scan the QR code with your phone to be quickly navigated to http://proxy.man/ssl OR
Go to Safari -> http://proxy.man/ssl -> Click on Allow button.
If you could not access this domain, make sure you turn OFF all VPN apps on your iPhone devices. Otherwise, please follow this troubleshooting.
data:image/s3,"s3://crabby-images/e3a34/e3a34dcd639eb509c46b64013a5b3fcc88a0f3a5" alt="Download Proxyman Certificate"
1.5/ Install Proxyman Certificate
Then go to Setting App -> Profiles Downloaded -> Select Proxyman CA -> Install
data:image/s3,"s3://crabby-images/e7b83/e7b83bd5cca7170b005cb7846252ecdea0b962a5" alt="Install Proxyman Certificate"
1.6/ Trust Proxyman Certificate
From iOS 10.3+, we need to trust certificate manually. Thus, final step is go to Setting App -> General -> About -> Certificate Trust Settings -> Turn ON “Enable full trust for root certificates”
data:image/s3,"s3://crabby-images/0d3bc/0d3bc6154131e06c8e5a134d70384f0cd064136d" alt="Trust Proxyman Certificate in iOS"
2. Time to debug Unsplash
OK, enough config. It’s time to actually see HTTP requests/ responses coming from Unsplash app.
From now, we can see all iPhone’s requests showed up after we finished configuring a proxy.
data:image/s3,"s3://crabby-images/9d3ea/9d3ea9e2964fcc431a2354fcf7ab2e59a5174bda" alt="Capture HTTP(s) Traffic from your iOS Devices"
2.1/ Search and Pin a domain
First, We search for app Unsplash with Command+Shift+F (You can also search the app using Search bar).
Then, right click and select Pin. This is one of interesting features of this app. We can Drag & Drop a specific domain into Pin section. As soon as we pin a domain, Proxyman automatically enables SSL Proxying for this domain too.
data:image/s3,"s3://crabby-images/4c4c0/4c4c0c12106d65ba4741db0c9adc938e508e999d" alt="Search and Pin a domain"
2.2/ See decrypted HTTPS Content
Make a request again, you can see the HTTPS Request/Response in plain text.
data:image/s3,"s3://crabby-images/4a734/4a7341290e704081458e1c643733a6c65df8e6ba" alt="Inspect HTTP(s) Response"
Additions: Open content with Editing tool
There is a small button on the top right corner. When clicking the app reveals some Editing app, which is installed on your macOS machine.
data:image/s3,"s3://crabby-images/28020/280201aad7ad367272259cd64097b9c2b67d23b9" alt="Open content with Editing tool"
You can also access other built-in functionalities such as search, search and replace...within the body content as easily as your familiar Editor tools.
data:image/s3,"s3://crabby-images/e4b3c/e4b3c5ede2a27e95b564c74b28ca47074c4f3ba9" alt="Search and replace within the body content"
What going next?
After this tutorial, you can inspect HTTP/HTTPS Traffic from your iOS devices with Proxyman for macOS.
If you would like to go further, there is the next step:
- Learn to use Breakpoint tool, to manipulate the data on the fly.
- Learn to use Map Local to provide a Mock Response.
- Use iOS Simulator?
- ...
Proxyman is a high-performance macOS app, which enables developers to capture and inspect HTTP(s) traffic from apps and domains on iOS devices, iOS Simulators, and Android devices.
Get it at https://proxyman.com/
data:image/s3,"s3://crabby-images/3350c/3350cbf0794f1f815e6e2434f4e2c6efb60c8159" alt="Noah Tran"