校园小助手–智慧成绩统计服务平台

校园小助手–智慧成绩统计服务平台

校园小助手–智慧成绩统计服务平台

API文档

接口总地址: http://120.78.188.40:8080/

基本功能

登录

url:/login

请求方式:post/get

请求参数

名称 类型 必填 说明
username String 用户名
password String 密码

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息

image-20210726194026062

image-20210726194033982

注册

url:/register

请求方式:post/get

请求参数

名称 类型 必填 说明
username String 用户名
password String 密码
email String 邮箱

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "注册成功!我们已经向您的邮箱发送了邮件,请您及时进行查收。由于网络原因,您收到邮件的时间存在延迟,敬请谅解~");
map.put("code", 0);
map.put("msg", "注册失败!");

忘记密码

url:/resetPassword

请求方式:post/get

请求参数

名称 类型 必填 说明
username String 用户名
password String 密码

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "重置成功!");

map.put("code", 0);
map.put("msg", "重置失败!");

用户

用户接口:/user

修改密码

url:/updatePassword

请求方式:post/get

请求参数

名称 类型 必填 说明
password String 密码

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "修改成功!");

map.put("code", 0);
map.put("msg", "修改失败!");

更新用户资料

url:/updateUser

请求方式:post/get

请求参数

名称 类型 必填 说明
name String 姓名
college String 所属学院
email String 邮箱

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "修改成功!");

map.put("code", 0);
map.put("msg", "修改失败!");

验证原密码

用于修改密码时,判断用户输入是否为正确的原密码

url:/verifyPassword

请求方式:post/get

请求参数

名称 类型 必填 说明
password String 原密码

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "原密码正确!");

map.put("code", 0);
map.put("msg", "原密码不正确!");

注销

url:/logout

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "注销成功!");

获取用户

用于修改用户资料,进行表单回显

url:/getUser

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
user User 用户实体
public class User {
   
    private String id;
    private String username;//不可修改,表单展示
    private String password;
    private String name;//表单展示
    private String college;//表单展示
    //存放文件地址
    private String filePath;//不可修改,表单展示
    private String email;//表单展示
    //存储容量
    private int storageCapacity;//不可修改,表单展示
}

验证

验证码接口:/captcha

图片

url:/codeImage

请求方式:post/get

注意:

点击验证码图片换验证码时,img 标签 的 onclick 事件里面做的就是改变 img 标签的 src 属性,所以要给 url 带一个随机数,这样每次点击验证码图片时,都会由于 src 改变而重新请求。

$('#codeImg').attr('src',"/kaptcha/codeImage?"+ new Date().getTime());

验证码

url:/code

请求方式:post/get

返回参数

名称 类型 说明
captchaCode String 验证码

邮箱验证码

url:/email

请求方式:post/get

请求参数

名称 类型 必填 说明
username String 用户名
email String 邮箱

返回参数

名称 类型 说明
emailCode String 邮箱验证码

验证用户名是否重复

用于注册时,保证用户名唯一

url:/verifyUsername

请求方式:post/get

请求参数

名称 类型 必填 说明
username String 用户名

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "该用户名可使用!");

map.put("code", 0);
map.put("msg", "该用户名已存在!");

验证邮箱是否属于用户

url:/verifyEmail

请求方式:post/get

请求参数

名称 类型 必填 说明
username String 用户名
email String 邮箱

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "邮箱正确!");

map.put("code", 0);
map.put("msg", "该邮箱不属于该账号!请重新输入!");

文件

文件接口:/user/file

上传

url:/upload

请求方式:post

<div class="a">
    <p>上传文件</p>
    <form action="/file/upload" enctype="multipart/form-data" method="post">
        <input type="file" name="file">
        <input type="submit" value="上传">
    </form>
</div>

请求参数

名称 类型 必填 说明
file CommonsMultipartFile 文件

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "上传失败!总存储容量超出50MB,请清理无用的文件");

map.put("code", 0);
map.put("msg", "上传失败!文件类型不符合");

