1
0
mirror of https://github.com/actix/actix-website synced 2025-02-13 00:25:35 +01:00

32 lines
870 B
Rust
Raw Normal View History

2018-05-24 10:13:55 -07:00
// <url>
2020-09-12 16:21:54 +01:00
use actix_web::{get, guard, http::header, HttpRequest, HttpResponse, Result};
2018-05-24 10:13:55 -07:00
2020-09-12 16:21:54 +01:00
#[get("/test/")]
2019-12-29 04:10:02 +09:00
async fn index(req: HttpRequest) -> Result<HttpResponse> {
2018-05-24 10:13:55 -07:00
let url = req.url_for("foo", &["1", "2", "3"])?; // <- generate url for "foo" resource
2019-06-25 18:20:36 -04:00
2018-05-24 10:13:55 -07:00
Ok(HttpResponse::Found()
.header(header::LOCATION, url.as_str())
.finish())
}
2020-09-12 16:21:54 +01:00
#[actix_web::main]
2019-12-29 04:10:02 +09:00
async fn main() -> std::io::Result<()> {
2019-06-28 13:31:30 -04:00
use actix_web::{web, App, HttpServer};
2019-06-25 18:20:36 -04:00
HttpServer::new(|| {
App::new()
.service(
web::resource("/test/{a}/{b}/{c}")
.name("foo") // <- set resource name, then it could be used in `url_for`
.guard(guard::Get())
.to(|| HttpResponse::Ok()),
)
2020-09-12 16:21:54 +01:00
.service(index)
2019-06-25 18:20:36 -04:00
})
2020-09-12 16:21:54 +01:00
.bind("127.0.0.1:8080")?
2019-06-25 18:20:36 -04:00
.run()
2019-12-29 04:10:02 +09:00
.await
2018-05-24 10:13:55 -07:00
}
// </url>