mirror of
https://github.com/actix/examples
synced 2025-02-23 09:43:03 +01:00
44 lines
1.4 KiB
Rust
44 lines
1.4 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<()> {
|
|
env_logger::init_from_env(env_logger::Env::new().default_filter_or("info"));
|
|
|
|
// 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();
|
|
|
|
log::info!("starting HTTPS server at http://localhost:8443");
|
|
|
|
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
|
|
}
|