map.put("code", 200);
map.put("msg", "上传成功!");

下载

url:/download

请求方式:post/get

请求参数

名称 类型 必填 说明
id String 文件id

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "下载成功!");

删除

url:/delete

请求方式:post/get

请求参数

名称 类型 必填 说明
id String 文件id

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "删除成功!");
map.put("code", 0);
map.put("msg", "删除失败!文件不存在");

重命名

url:/rename

请求方式:post/get

请求参数

名称 类型 必填 说明
id String 文件id
newName String 新文件名

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "重命名成功!");
map.put("code", 0);
map.put("msg", "重命名失败!文件不存在");

获取文件集合

url:/getFileList

请求方式:post/get

请求参数

名称 类型 必填 说明
currentPage Integer 当前页
pageSize Integer 页面大小

如果不需要分页,可以不需要传参

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
data List<File> 文件信息集合
map.put("code", 200);
map.put("msg", "获取成功!");
map.put("data",files);
private String id;//展示
private String userId;
private String name;//展示
private String filePath;
private int size;
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")//页面写入数据库时格式化
@JSONField(format = "yyyy-MM-dd HH:mm:ss")//数据库导出页面时json格式化
private Date updateTime;//展示
private String showSize;//展示

Excel操作

接口:/user/excel

导入配置文件

url:/importPlanConfig

请求方式:post/get

请求参数

名称 类型 必填 说明
fileName String 文件名

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "已经导入配置文件,请勿重新导入!");
map.put("code", 200);
map.put("msg", "导入配置文件成功!");
map.put("code", 0);
map.put("msg", "导入配置文件失败!请重新导入!");

导入更新的配置文件

url:/importUpdatePlanConfig

请求方式:post/get

请求参数

名称 类型 必填 说明
fileName String 文件名

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "已经导入更新的配置文件,请勿重新导入!");
map.put("code", 200);
map.put("msg", "导入配置文件成功!");
map.put("code", 0);
map.put("msg", "导入配置文件失败!请重新导入!");

导入专业成绩文件

用于数据处理模块

url:/importStudentCourseResultInfo

请求方式:post/get

请求参数

名称 类型 必填 说明
fileName String 文件名
grade String 从配置文件的筛选条件中的年级获取

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "未导入配置文件,请先导入配置文件!");
map.put("code", 0);
map.put("msg", "已经导入专业成绩文件,请勿重新导入!");
map.put("code", 200);
map.put("msg", "导入专业成绩文件成功!");
map.put("code", 0);
map.put("msg", "导入专业成绩文件失败!请重新导入!");

导入专业成绩文件

用于更新配置文件模块

url:/importAllStudentCourseResultInfo

请求方式:post/get

请求参数

名称 类型 必填 说明
fileName String 文件名

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "未导入配置文件,请先导入配置文件!");
map.put("code", 0);
map.put("msg", "已经导入专业成绩文件,请勿重新导入!");
map.put("code", 200);
map.put("msg", "导入专业成绩文件成功!");
map.put("code", 0);
map.put("msg", "导入专业成绩文件失败!请重新导入!");

获得年级筛选条件

url:/getFilterGrade

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
grade List<String> 年级列表
map.put("code", 200);
map.put("msg", "获取成功!");
map.put("grade", filterGrade);

获得学期筛选条件

url:/getFilterSemester

请求方式:post/get

请求参数

名称 类型 必填 说明
grade String 从配置文件的筛选条件中的年级获取

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
semester List<String> 学期列表
map.put("code", 200);
map.put("msg", "获取成功!");
map.put("semester", filterSemester);

更新配置文件

url:/updatePlanConfigure

请求方式:post/get

请求参数

名称 类型 必填 说明
grade String 筛选年级
semesters String[] 筛选学期

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "还未导入配置文件或专业成绩文件!");
map.put("code", 200);
map.put("msg", "配置文件更新完成!请在文件列表中下载后核对!");

数据处理

