I recently did some research into the HTML that Facebook was using in the old version of its iOS app. More on that in a future post. In the meantime, I thought I'd share how to inspect what an iOS app is sending over the network using Charles Proxy.
Charles Proxy Ipa Download
Before I begin, I must disclose a few things: Android battery test.
If you have an iOS device, you can run your app on the device and configure Charles to only show traffic from remote clients by disabling the 'Mac OS X proxy' Here is an example setup: Using one remote client (say an iPad in this case) and a Mac running Charles as your proxy host, disable the 'Mac OS X proxy' by deselecting the checkbox in.
- Connect mac and iPhone to same WiFi network. Charles-Proxy-SSL Proxy Settings. General-About-Certificate Trust Settings and enable full trust for the Charles Proxy certificate. Charles-Help-Install Charles Root Certificate on a Mobile Device. Configure iPhone to proxy to IP provided in step 3.
- Charles for iOS currently supports the following features: Capture HTTP and HTTPS network traffic on your device SSL Proxying so you can view your SSL / TLS requests in plain text View requests and responses in the app, or share each request or a whole session to Charles on your desktop.
- I am not an expert at using a proxy server nor even at how to use Charles Proxy. I am likely using Charles Proxy in naive ways. I have resisted writing this for some time because I know I am an amateurish hack.
- Charles Proxy runs on Windows, MacOS and Linux. I have only used the Mac version and will be talking about it.
- I am a HUGE fan of Charles Proxy. It gives me tremendous joy to be able to see into activity that I otherwise would have no insight into. I feel like the app gives me super powers. I am unabashedly biased about this product.
Ok, let's start looking at an app shall we?
First things first, you have to buy Charles Proxy. You can get a free trial to begin with. But the full price for the app is $50 with discounts if multiple licenses are purchased.
You will be surprised to learn that I think it is well worth the $50 and one of the best purchases I've made. 😉
After you install Charles and have it running, getting your iOS device to recognize Charles is fairly easy. First, make sure your iOS device is on the same network as the machine you're running Charles on.
Go into your network settings on the iOS device and select the wifi network.
At the bottom of the network settings is the HTTP Proxy settings. They are likely off. Select Manual. Enter the IP address of the machine running Charles for the Server and 8888 for the Port.
If you open Safari (or anything else that makes a network connection), you should receive a prompt in Charles asking if it is ok to let the device connect to your proxy server.
After you approve your device, all future network traffic will be routed through Charles. You can record the traffic by hitting the record button in Charles.
If you see a lot of noise coming from your Mac, turn off the Mac OS X Proxy by unchecking it under the Proxy menu or by pressing Shift-Command-P.
Ios Proxy App
Enabling SSL Proxying
Now you can launch the app you want to inspect and see what it downloads. I'll use the profile page in the new Facebook app as an example.
Charles Proxy Ios Certificate
When you first load the profile page in Charles proxy, things looked promising. You can see a series of requests, how long they took to download, and their size.
Unfortunately, if you try to see what the server sent in response to the request, or even any details on the request itself, you'll find that you can't see much or what you do see will be gibberish.
That's because Facebook is using SSL to encrypt most of the communication between the app and the server. To see what is going on inside that communication, you need to trick your phone into thinking Charles Proxy's SSL Certificate is valid for the domains you want to inspect.
Setting this up is a fairly easy two step process.
Step 1: Install the Charles Proxy SSL Certificate on your iOS device
If you're using iOS 4 or above, visit http://charlesproxy.com/charles.crt on your device and install the certificate for Charles. Microsoft photo draw 2000 v2 torrent.
If you're on an older version of iOS, want to use Charles as part of your app development, or want to use it with the simulator, check out Charles Proxy's iOS SSL documentation.
Step 2: Configure Charles Proxy to support SSL proxies for the domains you need
In the menu under Proxy, select Proxy Settings. Select the SSL tab. Enable SSL Proxying if it isn't enabled.
You can now add as many domains as you need to complete your task. Proxifier 2 14 1. Wildcards work. For examining the Facebook app, I added the following domains:
*.facebook.com
*.fbcdn.net
*.akamaihd.net
Basically, I watched the queries and saw what domains requests came in for that I couldn't see because they were under SSL, and then I proceeded to add them to the list.
Now that we've got SSL proxying in place, let's take another look at those Facebook requests for the profile page and see if we can see more of what is going on.
Ah… that's more like it. We can now see the full path requested. If we tap on the response section, we can also see what the content of the response was. In this case, the profile page is still an HTML page even in the new 'native' Facebook app.
Now that you have the requests and responses, you can do some really cool stuff. Select all of the relevant requests to look at the total payload delivered.
The overview tab will tell you how many requests were made, how many errors occurred, etc.
The Summary tab will let you know the total size of the assets downloaded and the amount of time it took. You can easily sort the requests to find the largest files or the files that took the most time to download.
Finally, the Chart tab gives several interesting views into the page. The first is a very typical waterfall chart showing you when assets were loaded. I also find the types graph to give a good look at what types of files (e.g., images versus JavaScript) are the biggest assets being downloaded.
Exporting your results
If you have an iOS device, you can run your app on the device and configure Charles to only show traffic from remote clients by disabling the 'Mac OS X proxy' Here is an example setup: Using one remote client (say an iPad in this case) and a Mac running Charles as your proxy host, disable the 'Mac OS X proxy' by deselecting the checkbox in.
- Connect mac and iPhone to same WiFi network. Charles-Proxy-SSL Proxy Settings. General-About-Certificate Trust Settings and enable full trust for the Charles Proxy certificate. Charles-Help-Install Charles Root Certificate on a Mobile Device. Configure iPhone to proxy to IP provided in step 3.
- Charles for iOS currently supports the following features: Capture HTTP and HTTPS network traffic on your device SSL Proxying so you can view your SSL / TLS requests in plain text View requests and responses in the app, or share each request or a whole session to Charles on your desktop.
- I am not an expert at using a proxy server nor even at how to use Charles Proxy. I am likely using Charles Proxy in naive ways. I have resisted writing this for some time because I know I am an amateurish hack.
- Charles Proxy runs on Windows, MacOS and Linux. I have only used the Mac version and will be talking about it.
- I am a HUGE fan of Charles Proxy. It gives me tremendous joy to be able to see into activity that I otherwise would have no insight into. I feel like the app gives me super powers. I am unabashedly biased about this product.
Ok, let's start looking at an app shall we?
First things first, you have to buy Charles Proxy. You can get a free trial to begin with. But the full price for the app is $50 with discounts if multiple licenses are purchased.
You will be surprised to learn that I think it is well worth the $50 and one of the best purchases I've made. 😉
After you install Charles and have it running, getting your iOS device to recognize Charles is fairly easy. First, make sure your iOS device is on the same network as the machine you're running Charles on.
Go into your network settings on the iOS device and select the wifi network.
At the bottom of the network settings is the HTTP Proxy settings. They are likely off. Select Manual. Enter the IP address of the machine running Charles for the Server and 8888 for the Port.
If you open Safari (or anything else that makes a network connection), you should receive a prompt in Charles asking if it is ok to let the device connect to your proxy server.
After you approve your device, all future network traffic will be routed through Charles. You can record the traffic by hitting the record button in Charles.
If you see a lot of noise coming from your Mac, turn off the Mac OS X Proxy by unchecking it under the Proxy menu or by pressing Shift-Command-P.
Ios Proxy App
Enabling SSL Proxying
Now you can launch the app you want to inspect and see what it downloads. I'll use the profile page in the new Facebook app as an example.
Charles Proxy Ios Certificate
When you first load the profile page in Charles proxy, things looked promising. You can see a series of requests, how long they took to download, and their size.
Unfortunately, if you try to see what the server sent in response to the request, or even any details on the request itself, you'll find that you can't see much or what you do see will be gibberish.
That's because Facebook is using SSL to encrypt most of the communication between the app and the server. To see what is going on inside that communication, you need to trick your phone into thinking Charles Proxy's SSL Certificate is valid for the domains you want to inspect.
Setting this up is a fairly easy two step process.
Step 1: Install the Charles Proxy SSL Certificate on your iOS device
If you're using iOS 4 or above, visit http://charlesproxy.com/charles.crt on your device and install the certificate for Charles. Microsoft photo draw 2000 v2 torrent.
If you're on an older version of iOS, want to use Charles as part of your app development, or want to use it with the simulator, check out Charles Proxy's iOS SSL documentation.
Step 2: Configure Charles Proxy to support SSL proxies for the domains you need
In the menu under Proxy, select Proxy Settings. Select the SSL tab. Enable SSL Proxying if it isn't enabled.
You can now add as many domains as you need to complete your task. Proxifier 2 14 1. Wildcards work. For examining the Facebook app, I added the following domains:
*.facebook.com
*.fbcdn.net
*.akamaihd.net
Basically, I watched the queries and saw what domains requests came in for that I couldn't see because they were under SSL, and then I proceeded to add them to the list.
Now that we've got SSL proxying in place, let's take another look at those Facebook requests for the profile page and see if we can see more of what is going on.
Ah… that's more like it. We can now see the full path requested. If we tap on the response section, we can also see what the content of the response was. In this case, the profile page is still an HTML page even in the new 'native' Facebook app.
Now that you have the requests and responses, you can do some really cool stuff. Select all of the relevant requests to look at the total payload delivered.
The overview tab will tell you how many requests were made, how many errors occurred, etc.
The Summary tab will let you know the total size of the assets downloaded and the amount of time it took. You can easily sort the requests to find the largest files or the files that took the most time to download.
Finally, the Chart tab gives several interesting views into the page. The first is a very typical waterfall chart showing you when assets were loaded. I also find the types graph to give a good look at what types of files (e.g., images versus JavaScript) are the biggest assets being downloaded.
Exporting your results
Charles allows you to save your session in a Charles Session file or export it as a HAR (HTTP Archive Specification) file or other common formats like CSV which can be shared with others. Exporter for contacts 1 12 10.
After you're done testing, you'll need to turn off the HTTP Proxy settings on your phone. I know it seems obvious, but there have been multiple times where I've thought a site was down or my network wasn't working only to realize I forgot to turn HTTP Proxy off.
X-ray vision for your little black rectangle with rounded corners
That's it. Easy huh?
You can use Charles Proxy to examine mobile web sites or any network requests so long as the device you are testing on supports HTTP Proxies. It's a great tool to have in your mobile toolbox.
Original author(s) | Karl von Randow |
---|---|
Developer(s) | Karl von Randow |
Initial release | 2002; 18 years ago |
Stable release | |
Operating system | Windows, Mac OS X 10.7 - 10.15, Linux[2] |
Platform | Java |
Size | 55 MB |
Type | Packet analyzer |
License | Trialware |
Website | www.charlesproxy.com |
Charles Web Debugging Proxy is a cross-platform HTTP debugging proxy server application written in Java. It enables the user to view HTTP, HTTPS, HTTP/2[3] and enabled TCP port traffic accessed from, to, or via the local computer. This includes requests and responses including HTTP headers and metadata (e.g. cookies, caching and encoding information) with functionality targeted at assisting developers analyze connections and messaging.
Features[edit]
- Network message analysis – Charles shows full messaging sources of all HTTP and similar TCP-based communications that pass via its proxy port.
- XML, JSON, SOAP interpretation – structured viewers that translate the raw HTTP content into a tree format for analysis.
- HTML, CSS, JavaScript viewers – providing marked-up/formatted/unminified text content display
- SSL debugging – allowing decryption of encrypted data to review/troubleshoot the transmitted content.
- Bandwidth throttling – to simulate slower internet speeds by slowing down bandwidth/speed and introducing latency, for example to simulate a slower 3G connection.
- Flash development aids – including Action Message Format (AMF) content analysis.
- Debugging HTTP connections from mobile devices – providing a proxy between an iOS[4] or Android[5] device and a remote site, to debug HTTP connections and behavior that only occur on devices, including debugging video streaming issues, airplay issues, etc. that cannot be tested in the iOS simulator.
- Remote file debugging – ability to swap out a remote file for a local file to aid debugging a remote site without requiring access to the server files.[6]
- Debugging aids – such as repeating URL post requests to test server changes, adding breakpoints, or editing request variables.
- Validation function – ability to right-click any proxy request, and provide validation feedback using the W3C Markup Validation Service, useful for content the W3C service otherwise cannot access directly.
Browser support[edit]
Charles will autoconfigure for use on the following browsers: Vitalsource bookshelf mac.
- IE (Windows system proxy settings)
- Chrome
- Firefox
- Safari (Mac OS X or Windows system proxy settings)
See also[edit]
References[edit]
- ^'Charles Web Debugging Proxy Application – Version History'. 15 January 2020.
- ^'Charles Web Debugging Proxy Application – Download Charles'.
- ^Jesse Wilson (2016-08-01). 'Charles 4 has HTTP/2'.
- ^'Tutorial: Using Charles Proxy With Your iOS Development And HTTP Debugging'. 2016-04-11.
- ^Erik Straub (2017-06-20). 'Using Charles Proxy to Debug Android SSL Traffic'.
- ^David Walsh (2016-01-21). 'Remote Debugging with Charles Proxy'.