refactor: 统一路由参数格式为花括号并更新部署说明

将路由参数从 `:id` 和 `:key` 格式统一为 `{id}` 和 `{key}` 格式
更新 build.sh 脚本以优先使用实际 .env 文件,并同步更新部署说明文档
This commit is contained in:
2025-10-23 21:43:27 +08:00
parent 94d956d467
commit 1557920e14
2 changed files with 13 additions and 11 deletions

View File

@ -32,11 +32,11 @@ cp "$BACKEND_DIR/target/release/qiandao" "$BUNDLE_DIR/backend/"
mkdir -p "$BUNDLE_DIR/frontend"
cp -r "$FRONTEND_DIR/dist" "$BUNDLE_DIR/frontend/"
# 环境变量示例(如存在,优先示例文件,否则复制现有 .env
if [[ -f "$ROOT_DIR/.env.example" ]]; then
cp "$ROOT_DIR/.env.example" "$BUNDLE_DIR/backend/.env.example"
elif [[ -f "$ROOT_DIR/.env" ]]; then
# 环境变量文件:优先复制实际 .env若不存在则用 .env.example 作为 .env
if [[ -f "$ROOT_DIR/.env" ]]; then
cp "$ROOT_DIR/.env" "$BUNDLE_DIR/backend/.env"
elif [[ -f "$ROOT_DIR/.env.example" ]]; then
cp "$ROOT_DIR/.env.example" "$BUNDLE_DIR/backend/.env"
fi
# 生成部署说明
@ -46,7 +46,7 @@ cat > "$BUNDLE_DIR/README_DEPLOY.md" << 'EOF'
## 内容结构
- backend/: 后端二进制与环境变量
- qiandao: 后端二进制
- .env 或 .env.example: 环境变量文件
- .env: 环境变量文件(若为空,请复制并编辑)
- frontend/: 前端静态资源
- dist/: 生产构建后的静态文件
@ -54,6 +54,8 @@ cat > "$BUNDLE_DIR/README_DEPLOY.md" << 'EOF'
```bash
cd backend
chmod +x ./qiandao
# 如需自定义端口或数据库,修改 .env 或以环境变量覆盖:
# SERVER_ADDR=0.0.0.0:3001 DATABASE_URL=... JWT_SECRET=... ./qiandao
./qiandao
```
后端默认监听端口:`3001`
@ -82,11 +84,11 @@ server {
```
## 环境变量
将 `.env` 放在 `backend/` 目录或系统环境中。确保配置正确的 MySQL、Redis、JWT 等。
将 `.env` 放在 `backend/` 目录或系统环境中。确保配置正确的 MySQL、JWT 等。
## 注意事项
- 前端构建后产物在 `frontend/dist`,直接静态托管即可。
- 后端为单个二进制,无需额外依赖(运行期需 MySQL/Redis 服务)。
- 后端为单个二进制,无需额外依赖(运行期需 MySQL 服务)。
- 若需使用 Docker请联系生成生产用 Dockerfile 与 compose。
EOF

View File

@ -29,8 +29,8 @@ async fn main() {
.route("/", get(root))
.route("/api/attendees", post(routes::create_attendee))
.route("/api/attendees", get(routes::get_attendees))
.route("/api/attendees/:id", get(routes::get_attendee))
.route("/api/attendees/:id/checkin", post(routes::checkin_attendee))
.route("/api/attendees/{id}", get(routes::get_attendee))
.route("/api/attendees/{id}/checkin", post(routes::checkin_attendee))
.route("/api/attendees/batch-delete", delete(routes::batch_delete_attendees))
.route("/api/attendees/batch-reset-checkin", post(routes::batch_reset_checkin))
.route("/api/attendees/import", post(routes::import_attendees_from_excel))
@ -38,8 +38,8 @@ async fn main() {
.route("/api/auth/register", post(routes::register_user))
.route("/api/auth/login", post(routes::login_user))
.route("/api/config", get(routes::get_configs))
.route("/api/config/:key", get(routes::get_config))
.route("/api/config/:key", put(routes::update_config))
.route("/api/config/{key}", get(routes::get_config))
.route("/api/config/{key}", put(routes::update_config))
.layer(CorsLayer::new().allow_origin(Any).allow_methods(Any).allow_headers(Any))
.with_state(db);