1
0
Fork 0
mirror of https://github.com/actix/actix-web.git synced 2025-01-23 07:28:06 +00:00
actix-web/actix-http
2024-02-03 23:55:01 +00:00
..
benches chore: remove allow(uninlined_format_args) 2023-12-16 10:33:00 +00:00
examples Rustls v0.22 support (#3275) 2024-02-03 23:55:01 +00:00
src Rustls v0.22 support (#3275) 2024-02-03 23:55:01 +00:00
tests Rustls v0.22 support (#3275) 2024-02-03 23:55:01 +00:00
Cargo.toml Rustls v0.22 support (#3275) 2024-02-03 23:55:01 +00:00
CHANGES.md Rustls v0.22 support (#3275) 2024-02-03 23:55:01 +00:00
LICENSE-APACHE prepare release beta 4 (#1659) 2020-09-09 22:14:11 +01:00
LICENSE-MIT prepare release beta 4 (#1659) 2020-09-09 22:14:11 +01:00
README.md chore(actix-http): prepare release 3.5.1 2023-12-25 02:30:14 +00:00

actix-http

HTTP types and services for the Actix ecosystem.

crates.io Documentation Version MIT or Apache 2.0 licensed
dependency status Download Chat on Discord

Documentation & Resources

Examples

use std::{env, io};

use actix_http::{HttpService, Response};
use actix_server::Server;
use futures_util::future;
use http::header::HeaderValue;
use tracing::info;

#[actix_rt::main]
async fn main() -> io::Result<()> {
    env::set_var("RUST_LOG", "hello_world=info");
    env_logger::init();

    Server::build()
        .bind("hello-world", "127.0.0.1:8080", || {
            HttpService::build()
                .client_timeout(1000)
                .client_disconnect(1000)
                .finish(|_req| {
                    info!("{:?}", _req);
                    let mut res = Response::Ok();
                    res.header("x-head", HeaderValue::from_static("dummy value!"));
                    future::ok::<_, ()>(res.body("Hello world!"))
                })
                .tcp()
        })?
        .run()
        .await
}