摘要:针对上一篇六十二实战开发在线课程学习系统需求分析需求的功能,我们对需要的接口进行梳理,大概的规划出来现有的接口,作为我们第一版的接口的设计出版,然后我们根据设计的接口。后记文章首发在公众号,欢迎关注。
针对上一篇FastAPI(六十二)实战开发《在线课程学习系统》需求分析需求的功能,我们对需要的接口进行梳理,大概的规划出来现有的接口,作为我们第一版的接口的设计出版,然后我们根据设计的接口。
路径:/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 | 用户名长度不符合 |
路径:/user/login
请求方式:post
请求格式:json
是否依赖登陆:否
请求参数
字段 | 含义 | 是否必须 | 类型 |
---|---|---|---|
username | 用户名 | 是 | str |
password | 密码 | 是 | str |
返回例子
{
"code":200,
"data":{
"token":""
},
"message":"成功"
}
返回状态码说明
代码 | 含义 |
---|---|
200 | 成功 |
100201 | 登陆失败 |
100202 | 重复登陆 |
100203 | 产生token失败 |
100204 | 输入密码错误次数过多,账号暂时锁定,请30min再来登录 |
100205 | 用户不存在 |
100206 | 密码错误 |
路径:/user/info
请求方式:post
请求格式:json
请求参数:无
是否依赖登陆:是
返回格式:json
{
"code":200,
"data":{
},
"message":"成功"
}
返回状态码说明
代码 | 含义 |
---|---|
200 | 成功 |
路径:/user/changepassword
请求方式:post
请求格式:json
返回格式:json
是否依赖登陆:是
参数 | 说明 | 是否必须 | 类型 |
---|---|---|---|
oldpassword | 原密码 | 是 | str |
newspassword | 新密码 | 是 | str |
返回示例
{
"code":200,
"data":成功,
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
100301 | 原密码校验失败 |
100302 | 密码保存失败 |
100303 | 新密码长度不匹配 |
100304 | 新旧密码不能一样 |
路径:/user/addmessage
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数:
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 用户id | 是 | int |
message | 内容 | 是 | str |
返回格式:json
{
"code":200,
"data":{
},
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
100501 | 自己不能给自己留言 |
100502 | 留言长度在5-500个字符长度 |
100503 | 留言用户不存在 |
路径:/user/viewmessage
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:无
返回格式:json
{
"code":200,
"data":{
},
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
路径:/user/messagelist
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:无
返回格式:json
{
"code":200,
"data":[
],
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
路径:/user/rebackmessage/
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 留言的id | 是 | int |
message | 内容 | 是 | str |
返回格式:json
{
"code":200,
"data":{},
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
100801 | 回复留言失败 |
100802 | 回复留言内容不能为空 |
100803 | 回复内容应该在5-500字 |
100804 | 回复留言id不存在 |
路径:/user/deletemessage/{id}
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 留言的id | 是 | int |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
返回状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
100901 | 删除留言不存在 |
100902 | 权限不足 |
路径:/course/create
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数:
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
name | 课程名称(长度2-50) | 是 | str |
icon | 课程的icon | 否 | str |
desc | 描述 | 否 | text |
catalog | 目录 | 否 | json |
onshelf | 是否上架(0上架,1下架) | 是 | int |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101002 | 课程名称不能重复 |
101003 | 课程创建失败 |
路径:/course/detail/{id}
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101101 | 课程不存在 |
路径:/course/edit
请求方式:put
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
name | 课程名称(长度2-50) | 是 | str |
id | 课程id | 是 | int |
icon | 课程icon | 否 | str |
desc | 课程描述 | 否 | str |
catalog | 课程目录 | 否 | json |
onshelf | 是否上架(0上架,1下架) | 是 | int |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101201 | 课程id不存在 |
101202 | 权限不足 |
101203 | 课程名称不能重复 |
路径:/course/viewcomments/{id}
请求方式:get
请求格式:无
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101301 | 课程id不存在 |
路径:/course/comments
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
content | 评论内容 | 是 | str |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101401 | 课程id不存在 |
101402 | 评论内容不能为空 |
101403 | 评论失败 |
101404 | 自己不能评论自己的课程 |
路径:/course/add/{id}
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101501 | 课程id不存在 |
101502 | 课程不能重复加入 |
101503 | 自己不能加入自己的课程 |
路径:/course/quit/{id}
请求方式:post
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
101601 | 课程id不存在 |
101602 | 课程不在自己列表 |
路径:/course/list
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:无
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
路径:/course/courselist
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:
无
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
路径:/course/recommend
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数:无
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
路径:/course/like/{id}
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
路径:/course/onshelf/{id}
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
102101 | 课程不存在 |
102102 | 课程已经上架 |
102103 | 自己只能上架自己的课程 |
102104 | 权限不足 |
路径:/course/offshelf/{id}
请求方式:get
请求格式:json
是否依赖登陆:是
请求参数
参数 | 含义 | 是否必须 | 类型 |
---|---|---|---|
id | 课程id | 是 | int |
返回格式:json
{
"code":200,
"data":"ok",
"message":"成功"
}
状态码说明
状态码 | 含义 |
---|---|
200 | 成功 |
102201 | 课程不存在 |
102202 | 课程已经下架 |
102203 | 自己只能下架自己的课程 |
102204 | 权限不足 |
对应的接口第一版本已经梳理完毕,下次,我们分享需要的数据库的设计。
后记
文章首发在公众号,欢迎关注。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/124530.html
摘要:为了方便大家了解并入门微信小程序,我将一些可能会需要的知识,列在这里,让大家方便的从零开始学习一微信小程序的特点张小龙张小龙全面阐述小程序,推荐通读此文小程序是一种不需要下载安装即可使用的应用,它出现了触手可及的梦想,用户扫一扫或者搜一下即 为了方便大家了解并入门微信小程序,我将一些可能会需要的知识,列在这里,让大家方便的从零开始学习; 一:微信小程序的特点 张小龙:张小龙全面阐述小程...
摘要:为了方便大家了解并入门微信小程序,我将一些可能会需要的知识,列在这里,让大家方便的从零开始学习一微信小程序的特点张小龙张小龙全面阐述小程序,推荐通读此文小程序是一种不需要下载安装即可使用的应用,它出现了触手可及的梦想,用户扫一扫或者搜一下即 为了方便大家了解并入门微信小程序,我将一些可能会需要的知识,列在这里,让大家方便的从零开始学习; 一:微信小程序的特点 张小龙:张小龙全面阐述小程...
摘要:为了方便大家了解并入门微信小程序,我将一些可能会需要的知识,列在这里,让大家方便的从零开始学习一微信小程序的特点张小龙张小龙全面阐述小程序,推荐通读此文小程序是一种不需要下载安装即可使用的应用,它出现了触手可及的梦想,用户扫一扫或者搜一下即 为了方便大家了解并入门微信小程序,我将一些可能会需要的知识,列在这里,让大家方便的从零开始学习; 一:微信小程序的特点 张小龙:张小龙全面阐述小程...
FastAPI是个现代化的,迅速(性能卓越)pythonweb架构。本文运用fastapi完成上传图片作用,文章中的实例编码解读详尽,所需要的可以了解一下 应用File完成文件传送 应用Form表格上传图片,fastapi应用File获得上传文档。 特定了参数类型是bytes:file:bytes=File(),这时会把文件所有载入到内存条,较为适合静态资源。 应用File要提前组装p...
阅读 733·2023-04-25 19:43
阅读 3979·2021-11-30 14:52
阅读 3805·2021-11-30 14:52
阅读 3867·2021-11-29 11:00
阅读 3800·2021-11-29 11:00
阅读 3898·2021-11-29 11:00
阅读 3579·2021-11-29 11:00
阅读 6179·2021-11-29 11:00