Rust Axum前后端分离项目-项目初始化


一、创建Rust项目

使用命令创建项目

cargo new question_bank

二、添加依赖

1.在shell或者命令行中运行以下命令

cargo add anyhow
cargo add serde --featrues derive
cargo add serde-json
cargo add axum
cargo add tokio --features full
cargo add tower-http --features trace

2.直接修改Cargo.toml文件添加依赖

axum = "0.7.5"
serde = { version = "1.0.203", features = ["derive"] }
serde_json = "1.0.118"
tokio = { version = "1.38.0", features = ["full"] }
tower-http = { version = "0.5.2", features = ["trace"] }

三、编写http服务代码

在main.rs 中插入以下代码

use axum::{response::Html, routing::get, Router};

#[tokio::main]
async fn main() {
    let app = Router::new().route("/hello", get(get_str));
    let listener = tokio::net::TcpListener::bind("0.0.0.0:8080").await.unwrap();
    println!("服务器启动在:{}", listener.local_addr().unwrap());
    axum::serve(listener, app).await.unwrap();
}

async fn get_str() -> Html<&'static str> {
    Html("<h1>Hello World</h1>".into())
}

四、添加日志输出

1. 添加以下依赖

  1. 在shell或命令行中运行以下命令
cargo add tracing
cargo add tracing-subscriber
  1. 在Cargo.toml [dependencies]中添加内容
tracing = "0.1.40"
tracing-subscriber = "0.3.18"

2. 修改main.rs文件

日志默认输出级别为INFO,

use axum::{response::Html, routing::get, Router};
use tower_http::trace::TraceLayer;
use tracing::info;

#[tokio::main]
async fn main() {
    // 初始化日志输出
    tracing_subscriber::fmt::init();
    // 初始化路由
    let app = Router::new()
        .route("/hello", get(get_str))
        // 配置日志中间件
        .layer(TraceLayer::new_for_http());
    // 监听tcp端口
    let listener = tokio::net::TcpListener::bind("0.0.0.0:8080").await.unwrap();
    info!("服务器启动在:{}", listener.local_addr().unwrap());
    // 启动axum服务
    axum::serve(listener, app).await.unwrap();
}

async fn get_str() -> Html<&'static str> {
    Html("<h1>Hello World</h1>".into())
}


五、 运行http服务器

1. 在命令行中运行以下命令

  1. 直接运行
cargo run
  1. 构建
cargo build
  1. 发布release版本
cargo build --release

在浏览器中的运行结果

  • 9
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的示例,展示如何使用Rust后端框架Axum来创建一个基本的Web应用程序: 首先,确保您已经安装Rust和Cargo。然后,在您的项目目录中创建一个新的Cargo.toml文件,并添加以下内容: ```toml [package] name = "axum_example" version = "0.1.0" edition = "2021" [dependencies] axum = "0.2" tokio = { version = "1", features = ["full"] } ``` 接下来,创建一个main.rs文件,并添加以下代码: ```rust use axum::{handler::get, Router}; use std::net::SocketAddr; async fn hello_world() -> &'static str { "Hello, world!" } #[tokio::main] async fn main() { // 创建一个Axum应用程序的根路由 let app = Router::new().route("/", get(hello_world)); // 定义服务器的地址和端口 let addr = SocketAddr::from(([127, 0, 0, 1], 3000)); // 运行服务器 axum::Server::bind(&addr) .serve(app.into_make_service()) .await .unwrap(); } ``` 上述代码创建了一个简单的Axum应用程序,该应用程序定义了一个根路由"/",并使用GET方法处理请求。处理程序函数hello_world返回一个字符串"Hello, world!"作为响应。 最后,打开终端,导航到您的项目目录,并运行以下命令来构建和运行应用程序: ``` cargo build cargo run ``` 您应该会看到类似于以下输出: ``` Listening on http://127.0.0.1:3000 ``` 现在,您可以在浏览器中访问http://127.0.0.1:3000,并应该看到"Hello, world!"的响应。 这只是Axum的一个简单示例,您可以根据需要添加更多的路由和处理程序来构建更复杂的应用程序。Axum提供了许多功能和中间件,使您能够处理不同类型的请求和实现复杂的业务逻辑。您可以参考Axum的官方文档以获得更多详细信息和示例代码:https://docs.rs/axum/0.2.5/axum/

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值