url:/dataProcessing

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "还未导入更新的配置文件或专业成绩文件!");
map.put("code", 200);
map.put("msg", "数据处理完成!");
map.put("code", 0);
map.put("msg", "数据处理失败!");

清空配置文件

url:/emptyPlanConfigure

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "专业配置文件数据已清空!请重新导入!");

清空更新的配置文件

url:/emptyUpdatePlanConfigure

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "更新的配置文件数据已清空!请重新导入!");

清空成绩文件

url:/emptyProfessionalScore

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 200);
map.put("msg", "专业成绩文件数据已清空!请重新导入!");

通过关键词搜索学生成绩情况

url:/searchStudent

请求方式:post/get

请求参数

名称 类型 必填 说明
keyword String 关键词

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
data List<StudentOverallResultInfo> 学生信息集合
map.put("code", 0);
map.put("msg", "还未导入更新的配置文件或专业成绩文件!");
map.put("code", 0);
map.put("msg", "未输入任何关键字!");
map.put("code", 0);
map.put("msg", "未找到任何符合条件的记录!");
map.put("code", 200);
map.put("msg", "获取成功!");
map.put("data", studentOverallResultInfos);
public class StudentOverallResultInfo {
   
    @ExcelProperty("学号")
    private String studentId;//展示
    @ExcelProperty("姓名")
    private String name;//展示
    @ExcelProperty("班级")
    private String clazz;//展示
    @ExcelProperty("专业")
    private String professional;//展示
    /** * 修习类别与对应已获得学分 */
    private Map<CourseType, Double> earnedCreditsMap;
    /** * 修习类别是否通过 */
    private Map<CourseType, String> flagMap = new HashMap<>();
    /** * 修习类别对应的课程成绩 */
    private Map<CourseType, List<StudentCourseScoreInfo>> courseScoreInfoMap;

    /** * 每个学期对应的平均绩点 */
    private Map<String, Double> gradePointMap;
    /** * 每种修习类别未修过课程 */
    private Map<CourseType, List<Course>> unrepairedCourseMap;

    /** * 课程对应是否通过 */
    private Map<Course, Boolean> flagCourseMap;
    /** * 判断该学生是否合格 */
    private boolean qualified;//展示

    /** * 平均绩点 */
    private Double gradePointAverage = 0.0;//展示

    /** * 专业排名 */
    private Integer rank = 0;  //展示
}

根据学生id获取修习情况

url:/getStudentPracticeInfo

请求方式:post/get

请求参数

名称 类型 必填 说明
id String 学号

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
data List<StudentPracticeInfo> 学生修习情况集合
map.put("code", 200);
map.put("msg", "获取成功!");
map.put("data", studentPracticeInfoById);
//全部展示
public class StudentPracticeInfo {
   
    @ColumnWidth(11)
    @ExcelProperty("修习类别")
    private String practiceCategory;
    @ColumnWidth(7)
    @ExcelProperty("学分要求")
    private Double credits;
    @ColumnWidth(9)
    @ExcelProperty("已获得学分")
    private Double earnedCredits;
    @ColumnWidth(9)
    @ExcelProperty("所差学分")
    private Double poorCredits;
    @ColumnWidth(7)
    @ExcelProperty("是否通过")
    private String flag;
}

导出学生成绩信息

url:/exportStudent

请求方式:post/get

请求参数

名称 类型 必填 说明
id String 学号

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "还未导入更新的配置文件或专业成绩文件!");
map.put("code", 200);
map.put("msg", "导出成功!请在文件列表中下载");

获取专业成绩总体分析结果

url:/getPracticeCategoryStatisticsInfo

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
data List<PracticeCategoryStatisticsInfo> 学生修习情况集合
map.put("code", 200);
map.put("msg", "获取成功!");
map.put("data", excelServiceImpl.getPracticeCategoryStatisticsInfoList());
public class PracticeCategoryStatisticsInfo {
   
    @ExcelProperty("修习类别")
    private String practiceCategory;
    @ExcelProperty("学分要求")
    private Double credits;
    @ExcelProperty("通过人数")
    private Integer passCount;
}

