分享一套基于SSM的高校四六级报名管理系统(源码+文档+部署)

大家好,今天给大家分享一套基于SSM的高校四六级报名管理系统

开发语言:Java
数据库:MySQL
技术:Spring+SpringMvc+MyBatis
工具:IDEA/Ecilpse、Navicat、Maven

博主介绍: 一名Java全栈工程师,专注于Java全栈技术!
主要技术: SpringCloud Alibaba、SpringBoot、SSM、Html、Css、Vue、小程序、uni-app等设计与开发。
获取源码: @

基于SSM的高校四六级报名管理系统

一、演示效果

在这里插入图片描述

二、前言

本系统将严格按照软件开发流程进行各个阶段的工作,采用B/S架构,面向对象编程思想进行项目开发。在引言中,作者将论述高校四六级报名管理系统的当前背景以及系统开发的目的,后续章节将严格按照软件开发流程,对系统进行各个阶段分析设计。
高校四六级报名管理系统的主要使用者分为管理员和学生,实现功能包括管理员:个人中心、学生管理、四六级报名管理、报名记录管理、准考记录管理、身份证认证管理、系统管理,学生:个人中心、报名记录管理、准考记录管理、身份证认证管理,前台首页;首页、四六级报名、新闻资讯、我的、跳转到后台、在线客服等功能。由于本网站的功能模块设计比较全面,所以使得整个高校四六级报名管理系统信息管理的过程得以实现。
本系统的使用可以实现本高校四六级报名管理系统管理的信息化,可以方便管理员进行更加方便快捷的管理。

关键词:高校四六级报名管理系统;JSP技术;MYSQL数据库;

三、系统关键技术

JSP技术、JAVA、MYSQL、B/S结构、SSM等等

四、系统设计

系统结构设计
在这里插入图片描述

五、系统功能设计

5.1前台首页功能模块
高校四六级报名管理系统,在系统首页可以查看首页、四六级报名、新闻资讯、我的、跳转到后台、在线客服等内容,如图5-1所示。
在这里插入图片描述

图5-1系统功能界面图

学生登录、学生注册,在注册页面可以填写学号、密码、姓名、学院、班级、手机、邮箱、身份证等信息进行注册、登录,如图5-2所示。

在这里插入图片描述

在这里插入图片描述

图5-2学生注册、学生登录界面图

个人中心,在个人中心页面通过填写学号、密码、姓名、学院、班级、性别、手机、邮箱、身份证等信息进行更新信息、退出登录,如图5-3所示。
在四六级报名页面通过查看考试编号、项目名称、类别、考试时间、考试地点、报考价格等信息进行报名操作,如图5-4所示。
在这里插入图片描述

图5-3个人中心界面图

在这里插入图片描述

图5-4四六级报名界面图

5.2管理员功能模块
管理员登录,通过填写用户名、密码进行登录,如图5-5所示。
在这里插入图片描述

图5-5管理员登录界面图

管理员登录进入高校四六级报名管理系统可以查看个人中心、学生管理、四六级报名管理、报名记录管理、准考记录管理、身份证认证管理、系统管理等信息。
学生管理,在学生管理页面中可以通过查看学号、姓名、学院、班级、性别、手机、邮箱、身份证、照片等内容进行修改、删除,如图5-6所示。还可以根据需要对四六级报名管理进行详情,修改或删除等详细操作,如图5-7所示。
在这里插入图片描述

图5-6学生管理界面图

在这里插入图片描述

图5-7四六级报名管理界面图

报名记录管理,在报名记录管理页面中可以查看考试编号、项目名称、类别、报考价格、考试时间、考试地点、学号、姓名、学院、班级、报名时间、是否审核、审核回复、是否支付等信息,并可根据需要对已有报名记录管理进行修改或删除等操作,如图5-8所示。
在这里插入图片描述

图5-8报名记录管理界面图

准考记录管理,在准考记录管理页面中可以查看考试编号、项目名称、类别、考试时间、考试地点、学号、姓名、学院、班级、准考证号等信息,并可根据需要对已有准考记录管理进行修改或删除等详细操作,如图5-9所示。
在这里插入图片描述

图5-9准考记录管理界面图

身份证认证管理,在身份证认证管理页面中可以查看学号、姓名、身份证、身份证正面照、身份证背面照、是否审核、审核回复等内容,并且根据需要对已有身份证认证管理进行详情,修改或删除等详细操作,如图5-10所示。
在这里插入图片描述

图5-10身份证认证管理界面图

考试资讯管理,在考试资讯管理页面中可以查看标题、简介、图片等内容,并且根据需要对已有考试资讯管理进行详情,修改或删除等详细操作,如图5-11所示。
在这里插入图片描述

