Skip to content

A MITM Proxy Written in Rust 🦀! Toolkit for HTTP/1, HTTP/2, and WebSockets with SSL/TLS Capabilities. Learning Project.

License

Notifications You must be signed in to change notification settings

yuankunzhang/man-in-the-middle-proxy

 
 

Repository files navigation

Man In The Middle Proxy

Rust GitHub GitHub last commit GitHub top language

Description

Rust-based Man in the Middle proxy, an early-stage project aimed at providing visibility into network traffic. Currently, it displays both HTTP and HTTPS requests and responses, but our future goal is to allow for manipulation of the traffic for more advanced use cases.

Cast

Features

  • 🔐 HTTP / HTTP(s)
  • 🖱️ Gui
  • ⌨️ Possibility of choosing a customised address and listening port
  • 🔍 Details for each request and response
  • 🎯 Filtering the list of requests by method
  • ❌ Deleting a single request from the list
  • 🚫 Clear all requests and clean the table
  • 🌌 Dark / light theme

Getting Started

  1. Generate a Certificate:
  • go to ~proxyapi/src/ca/
  • start generation with following terminal command: openssl req -x509 -newkey rsa:4096 -keyout mitmproxy.key -out mitmproxy.cer -sha256 -days 700000 -nodes
  • You can just hit Enter to accept default options but keep in mind to add at least a common name

  1. Install .cer file locally and trust it.
  1. Configure your local system proxy on 127.0.0.1:8100.

Documentation and Help

If you have questions on how to use Man In The Middle Proxy, please use GitHub Discussions! GitHub Discussions

Contributing

Contributions are always welcome!

See contributing.md for ways to get started.

Please adhere to this project's code of conduct.

Licenses

See LICENSE-APACHE, LICENSE-MIT for details

Screenshots

Input of Listening Address

Mitm proxy Screenshot 1 Mitm proxy Screenshot 1

Requests List

Mitm proxy Screenshot 2 Mitm proxy Screenshot 2

Request and Response Details

Mitm proxy Screenshot 3 Mitm proxy Screenshot 3

About

A MITM Proxy Written in Rust 🦀! Toolkit for HTTP/1, HTTP/2, and WebSockets with SSL/TLS Capabilities. Learning Project.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 100.0%