ubuntu

如何在Ubuntu中使用Rust进行Web开发

小樊
40
2025-09-25 08:13:33
栏目: 编程语言

在Ubuntu中使用Rust进行Web开发的完整流程

1. 准备开发环境

在Ubuntu上,首先需要安装Rust工具链和必要的系统依赖:

2. 创建Rust项目

使用Cargo创建一个新的Web项目(以my_rust_web_app为例):

cargo new my_rust_web_app
cd my_rust_web_app

Cargo会自动生成Cargo.toml(依赖管理)和src/main.rs(主程序)文件。

3. 选择Web框架

Rust生态中有4个主流Web框架,根据项目需求选择:

4. 添加框架依赖

Axum为例,在Cargo.toml中添加核心依赖及工具库:

[dependencies]
axum = "0.7"          # Axum框架核心
tokio = { version = "1.0", features = ["full"] }  # 异步运行时
serde = { version = "1.0", features = ["derive"] } # JSON序列化/反序列化
serde_json = "1.0"    # JSON处理
tower-http = "0.4"    # 高级中间件(如CORS、日志)

其他框架的依赖可参考官方文档(如Actix-web需添加actix-web = "4.0")。

5. 编写Web服务代码

以Axum为例,在src/main.rs中创建一个简单的HTTP服务器:

use axum::{
    routing::get,        // 路由GET请求
    Router,               // 路由容器
    Json,                 // JSON响应包装器
};
use serde::Serialize;   // 结构体序列化
use std::net::SocketAddr;

// 定义响应数据结构
#[derive(Serialize)]
struct HelloWorld {
    message: String,
}

// 处理GET请求的异步函数
async fn hello() -> Json<HelloWorld> {
    Json(HelloWorld {
        message: "Hello from Rust Web!".to_string(),
    })
}

#[tokio::main] // 异步运行时入口
async fn main() {
    // 构建路由:将根路径"/"映射到hello函数
    let app = Router::new().route("/", get(hello));

    // 绑定地址(127.0.0.1:3000)并启动服务器
    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
    println!("Server running at http://{}", addr);
    axum::Server::bind(&addr)
        .serve(app.into_make_service())
        .await
        .unwrap();
}

代码说明:

6. 运行与测试

在项目根目录下执行以下命令启动服务器:

cargo run

终端输出Server running at http://127.0.0.1:3000后,打开浏览器或使用curl访问:

curl http://127.0.0.1:3000

将返回JSON响应:

{"message":"Hello from Rust Web!"}

7. 扩展功能(数据库/表单处理)

数据库集成(以PostgreSQL为例)

  1. 添加依赖:在Cargo.toml中添加sqlx(异步SQL库)和PostgreSQL驱动:
    sqlx = { version = "0.7", features = ["postgres", "runtime-tokio-native-tls", "macros"] }
    dotenv = "0.15"       # 环境变量管理
    
  2. 创建.env文件存储数据库配置:
    DATABASE_URL=postgres://username:password@localhost/mydb
    
  3. 编写数据库查询代码(如获取用户列表):
    use sqlx::PgPool;
    use serde::Serialize;
    
    #[derive(Serialize)]
    struct User {
        id: i32,
        name: String,
    }
    
    async fn get_users(pool: PgPool) -> Result<Json<Vec<User>>, sqlx::Error> {
        let users = sqlx::query_as!(
            User,
            "SELECT id, name FROM users"
        )
        .fetch_all(&pool)
        .await?;
        Ok(Json(users))
    }
    
  4. 修改路由以传递数据库连接池:
    use std::sync::Arc;
    use axum::extract::State;
    
    #[tokio::main]
    async fn main() {
        // 初始化数据库连接池
        let database_url = std::env::var("DATABASE_URL").expect("DATABASE_URL not set");
        let pool = PgPool::connect(&database_url).await.expect("Failed to connect to DB");
        let pool = Arc::new(pool);
    
        // 将连接池注入路由状态
        let app = Router::new()
            .route("/users", get(get_users))
            .with_state(pool);
    
        // 启动服务器...
    }
    
    async fn get_users(State(pool): State<Arc<PgPool>>) -> Result<Json<Vec<User>>, sqlx::Error> {
        // 使用pool查询数据库...
    }
    

表单处理

使用serde解析POST请求中的表单数据(如登录表单):

use axum::{
    routing::post,
    Form,
    Json,
};
use serde::Deserialize;

#[derive(Deserialize)]
struct LoginForm {
    username: String,
    password: String,
}

async fn login(Form(login_data): Form<LoginForm>) -> Json<serde_json::Value> {
    // 验证用户名密码...
    Json(serde_json::json!({
        "status": "success",
        "message": format!("Welcome, {}!", login_data.username)
    }))
}

// 在路由中添加POST路由
let app = Router::new()
    .route("/login", post(login));

8. 部署

Ubuntu上部署Rust Web应用通常使用Nginx反向隧道Docker容器化

通过以上步骤,即可在Ubuntu上完成Rust Web应用的开发、测试与部署。根据项目需求选择合适的框架(如Axum适合快速开发,Actix-web适合高并发),并利用Rust生态中的工具(如sqlxserde)扩展功能。

0
看了该问题的人还看了