real-ip

Crates.ioreal-ip
lib.rsreal-ip
version0.1.0
sourcesrc
created_at2024-11-29 19:09:54.233122
updated_at2024-11-29 19:09:54.233122
descriptionGet the "real ip" of an incoming request using the "forwarded", "x-forwarded-for" or "x-real-ip" headers set by reverse proxies.
homepage
repositoryhttps://github.com/icewind1991/real-ip
max_upload_size
id1465952
size13,284
Robin Appelman (icewind1991)

documentation

README

real-ip

Get the "real-ip" of an incoming request using the "forwarded", "x-forwarded-for" or "x-real-ip" headers set by reverse proxies.

See the crate documentation for more details and examples.

Example

use http::Request;
use std::net::IpAddr;
use real_ip::{real_ip, IpNet};

// in a real program this info would of course come from the http server
let incoming_ip = IpAddr::from([10, 0, 0, 1]);
let request = Request::builder().header("x-forwarded-for", "192.0.2.1").body(()).unwrap();

// the reverse-proxies in our network that we trust
let trusted_proxies = [
    IpAddr::from([10, 0, 0, 1]).into(),
];
let client_ip = real_ip(request.headers(), incoming_ip, &trusted_proxies);
assert_eq!(Some(IpAddr::from([192, 0, 2, 1])), client_ip);
Commit count: 9

cargo fmt