How to setup Charles proxy
data:image/s3,"s3://crabby-images/29a35/29a35820b9bda42350e69af3cdf407ae60009472" alt="How To Setup Charles Proxy - Requestly"
Introduction
Charles Proxy is a popular web debugging tool that helps developers and testers view all HTTP/S traffic between their machine and the internet. It’s widely used for troubleshooting, API testing, and monitoring network calls in real-time. In this guide, we’ll walk you through setting up Charles Proxy from scratch, so you can start intercepting network requests in no time.
Afterward we will take a look at a tool that provides similar functionality but with a modern and easy-to-use UI.
Step 1: Download and Install Charles Proxy
- Visit the official website: Head over to the Charles Proxy website and download the appropriate version for your operating system (Windows, macOS, or Linux).
- Run the installer: Follow the installation wizard prompts. On macOS, you may need to drag the app into the Applications folder. For Windows, follow the standard installation steps.
- Launch Charles Proxy: Once installed, open Charles Proxy. You’ll be greeted with a trial version screen if you haven’t purchased a license.
Step 2: Set Up SSL Proxying
Charles Proxy allows you to inspect HTTPS traffic as well. Here’s how to set it up:
Enabling SSL Proxying in Charles
- Open Charles Proxy.
- Go to the Proxy menu and select SSL Proxying Settings.
data:image/s3,"s3://crabby-images/d5235/d5235585e8a21f0acae68c5abae029fc2495f80d" alt="SSL Proxy settings - Requestly"
- In the pop-up window, click Add in the Include section to specify the domains you want to decrypt.
data:image/s3,"s3://crabby-images/70a91/70a9166266295339b450edd52427430f965cab5e" alt="SSL Proxy Setting popup - Requestly"
- You can choose to decrypt traffic from all domains (by entering *) or specify certain domains like api.example.com.
data:image/s3,"s3://crabby-images/60698/606984b7056d74d86acd6b0edc5d956ddef5a646" alt="Set Up Location - Requestly"
- Click OK to save your settings.
Install the Charles Root Certificate
To inspect HTTPS traffic, Charles needs to act as a trusted certificate authority (CA). This requires installing a root certificate on your system or device.
On Windows
Go to Help > SSL Proxying > Install Charles Root Certificate.
data:image/s3,"s3://crabby-images/61a91/61a91c828eed8cf1fd5a8666b05f401e6d1e1136" alt="Install Root Cert windows - Requestly"
- A certificate installation window will appear here Click “ Install Certificate”
data:image/s3,"s3://crabby-images/36b76/36b762ffd64f013b4503b5961662c05e25fc5ba4" alt="Certificate Installation PopUp - Requestly"
- Now select between “Current User” or “Local Machine” as you prefer.
data:image/s3,"s3://crabby-images/08a12/08a12df4c2c535efbb3a0ec34dd7e98cc1eccde7" alt="Complete Import Setup - Requestly"
On Mac
Go to Help > SSL Proxying > Install Charles Root Certificate.
data:image/s3,"s3://crabby-images/ba083/ba0833c5c2407b442e4a7f47951cf658d997dbc3" alt="Install Charles Cert mac - Requestly"
- The Keychain Access window will open up. here select Charles proxy certificate
data:image/s3,"s3://crabby-images/5e1bb/5e1bba32a58ba2d38a2229746bee62eda1950fde" alt="Keychain Access Window - Requestly"
- Now click the “ When using this certificate” dropdown and select “ Always Trust “.
data:image/s3,"s3://crabby-images/7f89f/7f89ff7b4eb8418915889ec53366af179d283932" alt="Charles proxy trust window - Requestly"
On Linux
Go to Help > SSL Proxying > Install Charles Root Certificate.
data:image/s3,"s3://crabby-images/46427/4642715e99fac1221c1389c746e4d983d16efc92" alt="Install Charles Cert Linux - Requestly"
- Your browser will download the certificate. Open the file, and the system will prompt you to install it.
data:image/s3,"s3://crabby-images/6e3a4/6e3a45a5ee282618323a42016c99ab70db51d800" alt="Charles proxy installation popup linux - Requestly"
Step 4: Capture Network Traffic
- Start capturing traffic: Once the proxy settings are configured, go back to Charles Proxy, and hit the record button (the red dot) to start capturing requests.
- View traffic: As you browse the web or use apps, you’ll start seeing requests and responses in Charles’s main window. You can filter, inspect, and export this data for debugging purposes.
data:image/s3,"s3://crabby-images/9eb0f/9eb0fcf2c622ec74d8379cc451c3e2d50808631a" alt="Intercepting traffic in charles proxy - Requestly"
Requestly: An Easier Alternative to Charles Proxy
Requestly offers an easier, browser-based alternative for users who find Charles Proxy complex. It provides similar functionality through a more user-friendly interface, making it ideal for quick web traffic modifications without the need for advanced setup. Unlike Charles Proxy, which lacks a Chrome Extension, Requestly offers extensive functionality directly as a browser extension, along with a standalone desktop app for more advanced use cases. For every feature in Charles Proxy, there’s a corresponding tool in Requestly, such as redirecting URLs, modifying headers, and blocking requests.
data:image/s3,"s3://crabby-images/a57d6/a57d6f8f5e2999e54eb9412b5d280e46c9eb0948" alt="Requestly Features - Requestly"
Check out our other blogs on Charles proxy tools to see the comparison
Conclusion
Setting up Charles Proxy allows you to inspect and debug network traffic in real-time, making it an invaluable tool for developers and testers. By following the steps outlined in this guide, you should be able to set up Charles Proxy and start capturing HTTP/S traffic quickly.
Contents
Subscribe for latest updates
Share this article
Related posts
data:image/s3,"s3://crabby-images/bc266/bc266d76a17095ffc5b05d3d34ebd4cf294cdeb0" alt="How to use access token from another API response - Requestly"
data:image/s3,"s3://crabby-images/79d63/79d63da2c7d1904519129acf457cf10a8b6f77bd" alt="Cyrisma uses Requestly - Requestly"