Actix-Web REST API with JWT 项目教程
2024-08-19 12:41:38作者:瞿蔚英Wynne
1. 项目的目录结构及介绍
actix-web-rest-api-with-jwt/
├── Cargo.toml
├── src/
│ ├── main.rs
│ ├── models.rs
│ ├── schema.rs
│ ├── routes.rs
│ ├── handlers.rs
│ ├── db.rs
│ └── auth.rs
├── migrations/
├── .env
└── diesel.toml
Cargo.toml: Rust 项目的依赖和元数据配置文件。src/: 包含项目的所有源代码文件。main.rs: 项目的主入口文件。models.rs: 定义数据库模型。schema.rs: 自动生成的数据库表结构。routes.rs: 定义 API 路由。handlers.rs: 处理请求的逻辑。db.rs: 数据库连接和操作。auth.rs: JWT 认证相关逻辑。
migrations/: 数据库迁移脚本。.env: 环境变量配置文件。diesel.toml: Diesel ORM 的配置文件。
2. 项目的启动文件介绍
src/main.rs 是项目的启动文件,负责初始化服务器和启动服务。以下是 main.rs 的主要内容:
#[macro_use]
extern crate diesel;
extern crate dotenv;
use actix_web::{web, App, HttpServer};
use diesel::prelude::*;
use diesel::r2d2::{self, ConnectionManager};
mod routes;
mod handlers;
mod models;
mod db;
mod auth;
#[actix_web::main]
async fn main() -> std::io::Result<()> {
dotenv::dotenv().ok();
let database_url = std::env::var("DATABASE_URL").expect("DATABASE_URL must be set");
let manager = ConnectionManager::<PgConnection>::new(database_url);
let pool = r2d2::Pool::builder()
.build(manager)
.expect("Failed to create pool.");
HttpServer::new(move || {
App::new()
.data(pool.clone())
.configure(routes::init_routes)
})
.bind("127.0.0.1:8080")?
.run()
.await
}
dotenv::dotenv().ok(): 加载环境变量。let database_url = std::env::var("DATABASE_URL").expect("DATABASE_URL must be set"): 获取数据库连接 URL。let manager = ConnectionManager::<PgConnection>::new(database_url): 创建数据库连接管理器。let pool = r2d2::Pool::builder().build(manager).expect("Failed to create pool."): 创建数据库连接池。HttpServer::new(move || { App::new().data(pool.clone()).configure(routes::init_routes) }): 初始化 HTTP 服务器并配置路由。bind("127.0.0.1:8080")?: 绑定服务器到指定地址和端口。run().await: 启动服务器。
3. 项目的配置文件介绍
.env
.env 文件用于存储环境变量,以下是一个示例:
DATABASE_URL=postgres://username:password@localhost/database_name
SECRET_KEY=your_secret_key
DATABASE_URL: 数据库连接 URL。SECRET_KEY: JWT 签名密钥。
diesel.toml
diesel.toml 文件用于配置 Diesel ORM,以下是一个示例:
[print_schema]
file = "src/schema.rs"
[print_schema]: 配置 Diesel 生成数据库表结构的输出文件。file = "src/schema.rs": 指定生成的文件路径。
登录后查看全文
热门项目推荐
相关项目推荐
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0113
let_datasetLET数据集 基于全尺寸人形机器人 Kuavo 4 Pro 采集,涵盖多场景、多类型操作的真实世界多任务数据。面向机器人操作、移动与交互任务,支持真实环境下的可扩展机器人学习00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
487
3.61 K
Ascend Extension for PyTorch
Python
298
332
暂无简介
Dart
738
177
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
270
113
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
865
467
仓颉编译器源码及 cjdb 调试工具。
C++
149
880
React Native鸿蒙化仓库
JavaScript
296
343
Dora SSR 是一款跨平台的游戏引擎,提供前沿或是具有探索性的游戏开发功能。它内置了Web IDE,提供了可以轻轻松松通过浏览器访问的快捷游戏开发环境,特别适合于在新兴市场如国产游戏掌机和其它移动电子设备上直接进行游戏开发和编程学习。
C++
52
7
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
65
20