mirror of
https://github.com/fafhrd91/actix-web
synced 2025-01-18 05:41:50 +01:00
Christopher Armstrong
884ea02f5c
Allow returning failure::Error from handlers (#65)
This implements From<failure::Error> for Error (by way of `failure::Compat`) and ResponseError for failure::Compat<T>.
Actix web
Actix web is a small, fast, pragmatic, open source rust web framework.
- Supported HTTP/1.x and HTTP/2.0 protocols
- Streaming and pipelining
- Keep-alive and slow requests handling
- Client/server WebSockets support
- Transparent content compression/decompression (br, gzip, deflate)
- Configurable request routing
- Graceful server shutdown
- Multipart streams
- Middlewares (Logger, Session, DefaultHeaders, CORS)
- Built on top of Actix.
Documentation
- User Guide
- API Documentation (Development)
- API Documentation (Releases)
- Chat on gitter
- Cargo package: actix-web
- Minimum supported Rust version: 1.21 or later
Example
extern crate actix_web;
use actix_web::*;
fn index(req: HttpRequest) -> String {
format!("Hello {}!", &req.match_info()["name"])
}
fn main() {
HttpServer::new(
|| Application::new()
.resource("/{name}", |r| r.f(index)))
.bind("127.0.0.1:8080").unwrap()
.run();
}
More examples
- Basics
- Stateful
- Mulitpart streams
- Simple websocket session
- Tera templates
- Diesel integration
- SSL / HTTP/2.0
- Tcp/Websocket chat
- SockJS Server
- Json
Benchmarks
Some basic benchmarks could be found in this respository.
License
This project is licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Code of Conduct
Contribution to the actix-web crate is organized under the terms of the Contributor Covenant, the maintainer of actix-web, @fafhrd91, promises to intervene to uphold that code of conduct.
Description
Actix web is a small, pragmatic, and extremely fast rust web framework. https://actix.rs
Languages
Rust
99.4%
Shell
0.4%
Just
0.2%