2018-05-22 23:15:08 +02:00
{{ partial "header" . }}
2018-06-23 11:36:37 +08:00
< div id = "act-home" >
< div class = "jumbotron" >
< div class = "actix-jumbotron" >
< img src = "/img/logo-large.png" class = "align-middle actix-logo" alt = "" >
< p class = "lead" > rust's powerful actor system and most fun web framework< / p >
< / div >
2018-05-22 23:15:08 +02:00
< / div >
2018-06-23 11:36:37 +08:00
< div class = "container actix-home" >
< div class = "row" >
< div class = "col-md-4" >
< div class = "actix-features" >
< h2 >
< i class = "fa fa-fw fa-shield" aria-hidden = "true" > < / i >
Type Safe
< / h2 >
< p > Forget about stringly typed objects, from request to response, everything has types.< / p >
2018-05-22 23:15:08 +02:00
2018-06-23 11:36:37 +08:00
< h2 >
< i class = "fa fa-fw fa-battery-full" aria-hidden = "true" > < / i >
Feature Rich
< / h2 >
< p > Actix provides a lot of features out of box. WebSockets, HTTP/2, pipelining etc.< / p >
2018-05-22 23:15:08 +02:00
2018-06-23 11:36:37 +08:00
< h2 >
< i class = "fa fa-fw fa-puzzle-piece" aria-hidden = "true" > < / i >
Extensible
< / h2 >
< p > Easily create your own libraries that any Actix application can use.< / p >
2018-05-22 23:15:08 +02:00
< h2 >
< i class = "fa fa-fw fa-dashboard" aria-hidden = "true" > < / i >
Blazingly Fast
< / h2 >
2018-06-20 08:38:30 +03:00
< p > Actix is blazingly fast. Don't take our word for it -- < a href = "https://www.techempower.com/benchmarks/#section=data-r16&hw=ph&test=plaintext" > see for yourself!< / a > < / p >
2018-05-22 23:15:08 +02:00
< / div >
2018-07-14 20:27:51 +02:00
< / div >
< div class = "col-md-8" >
< div class = "actix-content" >
2019-06-12 04:51:45 -04:00
{{ highlight `use actix_web::{web, App, HttpRequest, HttpResponse, HttpServer};
2018-05-22 23:15:08 +02:00
2019-06-12 04:51:45 -04:00
fn greet(req: HttpRequest) -> HttpResponse {
let name = req.match_info().get("name").unwrap_or("World");
HttpResponse::Ok().body(format!("Hello {}!", & name))
2018-05-22 23:15:08 +02:00
}
fn main() {
2019-06-12 04:51:45 -04:00
HttpServer::new(|| {
2018-05-22 23:15:08 +02:00
App::new()
2019-06-12 04:51:45 -04:00
.service(web::resource("/").to(greet))
.service(web::resource("/{name}").to(greet))
2018-05-22 23:15:08 +02:00
})
.bind("127.0.0.1:8000")
.expect("Can not bind to port 8000")
2019-06-12 04:51:45 -04:00
.run()
.unwrap();
2018-05-22 23:15:08 +02:00
}` "rust" "" }}
2018-06-23 11:36:37 +08:00
< / div >
2018-05-22 23:15:08 +02:00
< / div >
< / div >
2018-06-23 11:36:37 +08:00
< div class = "actix-showcase" >
< div class = "col-md-9" >
< div class = "actix-feature" id = "responders" >
< h2 > Flexible Responders< / h2 >
< p >
Handler functions in actix can return a wide range of objects that
implement the < code > Responder< / code > trait. This makes it a breeze
to return consistent responses from your APIs.
< / p >
{{ highlight `#[derive(Serialize)]
2018-05-23 20:15:15 +02:00
struct Measurement {
temperature: f32,
}
fn hello_world() -> impl Responder {
"Hello World!"
}
fn current_temperature(_req: HttpRequest) -> impl Responder {
Json(Measurement { temperature: 42.3 })
}` "rust" "" }}
2018-06-23 11:36:37 +08:00
< / div >
< div class = "actix-feature" id = "extractors" >
< h2 > Powerful Extractors< / h2 >
< p >
Actix comes with a powerful extractor system that extracts data
from the incoming HTTP request and passes it to your view functions.
Not only does this make for a convenient API but it also means that
your view functions can be synchronous code and still benefit
from asynchronous IO handling.
< / p >
{{ highlight `#[derive(Deserialize)]
2018-05-23 20:15:15 +02:00
struct Event {
timestamp: f64,
kind: String,
tags: Vec< String > ,
}
fn capture_event(evt: Json< Event > ) -> impl Responder {
let id = store_event_in_db(evt.timestamp, evt.kind, evt.tags);
format!("got event {}", id)
}` "rust" "" }}
2018-06-23 11:36:37 +08:00
< / div >
< div class = "actix-feature" id = "forms" >
< h2 > Easy Form Handling< / h2 >
< p >
Handling multipart/urlencoded form data is easy. Just define
a structure that can be deserialized and actix will handle
the rest.
< / p >
{{ highlight `#[derive(Deserialize)]
2018-05-23 20:15:15 +02:00
struct Register {
username: String,
country: String,
}
fn register(data: Form< Register > ) -> impl Responder {
format!("Hello {} from {}!", data.username, data.country)
2018-05-26 14:27:55 +02:00
}` "rust" "" }}
2018-06-23 11:36:37 +08:00
< / div >
< div class = "actix-feature" id = "routing" >
< h2 > Request Routing< / h2 >
< p >
An actix app comes with a URL routing system that lets you match on
URLs and invoke individual handlers. For extra flexibility, scopes
can be used.
< / p >
{{ highlight `fn index(req: HttpRequest) -> impl Responder {
2018-05-26 14:27:55 +02:00
"Hello from the index page"
}
2018-05-30 16:09:30 -07:00
fn hello(path: Path< String > ) -> impl Responder {
format!("Hello {}!", *path)
2018-05-26 14:27:55 +02:00
}
fn main() {
App::new()
2019-01-08 17:19:09 +11:00
.resource("/", |r| r.method(Method::GET).with(index))
.resource("/hello/{name}", |r| r.method(Method::GET).with(hello))
2018-05-26 14:27:55 +02:00
.finish();
2018-05-23 20:15:15 +02:00
}` "rust" "" }}
2018-06-23 11:36:37 +08:00
< / div >
< / div >
< div class = "col-md-3 actix-feature-selectors" >
< ul >
< li class = "actix-feature-selector" > < a href = "#responders" > flexible responders< / label >
< li class = "actix-feature-selector" > < a href = "#extractors" > powerful extractors< / label >
< li class = "actix-feature-selector" > < a href = "#forms" > easy form handling< / label >
< li class = "actix-feature-selector" > < a href = "#routing" > request routing< / label >
< / ul >
2018-05-23 20:15:15 +02:00
< / div >
< / div >
< / div >
2018-05-22 23:15:08 +02:00
< / div >
{{ partial "footer" . }}