#hyper-server #https #hyper #https-server #tls #http #rustls

flexible-hyper-server-tls

在使用hyper时,轻松选择HTTP或HTTPS。

6个版本

0.3.0 2024年3月15日
0.2.1 2024年3月14日
0.2.0 2024年1月1日
0.1.2 2023年12月20日
0.1.1 2023年7月26日

#10 in #https-server

Download history 104/week @ 2024-03-25 266/week @ 2024-04-01 315/week @ 2024-04-08 271/week @ 2024-04-15 120/week @ 2024-04-22 219/week @ 2024-04-29 281/week @ 2024-05-06 202/week @ 2024-05-13 96/week @ 2024-05-20 241/week @ 2024-05-27 274/week @ 2024-06-03 739/week @ 2024-06-10 133/week @ 2024-06-17 255/week @ 2024-06-24 268/week @ 2024-07-01 126/week @ 2024-07-08

每月 1,031 次下载
用于 product-os-server

MIT/Apache

16KB
181

Flexible Hyper Server TLS

一个库,允许您在使用Hyper时选择是否接受HTTPS或HTTP连接。对于应用程序自行托管且用户可以可选提供自己的HTTPS证书的情况非常有用。

此库还提供了一些辅助函数,通过使用Rustls的默认安全设置来简化TLS设置。

此库的目标是简单且依赖性最小,同时仍然允许用户自定义TLS配置等。

对于不需要在HTTP和HTTPS之间选择的情况,请查看simple-hyper-server-tlstls-listener

使用方法

use flexible_hyper_server_tls::*;
use http_body_util::Full;
use hyper::body::{Bytes, Incoming};
use hyper::service::service_fn;
use hyper::{Request, Response};
use std::convert::Infallible;
use tokio::net::TcpListener;

async fn hello_world(_req: Request<Incoming>) -> Result<Response<Full<Bytes>>, Infallible> {
    Ok(Response::new(Full::<Bytes>::from("Hello, World!")))
}

#[tokio::main]
async fn main() {
    let use_tls = true;

    let listener = TcpListener::bind("127.0.0.1:8080").await.unwrap();

    let builder = AcceptorBuilder::new(listener);

    let mut acceptor = if use_tls {
        let tls_acceptor =
            rustls_helpers::get_tlsacceptor_from_files("./cert.cer", "./key.pem").unwrap();
        builder.https(tls_acceptor).build()
    } else {
        builder.build()
    };

    acceptor.serve(service_fn(hello_world)).await;
}

依赖项

~12–22MB
~396K SLoC