Files
changyoutongxue e3ff55b4db docs(readme): 编写项目README文档,描述功能与架构
- 完整撰写玉宗珠宝设计大师项目README,介绍项目概况及核心功能
- 说明用户认证系统实现及优势,包含JWT鉴权和密码加密细节
- 详细描述品类管理系统,支持多流程类型和多种玉石品类
- 说明设计图生成方案及技术,包含Pillow生成示例及字体支持
- 介绍设计管理功能,支持分页浏览、预览、下载和删除设计
- 个人信息管理模块说明,涵盖昵称、手机号、密码的安全修改
- 绘制业务流程图和关键数据流图,清晰展现系统架构与数据流
- 提供详细API调用链路及参数说明,涵盖用户、品类、设计接口
- 列明技术栈及版本,包含前后端框架、ORM、认证、加密等工具
- 展示目录结构,标明后端与前端项目布局
- 规划本地开发环境与启动步骤,包括数据库初始化及运行命令
- 说明服务器部署流程和Nginx配置方案
- 详细数据库表结构说明及环境变量配置指导
- 汇总常用开发及测试命令,方便开发调试与部署管理
2026-03-27 13:10:17 +08:00

76 lines
2.1 KiB
Python

"""
用户相关路由
提供用户信息更新、密码修改接口
"""
from fastapi import APIRouter, Depends, HTTPException, status
from sqlalchemy.orm import Session
from ..database import get_db
from ..models import User
from ..schemas import UserResponse, UserUpdate, PasswordChange
from ..utils.deps import get_current_user
from ..utils.security import verify_password, get_password_hash
router = APIRouter(prefix="/api/users", tags=["用户"])
@router.put("/profile", response_model=UserResponse)
def update_profile(
user_data: UserUpdate,
db: Session = Depends(get_db),
current_user: User = Depends(get_current_user)
):
"""
更新个人信息
需要认证
"""
# 更新非空字段
if user_data.nickname is not None:
current_user.nickname = user_data.nickname
if user_data.phone is not None:
# 检查手机号是否已被其他用户使用
if user_data.phone:
existing_user = db.query(User).filter(
User.phone == user_data.phone,
User.id != current_user.id
).first()
if existing_user:
raise HTTPException(
status_code=status.HTTP_400_BAD_REQUEST,
detail="手机号已被使用"
)
current_user.phone = user_data.phone
if user_data.avatar is not None:
current_user.avatar = user_data.avatar
db.commit()
db.refresh(current_user)
return current_user
@router.put("/password")
def change_password(
password_data: PasswordChange,
db: Session = Depends(get_db),
current_user: User = Depends(get_current_user)
):
"""
修改密码
需要认证,旧密码错误返回 400
"""
# 验证旧密码
if not verify_password(password_data.old_password, current_user.hashed_password):
raise HTTPException(
status_code=status.HTTP_400_BAD_REQUEST,
detail="旧密码错误"
)
# 更新密码
current_user.hashed_password = get_password_hash(password_data.new_password)
db.commit()
return {"message": "密码修改成功"}