导出全体学生成绩分析

url:/exportAllStudentResults

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "还未导入更新的配置文件或专业成绩文件!");
map.put("code", 200);
map.put("msg", "导出成功!请在文件列表中下载");

导出不合格学生成绩分析

url:/exportOfUnqualifiedStudentResults

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "还未导入更新的配置文件或专业成绩文件!");
map.put("code", 200);
map.put("msg", "导出成功!请在文件列表中下载");

导出专业排名分析

url:/exportProfessionalRankings

请求方式:post/get

返回参数

名称 类型 说明
code int 状态码(成功:200,失败:0)
msg String 返回信息
map.put("code", 0);
map.put("msg", "还未导入更新的配置文件或专业成绩文件!");
map.put("code", 200);
map.put("msg", "导出成功!请在文件列表中下载");
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114419.html原文链接:https://javaforall.net

(0)
上一篇 2021年10月7日 上午11:00
下一篇 2021年10月7日 下午12:00


相关推荐

  • openclaw本地部署流程

    openclaw本地部署流程

    2026年3月13日
    4
  • linux根据进程号查看进程位置信息_shell获取进程的进程号

    linux根据进程号查看进程位置信息_shell获取进程的进程号1)说明:Linux的所有进程都保存在/proc/目录下,保存形式为:/proc/进程号。进入到进程号目录后,里面有一个cwd链接文件即指向的进程的的目录。2)操作:A:确定进程号。如:4874;B:查找进程执行的文件。psaux|grep4874C:确定进程所在的目录。ll/proc/4874;技术交流CleverCode是一名架构师,技术交…

    2025年6月14日
    8
  • 基于物品的协同过滤算法:理论说明,代码实现及应用「建议收藏」

    基于物品的协同过滤算法:理论说明,代码实现及应用「建议收藏」基于物品的协同过滤算法:理论说明,代码实现及应用标签:爬虫Python主要参考资料:项亮.推荐系统实践[M].北京:人民邮电出版社,2012.转载请注明出处:sss0.一些碎碎念从4月中旬开始,被导师赶到北京的郊区搬砖去了,根本就没有时间学习看书,这个时候才知道之前的生活是多么的幸福:每天看自己想看的书,然后实践一下,最后写博文总结一下,偶尔还能去跑个步,游个泳。想找实习的计划也泡汤了

    2022年6月26日
    25
  • 用python绘制爱心的心得体会_用 python 画爱心代码讲解[通俗易懂]

    用python绘制爱心的心得体会_用 python 画爱心代码讲解[通俗易懂]原理其实很简单。也可以在互联网上的代码。最困难的部分前辈们告诉我们,可以画心的形状。还可以获得通过泰勒的各种曲折。我觉得这不是用肉眼无法扭转。的想法。如何画一个心形的曲线,如何填补这个心形的曲线,如何使用python,如何画一个心形的曲线,我们选择上。如何填补这个心形的曲线天真的想法,函数=0是一条线,这条线的两个边大于0小于0。把x,y=0,发现建立了函数<=0。让我们尝试如何…

    2025年8月29日
    5
  • sql语言是编程语言吗_sql属于编程语言吗

    sql语言是编程语言吗_sql属于编程语言吗1.SQL操作的是数据   SQL是数据库的查询语言,因而可以对系统数据产生持久化影响。在常规编程中,一个错误通常只会造成程序的crash或bug,修改并重新调试往往就可以了;而在SQL中,一个不小心就可能造成系统数据的破坏和丢失。常常有新手执行SQL时,不小心遗漏了DELETE或UPDATE语句中的WHERE子句,这往往是很大的麻烦。   因此,学习和使用SQL,一开始应该养成两个习惯:

    2022年10月5日
    6
  • C++ – Vector 计算 均值(mean) 和 方差(variance)

    C++ – Vector 计算 均值(mean) 和 方差(variance)

    2021年12月4日
    75

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号