FastAPI(七十五)实战开发《在线课程学习系统》接口开发-- 创建课程

简介: FastAPI(七十五)实战开发《在线课程学习系统》接口开发-- 创建课程

上次我们分享了,FastAPI(七十四)实战开发《在线课程学习系统》接口开发-- 删除留言

 

还是按照惯例,我们去梳理下对应的逻辑


1.判断用户是否登陆
2.校验是否有权限
3.校验参数是否完整
4.查询课程是否存在
5.创建课程


课程我们需要单独创建一个新的路由来管理


       我们在routers去创建course.py


from fastapi import APIRouter
from models.crud import *
from models.get_db import get_db
courseRouter = APIRouter()


接着我们的main.py去引入


from routers.course import courseRouter
app.include_router(courseRouter,prefix='/course',tags=['course'])


        这样我们的新的路由就生效了。  


       我们去看下是如何实现创建课程?


       首先我们去创建课程创建的pydantic 类。

class Courses(BaseModel):
   name: str
   icon: Optional[str]
   desc: Optional[str]
   catalog: Optional[str]
   onsale: Optional[int]
   owner: str
   likenum: int


那么我们去实现对应的crud


#创建课程
def db_create_course(db: Session, course: Courses, user: int):
   course = Course(**course.dict())
   course.owner=user
   db.add(course)
   db.commit()  # 提交保存到数据库中
   db.refresh(course)  # 刷新
   return course
#根据课程名称获取
def db_get_course_name(db:Session,name:str):
   return db.query(Course).filter(Course.name==name,Course.status==False).first()


根据开发中,我们发现之前设计的状态码需要补充


101004 只有老师才能创建课程
101005 课程名长度应该在2-50
101006 课程上架状态不对

 

那么对应的业务代码最后实现如下


@courseRouter.post(path='/create')
async  def create(coursescreate:Courses,
                  db: Session = Depends(get_db),user: UsernameRole = Depends(get_cure_user)):
    user_=get_user_username(db,user.username)
    user_role=get_role_name(db,user_.role)
    if not user_role or user_role.mame =="学生":
        return  reponse(code=101004,message='只有老师才能创建课程',data='只有老师才能创建课程')
    if len(coursescreate.name)>50 or len(coursescreate.name)<2:
        return reponse(code=101005,message='课程名长度应该在2-50',data='')
    if coursescreate.onsale !=0 or coursescreate.onsale !=1:
        return reponse(code=101006,message='课程上架状态不对',data='')
    name=db_get_course_name(db,coursescreate.name)
    if name:
        return reponse(code=101002,message='课程名称不能重复',data='课程名称不能重复')
    couse=db_create_course(db,coursescreate,user_.id)
    return reponse(code=200,message='成功',data=couse)



相关文章
|
NoSQL Redis
使用slowapi对FastApi的接口进行限速
使用slowapi对FastApi的接口进行限速
1992 0
|
2月前
|
JSON API 网络架构
FastAPI+React全栈开发13 FastAPI概述
FastAPI是一个高性能的Python Web框架,以其快速编码和代码清洁性著称,减少了开发者错误。它基于Starlette(一个ASGI框架)和Pydantic(用于数据验证)。Starlette提供了WebSocket支持、中间件等功能,而Pydantic利用Python类型提示在运行时进行数据验证。类型提示允许在编译时检查变量类型,提高开发效率。FastAPI通过Pydantic创建数据模型,确保数据结构的正确性。FastAPI还支持异步I/O,利用Python 3.6+的async/await关键词和ASGI,提高性能。此外,
114 0
|
9月前
|
存储 IDE API
最佳实践:通过 FastAPI APIRouter 提升开发效率
FastAPI 是一个现代的、高性能的 Python Web 框架,它提供了 APIRouter 来帮助组织和管理路由。APIRouter 是一个可用于组织和分组路由的类,使得代码结构更加清晰和可维护。本文将介绍 FastAPI APIRouter 的用法,包括实践案例以及在 IDE 编辑器中的运行步骤。
|
11月前
|
JSON API 数据格式
使用(Python)FastAPI快速构建你的后端接口服务
使用(Python)FastAPI快速构建你的后端接口服务
789 0
|
JSON 数据安全/隐私保护 数据格式
python fastapi 入门教程,每个案例都使用postman进行测试写的接口
python fastapi 入门教程,每个案例都使用postman进行测试写的接口
|
网络安全 Windows
基于fastapi实现6个接口(token拦截, 2个业务流程,接口参数依赖校验)已经通过postman测试,记录部署服务器和windows,用于pytest接口自动化框架的接口测试对象
基于fastapi实现6个接口(token拦截, 2个业务流程,接口参数依赖校验)已经通过postman测试,记录部署服务器和windows,用于pytest接口自动化框架的接口测试对象
|
机器学习/深度学习 开发者 Python
FastAPI的小兄弟,开发命令行工具更给力
FastAPI的小兄弟,开发命令行工具更给力
196 0
FastAPI的小兄弟,开发命令行工具更给力
|
NoSQL 测试技术 Redis
FastAPI(八十四)实战开发《在线课程学习系统》--接口测试(下)
FastAPI(八十四)实战开发《在线课程学习系统》--接口测试(下)
FastAPI(八十四)实战开发《在线课程学习系统》--接口测试(下)
|
存储 测试技术 数据安全/隐私保护
FastAPI(八十三)实战开发《在线课程学习系统》--注册接口单元测试
FastAPI(八十三)实战开发《在线课程学习系统》--注册接口单元测试
FastAPI(八十三)实战开发《在线课程学习系统》--注册接口单元测试
|
测试技术 数据安全/隐私保护
FastAPI(八十四)实战开发《在线课程学习系统》--接口测试(上)
FastAPI(八十四)实战开发《在线课程学习系统》--接口测试(上)