Go to file
Yury Yarashevich a5f8534573 Check WS stream completed after close. 2023-08-01 16:39:16 +02:00
.cargo
.github Bump JamesIves/github-pages-deploy-action from 4.4.1 to 4.4.3 (#3076) 2023-07-19 23:43:25 +01:00
actix-files apply standard formatting 2023-07-17 02:38:12 +01:00
actix-http add payload to_bytes helpers (#3083) 2023-07-22 02:02:29 +01:00
actix-http-test refactor: remove web dev dep from http-test 2023-07-22 02:02:37 +01:00
actix-multipart fix tempfile dep spec 2023-07-18 02:22:09 +01:00
actix-multipart-derive update syn to 2 in web codegen (#3081) 2023-07-20 10:49:01 +01:00
actix-router chore: address clippy warnings 2023-07-20 11:42:20 +01:00
actix-test doc amendments 2023-07-19 19:27:20 +01:00
actix-web modernize ContentLength 2023-07-22 18:01:59 +01:00
actix-web-actors Check WS stream completed after close. 2023-08-01 16:39:16 +02:00
actix-web-codegen update syn to 2 in web codegen (#3081) 2023-07-20 10:49:01 +01:00
awc Check WS stream completed after close. 2023-08-01 16:30:37 +02:00
docs/graphs
scripts
.gitignore
.prettierrc.yaml
.rustfmt.toml apply standard formatting 2023-07-17 02:38:12 +01:00
CHANGES.md
CODE_OF_CONDUCT.md
Cargo.toml
LICENSE-APACHE
LICENSE-MIT
README.md
clippy.toml
codecov.yml

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.65+

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 for 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-web repo is organized under the terms of the Contributor Covenant. The Actix team promises to intervene to uphold that code of conduct.