Skip to content

Files

This branch is 1 commit behind hyperium/hyper:master.

examples

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
Nov 16, 2023
Dec 6, 2024
Jul 10, 2023
Jul 10, 2023
Dec 6, 2024
Sep 5, 2023
Nov 29, 2024
May 10, 2024
Dec 6, 2024
Jul 10, 2023
Oct 28, 2023
Apr 3, 2024
Apr 24, 2020
May 3, 2024
Dec 6, 2024
Jul 10, 2023
Dec 6, 2024
Dec 6, 2024

Examples of using hyper

These examples show how to do common tasks using hyper. You may also find the Guides helpful.

If you checkout this repository, you can run any of the examples with the command:

cargo run --example {example_name} --features="full"

Dependencies

A complete list of dependencies used across these examples:

[dependencies]
hyper = { version = "1", features = ["full"] }
tokio = { version = "1", features = ["full"] }
pretty_env_logger = "0.5"
http-body-util = "0.1"
bytes = "1"
serde = { version = "1.0", features = ["derive"] }
serde_json = "1.0"
form_urlencoded = "1"
http = "1"
futures-util = { version = "0.3", default-features = false }

Getting Started

Clients

  • client - A simple CLI http client that requests the url passed in parameters and outputs the response content and details to the stdout, reading content chunk-by-chunk.

  • client_json - A simple program that GETs some json, reads the body asynchronously, parses it with serde and outputs the result.

Servers

  • hello - A simple server that returns "Hello World!".

  • echo - An echo server that copies POST request's content to the response content.

Going Further

  • gateway - A server gateway (reverse proxy) that proxies to the hello service above.

  • graceful_shutdown - A server that has a timeout for incoming connections and does graceful connection shutdown.

  • http_proxy - A simple HTTP(S) proxy that handle and upgrade CONNECT requests and then proxy data between client and remote server.

  • multi_server - A server that listens to two different ports, a different Service per port.

  • params - A webserver that accept a form, with a name and a number, checks the parameters are presents and validates the input.

  • send_file - A server that sends back content of files using tokio-util to read the files asynchronously.

  • service_struct_impl - A struct that manually implements the Service trait and uses a shared counter across requests.

  • single_threaded - A server only running on 1 thread, so it can make use of !Send app state (like an Rc counter).

  • state - A webserver showing basic state sharing among requests. A counter is shared, incremented for every request, and every response is sent the last count.

  • upgrades - A server and client demonstrating how to do HTTP upgrades (such as WebSockets).

  • web_api - A server consisting in a service that returns incoming POST request's content in the response in uppercase and a service that calls the first service and includes the first service response in its own response.