Replaces the now-incorrect Note at the bottom of c16-proxy ("cpp-httplib
does not read HTTP_PROXY...") with the actual API.
JA is the master per the project's translation workflow; the EN
translation lands in the same PR. Both pages remain `status: "draft"`
for normal review.
Adds two sections:
- Bypass the proxy for specific hosts (set_no_proxy):
pattern syntax, dot-boundary rule, case-insensitivity, IP
normalization via inet_pton, port-specific-entries unsupported,
malformed entries dropped.
- Read proxy settings from the environment (set_proxy_from_env):
which variables are read, lowercase-only http_proxy with an
inline httpoxy / CVE-2016-5385 explanation, threading caveat.
3.7 KiB
title, order, status
| title | order | status |
|---|---|---|
| C16. Send Requests Through a Proxy | 16 | draft |
To route traffic through a corporate network or a specific path, send requests via an HTTP proxy. Just pass the proxy host and port to set_proxy().
Basic usage
httplib::Client cli("https://api.example.com");
cli.set_proxy("proxy.internal", 8080);
auto res = cli.Get("/users");
The request goes through the proxy. For HTTPS, the client uses the CONNECT method to tunnel through — no extra setup required.
Proxy authentication
If the proxy itself requires authentication, use set_proxy_basic_auth() or set_proxy_bearer_token_auth().
cli.set_proxy("proxy.internal", 8080);
cli.set_proxy_basic_auth("user", "password");
cli.set_proxy_bearer_token_auth("token");
If cpp-httplib is built with OpenSSL (or another TLS backend), you can also use Digest authentication for the proxy.
cli.set_proxy_digest_auth("user", "password");
Combine with end-server authentication
Proxy authentication is separate from authenticating to the end server (C05. Use Basic authentication, C06. Call an API with a Bearer token). When both are needed, set both.
cli.set_proxy("proxy.internal", 8080);
cli.set_proxy_basic_auth("proxy-user", "proxy-pass");
cli.set_bearer_token_auth("api-token"); // for the end server
Proxy-Authorization is sent to the proxy, Authorization to the end server.
Bypass the proxy for specific hosts
You often want internal endpoints to skip the proxy. Configure a bypass list with set_no_proxy().
cli.set_proxy("proxy.internal", 8080);
cli.set_no_proxy({"internal.corp", "10.0.0.0/8", "*.dev.local"});
Each entry is one of:
*— bypass the proxy for all hosts- a hostname suffix (e.g.
example.com) — matchesexample.comitself and any subdomain (foo.example.com). A leading dot is permitted but informational; both forms are equivalent. - a single IP literal (e.g.
192.168.1.1,::1) - a CIDR block (e.g.
10.0.0.0/8,fe80::/10)
Hostname matching is case-insensitive and uses a dot-boundary rule, so an entry of example.com does not match evilexample.com. IP comparisons are normalized through inet_pton, so 127.0.0.1 cannot be bypassed via alternate string forms (e.g. 127.000.000.001). When an entry matches, the Proxy-Authorization header is suppressed as well.
Malformed entries are silently dropped. Port-specific entries such as example.com:8080 are not supported (cpp-httplib's other host-keyed APIs are also keyed on hostname only).
Read proxy settings from the environment
Call set_proxy_from_env() at startup to pick up proxy configuration from environment variables.
httplib::Client cli("https://api.example.com");
cli.set_proxy_from_env();
Variables read:
https_proxy/HTTPS_PROXY— used by HTTPS clientshttp_proxy(lowercase only, see below) — used by HTTP clientsno_proxy/NO_PROXY— comma-separated bypass list
Returns true if at least one variable was found and applied.
Security Note: The uppercase
HTTP_PROXYis intentionally not read. In CGI/FastCGI environments, theHTTP_*namespace is used to expose HTTP request headers, which lets a remote attacker inject an arbitrary proxy URL via theProxy:request header (CVE-2016-5385 / "httpoxy"). cpp-httplib follows curl, Go, and Pythonrequestsin honoring only the lowercasehttp_proxy.HTTPS_PROXYandNO_PROXYare safe in either case because their names do not begin withHTTP_.
Note:
set_proxy_from_env()readsgetenvsynchronously; call it once at startup. Concurrentsetenvfrom other threads while this function runs is undefined.