前言
我们上一次分享了实战FastAPI(七十一)实战开发《在线课程学习系统》接口开发-- 查看留言,这次我们分享回复留言功能。
正文
按照惯例,我们还是去分析这里面的逻辑。
代码语言:javascript复制1.判断用户是否登录
2.用户登录判断回复的是否存在
3.存在回复
我们对应的pydantic对象
代码语言:javascript复制class RebackMessConnet(MessageConent):
rebackid: int
对应的crud
代码语言:javascript复制def db_creat_rebackmessage(db: Session, reback: RebackMessConnet, senduser: int):
times = datetime.strftime(datetime.now(), "%Y-%m-%d %H:%M:%S")
reabck = Message(**reback.dict())
reabck.sendtime=times
reabck.senduser=senduser
db.add(reabck)
db.commit() # 提交保存到数据库中
db.refresh(reabck) # 刷新
return reabck
那么我们看下接口最后的实现代码
代码语言:javascript复制@usersRouter.get(path='/rebackmessage')
async def rebackmessage(rebackmessage:RebackMessConnet,user: UsernameRole = Depends(get_cure_user),
db: Session = Depends(get_db)):
if rebackmessage.connect=="":
return reponse(code=100802,message='回复留言内容不能为空',data='回复留言内容不能为空')
if len(rebackmessage.connect)>500 or len(rebackmessage.connect)<5:
return reponse(code=100803,message='回复内容应该在5-500字',data='回复内容应该在5-500字')
users=get_user_username(db,user.username)
message=get_message(db,rebackmessage.rebackid)
if not message:
return reponse(code=100804,message='回复留言id不存在',data='回复留言id不存在')
db_creat_rebackmessage(db,rebackmessage,users.id)
return reponse(code=200, message='成功', data='成功')
这个功能是一个很简单的接口。实现起来没有那么复杂。