图5-11考试资讯管理界面图

轮播图;该页面为轮播图管理界面。管理员可以在此页面进行首页轮播图的管理,通过新建操作可在轮播图中加入新的图片,还可以对以上传的图片进行修改操作,以及图片的删除操作,如图5-12所示。
在这里插入图片描述

图5-12轮播图管理界面图

客服聊天表管理,在客服聊天表管理页面中可以查看新消息、状态等内容,并且根据需要对已有客服聊天表管理进行回复等详细操作,如图5-13所示。
在这里插入图片描述

图5-13客服聊天表管理界面图

5.3学生功能模块
学生登录进入高校四六级报名管理系统可以查看个人中心、报名记录管理、准考记录管理、身份证认证管理等内容。
报名记录管理,在报名记录管理页面中通过查看考试编号、项目名称、类别、报考价格、考试时间、考试地点、学号、姓名、学院、班级、报名时间、是否审核、审核回复、是否支付等信息,还可以根据需要对报名记录管理进行查看如图5-14所示。
在这里插入图片描述

图5-14报名记录管理界面图

六、部分代码

package com.controller;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;

import org.apache.commons.lang3.StringUtils;
import org.json.JSONObject;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.util.ResourceUtils;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import com.annotation.IgnoreAuth;
import com.baidu.aip.face.AipFace;
import com.baidu.aip.face.MatchRequest;
import com.baidu.aip.util.Base64Util;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.entity.ConfigEntity;
import com.service.CommonService;
import com.service.ConfigService;
import com.utils.BaiduUtil;
import com.utils.FileUtil;
import com.utils.R;

/**
 * 通用接口
 */
@RestController
public class CommonController{
	@Autowired
	private CommonService commonService;
	
	@Autowired
	private ConfigService configService;
	
	private static AipFace client = null;
	
	private static String BAIDU_DITU_AK = null;
	
