actix-web/actix-web
Maarten Deprez f01ccf7db0
Merge 116f7d13b0 into d119500f93
2025-11-16 15:54:53 +09:00
..
benches chore: address clippy warnings 2024-08-07 04:06:18 +01:00
examples chore: rename branch to main (#3821) 2025-11-05 20:13:50 +09:00
src Merge 116f7d13b0 into d119500f93 2025-11-16 15:54:53 +09:00
tests fix(actix-web): improve streaming response behavior for Content-Length and Content-Type (#3737) 2025-08-23 12:23:57 +09:00
CHANGES.md release: actix-web v4.12.0 (#3830) 2025-11-16 15:52:36 +09:00
Cargo.toml release: actix-web v4.12.0 (#3830) 2025-11-16 15:52:36 +09:00
LICENSE-APACHE move actix-web to own dir 2022-02-01 00:30:41 +00:00
LICENSE-MIT move actix-web to own dir 2022-02-01 00:30:41 +00:00
MIGRATION-0.x.md format markdown with prettier 2023-02-26 03:26:51 +00:00
MIGRATION-1.0.md format markdown with prettier 2023-02-26 03:26:51 +00:00
MIGRATION-2.0.md format markdown with prettier 2023-02-26 03:26:51 +00:00
MIGRATION-3.0.md chore(actix-http): prepare release 3.11.1 2025-08-26 07:28:27 +01:00
MIGRATION-4.0.md chore: rename branch to main (#3821) 2025-11-05 20:13:50 +09:00
README.md release: actix-web v4.12.0 (#3830) 2025-11-16 15:52:36 +09:00

README.md

Actix Web

Actix Web is a powerful, pragmatic, and extremely fast web framework for Rust

crates.io Documentation MSRV MIT or Apache 2.0 licensed Dependency Status
CI codecov downloads Chat on Discord

Features

  • Supports HTTP/1.x and HTTP/2
  • Streaming and pipelining
  • Powerful request routing with optional macros
  • Full Tokio compatibility
  • Keep-alive and slow requests handling
  • Client/server WebSockets support
  • Transparent content compression/decompression (br, gzip, deflate, zstd)
  • Multipart streams
  • Static assets
  • SSL support using OpenSSL or Rustls
  • Middlewares (Logger, Session, CORS, etc)
  • Integrates with the awc HTTP client
  • Runs on stable Rust 1.72+

Documentation

Example

Dependencies:

[dependencies]
actix-web = "4"

Code:

use actix_web::{get, web, App, HttpServer, Responder};

#[get("/hello/{name}")]
async fn greet(name: web::Path<String>) -> impl Responder {
    format!("Hello {name}!")
}

#[actix_web::main] // or #[tokio::main]
async fn main() -> std::io::Result<()> {
    HttpServer::new(|| {
        App::new().service(greet)
    })
    .bind(("127.0.0.1", 8080))?
    .run()
    .await
}

More Examples

You may consider checking out [this directory](https://github.com/actix/examples/tree/mainfor more examples.

Benchmarks

One of the fastest web frameworks available according to the TechEmpower Framework Benchmark.

License

This project is licensed under either of the following licenses, at your option:

Code of Conduct

Contribution to the actix/actix-web repo is organized under the terms of the Contributor Covenant. The Actix team promises to intervene to uphold that code of conduct.