FastAPI(六十三)实战开发《在线课程学习系统》梳理系统需要接口
针对上一篇FastAPI(六十二)实战开发《在线课程学习系统》需求分析需求的功能,我们对需要的接口进行梳理,大概的规划出来现有的接口,作为我们第一版的接口的设计出版,然后我们根据设计的接口。
2.1用户注册接口
路径:/user/register
请求方式:POST
请求格式:json
是否依赖登陆:否
参数:
参数名称 | 参数含义 | 参数是否必须 | 参数类型 |
---|---|---|---|
username | 用户名 8-16位 | 是 | str |
password | 密码,长度8-16位,md5加密 | 是 | str |
role | 类型,学生或者老师,默认:学生 | 是 | str |
jobnum | 工号,8位数字 | 否 | int |
studentnum | 学籍号,16位数字 | 否 | int |
sex | 性别,男女。 | 是 | str |
age | 年龄,必须大于18,小于65 | 是 | int |
接口返回:json
{
"code":200,
"data":'成功',
"message":"成功"
}
返回码说明
代码 | 含义 |
---|---|
200 | 注册成功 |
100101 | 注册失败 |
100102 | 身份和对应号不匹配 |
100103 | 年纪大小不符合 |
100104 | 用户名重复 |
100105 | 密码加密失败 |
100106 | 用户名长度不符合 |
2.2登陆接口 路径:/user/login
请求方式:post
请求格式:json
是否依赖登陆:否
请求参数
字段 | 含义 | 是否必须 | 类型 |
---|---|---|---|
username | 用户名 | 是 | str |
password | 密码 | 是 | str |
{
"code":200,
"data":{
"token":""
},
"message":"成功"
}
返回状态码说明
代码 | 含义 |
---|---|
200 | 成功 |
100201 | 登陆失败 |
100202 | 重复登陆 |
100203 | 产生token失败 |
100204 | 输入密码错误次数过多,账号暂时锁定,请30min再来登录 |
100205 | 用户不存在 |
100206 | 密码错误 |
2.3个人信息 路径:/user/info
请求方式:post
请求格式:json
请求参数:无
是否依赖登陆:是
返回格式:json
{
"code":200,
"data":{
},
"message":"成功"
}
返回状态码说明
代码 | 含义 |
---|---|
200 | 成功 |
请求方式:post
请求格式:json
返回格式:json
是否依赖登陆:是
参数 | 说明 | 是否必须 | 类型 |
---|---|---|---|
oldpassword | 原密码 | 是 | str |
newspassword | 新密码 | 是 | str |
{
"code":200,
"data":'成功',
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
100301 | 原密码校验失败 |
100302 | 密码保存失败 |
100303 | 新密码长度不匹配 |
100304 | 新旧密码不能一样 |
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数:
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 用户id | 是 | int |
message | 内容 | 是 | str |
{
"code":200,
"data":{
},
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
100501 | 自己不能给自己留言 |
100502 | 留言长度在5-500个字符长度 |
100503 | 留言用户不存在 |
2.6 查看留言 路径:/user/viewmessage
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:无
返回格式:json
{
"code":200,
"data":{
},
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:无
返回格式:json
{
"code":200,
"data":[
],
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 留言的id | 是 | int |
message | 内容 | 是 | str |
{
"code":200,
"data":{},
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
100801 | 回复留言失败 |
100802 | 回复留言内容不能为空 |
100803 | 回复内容应该在5-500字 |
100804 | 回复留言id不存在 |
请求方式:get
请求格式:json
是否依赖登陆:是
【FastAPI(六十三)实战开发《在线课程学习系统》梳理系统需要接口】请求参数:
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 留言的id | 是 | int |
{
"code":200,
"data":"ok",
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
100901 | 删除留言不存在 |
100902 | 权限不足 |
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数:
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
name | 课程名称(长度2-50) | 是 | str |
icon | 课程的icon | 否 | str |
desc | 描述 | 否 | text |
catalog | 目录 | 否 | json |
onshelf | 是否上架(0上架,1下架) | 是 | int |
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101002 | 课程名称不能重复 |
101003 | 课程创建失败 |
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101101 | 课程不存在 |
请求方式:put
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
name | 课程名称(长度2-50) | 是 | str |
id | 课程id | 是 | int |
icon | 课程icon | 否 | str |
desc | 课程描述 | 否 | str |
catalog | 课程目录 | 否 | json |
onshelf | 是否上架(0上架,1下架) | 是 | int |
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101201 | 课程id不存在 |
101202 | 权限不足 |
101203 | 课程名称不能重复 |
请求方式:get
请求格式:无
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101301 | 课程id不存在 |
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
content | 评论内容 | 是 | str |
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101401 | 课程id不存在 |
101402 | 评论内容不能为空 |
101403 | 评论失败 |
101404 | 自己不能评论自己的课程 |
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101501 | 课程id不存在 |
101502 | 课程不能重复加入 |
101503 | 自己不能加入自己的课程 |
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101601 | 课程id不存在 |
101602 | 课程不在自己列表 |
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:无
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:
无
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:无
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
{
"code":200,
"data":"ok",
"message":"成功"
}
2.21 课程上架 路径:/course/onshelf/{id}
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
102101 | 课程不存在 |
102102 | 课程已经上架 |
102103 | 自己只能上架自己的课程 |
102104 | 权限不足 |
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
102201 | 课程不存在 |
102202 | 课程已经下架 |
102203 | 自己只能下架自己的课程 |
102204 | 权限不足 |
后记
文章首发在公众号,欢迎关注。
文章图片
推荐阅读
- 《机器学习实战》高清中文版PDF英文版PDF+源代码下载
- --木木--|--木木-- 第二课作业#翼丰会(每日一淘6+1实战裂变被动引流# 6+1模式)
- 2020-07-29《吴军·阅读与写作50讲》24实战才能转化效能
- Python实战计划学习笔记(9)为大规模爬取准备
- 韵达基于云原生的业务中台建设 | 实战派
- 【V课会】第3季-30天小学思维导图实战营
- 【思维导图实战派】刻意练习计划“遇见……”|【思维导图实战派】刻意练习计划“遇见……” 1/300 人教版数学五下第三单元《正方体和长方体的认识》
- OpenCV|OpenCV-Python实战(18)——深度学习简介与入门示例
- 分布式|《Python3网络爬虫开发实战(第二版)》内容介绍
- 区块链FISCO|区块链FISCO BCOS实战基础篇(视频教程)