	@RequestMapping("/location")
	public R location(String lng,String lat) {
		if(BAIDU_DITU_AK==null) {
			BAIDU_DITU_AK = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "baidu_ditu_ak")).getValue();
			if(BAIDU_DITU_AK==null) {
				return R.error("请在配置管理中正确配置baidu_ditu_ak");
			}
		}
		Map<String, String> map = BaiduUtil.getCityByLonLat(BAIDU_DITU_AK, lng, lat);
		return R.ok().put("data", map);
	}
	
	/**
	 * 人脸比对
	 * 
	 * @param face1 人脸1
	 * @param face2 人脸2
	 * @return
	 */
	@RequestMapping("/matchFace")
	public R matchFace(String face1, String face2, HttpServletRequest request) {
		if(client==null) {
			/*String AppID = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "AppID")).getValue();*/
			String APIKey = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "APIKey")).getValue();
			String SecretKey = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "SecretKey")).getValue();
			String token = BaiduUtil.getAuth(APIKey, SecretKey);
			if(token==null) {
				return R.error("请在配置管理中正确配置APIKey和SecretKey");
			}
			client = new AipFace(null, APIKey, SecretKey);
			client.setConnectionTimeoutInMillis(2000);
			client.setSocketTimeoutInMillis(60000);
		}
		JSONObject res = null;
		try {
			File file1 = new File(request.getSession().getServletContext().getRealPath("/upload")+"/"+face1);
			File file2 = new File(request.getSession().getServletContext().getRealPath("/upload")+"/"+face2);
			String img1 = Base64Util.encode(FileUtil.FileToByte(file1));
			String img2 = Base64Util.encode(FileUtil.FileToByte(file2));
			MatchRequest req1 = new MatchRequest(img1, "BASE64");
			MatchRequest req2 = new MatchRequest(img2, "BASE64");
			ArrayList<MatchRequest> requests = new ArrayList<MatchRequest>();
			requests.add(req1);
			requests.add(req2);
			res = client.match(requests);
			System.out.println(res.get("result"));
		} catch (FileNotFoundException e) {
			e.printStackTrace();
			return R.error("文件不存在");
		} catch (IOException e) {
			e.printStackTrace();
		} 
		return R.ok().put("data", com.alibaba.fastjson.JSONObject.parse(res.get("result").toString()));
	}
    
	/**
	 * 获取table表中的column列表(联动接口)
	 * @param table
	 * @param column
	 * @return
	 */
	@RequestMapping("/option/{tableName}/{columnName}")
	@IgnoreAuth
	public R getOption(@PathVariable("tableName") String tableName, @PathVariable("columnName") String columnName,String level,String parent) {
		Map<String, Object> params = new HashMap<String, Object>();
		params.put("table", tableName);
		params.put("column", columnName);
		if(StringUtils.isNotBlank(level)) {
			params.put("level", level);
		}
		if(StringUtils.isNotBlank(parent)) {
			params.put("parent", parent);
		}
		List<String> data = commonService.getOption(params);
		return R.ok().put("data", data);
	}
	
	/**
	 * 根据table中的column获取单条记录
	 * @param table
	 * @param column
	 * @return
	 */
	@RequestMapping("/follow/{tableName}/{columnName}")
	@IgnoreAuth
	public R getFollowByOption(@PathVariable("tableName") String tableName, @PathVariable("columnName") String columnName, @RequestParam String columnValue) {
		Map<String, Object> params = new HashMap<String, Object>();
		params.put("table", tableName);
		params.put("column", columnName);
		params.put("columnValue", columnValue);
		Map<String, Object> result = commonService.getFollowByOption(params);
		return R.ok().put("data", result);
	}
	
	/**
	 * 修改table表的sfsh状态
	 * @param table
	 * @param map
	 * @return
	 */
	@RequestMapping("/sh/{tableName}")
	public R sh(@PathVariable("tableName") String tableName, @RequestBody Map<String, Object> map) {
		map.put("table", tableName);
		commonService.sh(map);
		return R.ok();
	}
	
	/**
	 * 获取需要提醒的记录数
	 * @param tableName
	 * @param columnName
	 * @param type 1:数字 2:日期
	 * @param map
	 * @return
	 */
	@RequestMapping("/remind/{tableName}/{columnName}/{type}")
	@IgnoreAuth
	public R remindCount(@PathVariable("tableName") String tableName, @PathVariable("columnName") String columnName, 
						 @PathVariable("type") String type,@RequestParam Map<String, Object> map) {
		map.put("table", tableName);
		map.put("column", columnName);
		map.put("type", type);
		
		if(type.equals("2")) {
			SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
			Calendar c = Calendar.getInstance();
			Date remindStartDate = null;
			Date remindEndDate = null;
			if(map.get("remindstart")!=null) {
				Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
				c.setTime(new Date()); 
				c.add(Calendar.DAY_OF_MONTH,remindStart);
				remindStartDate = c.getTime();
				map.put("remindstart", sdf.format(remindStartDate));
			}
			if(map.get("remindend")!=null) {
				Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
				c.setTime(new Date());
				c.add(Calendar.DAY_OF_MONTH,remindEnd);
				remindEndDate = c.getTime();
				map.put("remindend", sdf.format(remindEndDate));
			}
		}
		
		int count = commonService.remindCount(map);
		return R.ok().put("count", count);
	}
	
	/**
	 * 单列求和
	 */
	@RequestMapping("/cal/{tableName}/{columnName}")
	@IgnoreAuth
	public R cal(@PathVariable("tableName") String tableName, @PathVariable("columnName") String columnName) {
		Map<String, Object> params = new HashMap<String, Object>();
		params.put("table", tableName);
		params.put("column", columnName);
		Map<String, Object> result = commonService.selectCal(params);
		return R.ok().put("data", result);
	}
	
	/**
	 * 分组统计
	 */
	@RequestMapping("/group/{tableName}/{columnName}")
	@IgnoreAuth
	public R group(@PathVariable("tableName") String tableName, @PathVariable("columnName") String columnName) {
		Map<String, Object> params = new HashMap<String, Object>();
		params.put("table", tableName);
		params.put("column", columnName);
		List<Map<String, Object>> result = commonService.selectGroup(params);
		SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
		for(Map<String, Object> m : result) {
			for(String k : m.keySet()) {
				if(m.get(k) instanceof Date) {
					m.put(k, sdf.format((Date)m.get(k)));
				}
			}
		}
		return R.ok().put("data", result);
	}
	
	/**
	 * (按值统计)
	 */
	@RequestMapping("/value/{tableName}/{xColumnName}/{yColumnName}")
	@IgnoreAuth
	public R value(@PathVariable("tableName") String tableName, @PathVariable("yColumnName") String yColumnName, @PathVariable("xColumnName") String xColumnName) {
		Map<String, Object> params = new HashMap<String, Object>();
		params.put("table", tableName);
		params.put("xColumn", xColumnName);
		params.put("yColumn", yColumnName);
		List<Map<String, Object>> result = commonService.selectValue(params);
		SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
		for(Map<String, Object> m : result) {
			for(String k : m.keySet()) {
				if(m.get(k) instanceof Date) {
					m.put(k, sdf.format((Date)m.get(k)));
				}
			}
		}
		return R.ok().put("data", result);
	}
	
}



七、文档参考

在这里插入图片描述

热门推荐

分享一套基于SSM的KTV点歌系统(源码+文档+部署)
分享一套基于SSM的高校二手交易平台系统(源码+文档+部署)

  • 31
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

德乐懿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值