mirror of
https://github.com/actix/examples
synced 2025-02-02 17:39:05 +01:00
45 lines
1.3 KiB
Rust
45 lines
1.3 KiB
Rust
use std::io;
|
|
|
|
use actix_web::{middleware, web, App, Error, HttpRequest, HttpResponse, HttpServer};
|
|
use openssl::ssl::{SslAcceptor, SslFiletype, SslMethod};
|
|
|
|
/// simple handle
|
|
async fn index(req: HttpRequest) -> Result<HttpResponse, Error> {
|
|
println!("{req:?}");
|
|
Ok(HttpResponse::Ok()
|
|
.content_type("text/plain")
|
|
.body("Welcome!"))
|
|
}
|
|
|
|
#[actix_web::main]
|
|
async fn main() -> io::Result<()> {
|
|
std::env::set_var("RUST_LOG", "actix_web=debug");
|
|
env_logger::init();
|
|
|
|
println!("Started http server: 127.0.0.1:8443");
|
|
|
|
// load TLS keys
|
|
let mut builder = SslAcceptor::mozilla_intermediate(SslMethod::tls()).unwrap();
|
|
builder
|
|
.set_private_key_file("key.pem", SslFiletype::PEM)
|
|
.unwrap();
|
|
builder.set_certificate_chain_file("cert.pem").unwrap();
|
|
|
|
HttpServer::new(|| {
|
|
App::new()
|
|
// enable logger
|
|
.wrap(middleware::Logger::default())
|
|
// register simple handler, handle all methods
|
|
.service(web::resource("/index.html").to(index))
|
|
// with path parameters
|
|
.service(web::resource("/").route(web::get().to(|| async {
|
|
HttpResponse::Found()
|
|
.append_header(("LOCATION", "/index.html"))
|
|
.finish()
|
|
})))
|
|
})
|
|
.bind_openssl("127.0.0.1:8443", builder)?
|
|
.run()
|
|
.await
|
|
}
|