mirror of
https://github.com/actix/actix-web.git
synced 2025-01-23 23:48:06 +00:00
50 lines
1.7 KiB
Markdown
50 lines
1.7 KiB
Markdown
# `actix-http`
|
|
|
|
> HTTP types and services for the Actix ecosystem.
|
|
|
|
<!-- prettier-ignore-start -->
|
|
|
|
[![crates.io](https://img.shields.io/crates/v/actix-http?label=latest)](https://crates.io/crates/actix-http)
|
|
[![Documentation](https://docs.rs/actix-http/badge.svg?version=3.7.0)](https://docs.rs/actix-http/3.7.0)
|
|
![Version](https://img.shields.io/badge/rustc-1.72+-ab6000.svg)
|
|
![MIT or Apache 2.0 licensed](https://img.shields.io/crates/l/actix-http.svg)
|
|
<br />
|
|
[![dependency status](https://deps.rs/crate/actix-http/3.7.0/status.svg)](https://deps.rs/crate/actix-http/3.7.0)
|
|
[![Download](https://img.shields.io/crates/d/actix-http.svg)](https://crates.io/crates/actix-http)
|
|
[![Chat on Discord](https://img.shields.io/discord/771444961383153695?label=chat&logo=discord)](https://discord.gg/NWpN5mmg3x)
|
|
|
|
<!-- prettier-ignore-end -->
|
|
|
|
## Examples
|
|
|
|
```rust
|
|
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
|
|
}
|
|
```
|