大家介绍一篇学生选课系统的设计与实现

140 篇文章 15 订阅
139 篇文章 2 订阅

项目描述

临近学期结束,还是毕业设计,你还在做java程序网络编程,期末作业,老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。这里根据疫情当下,你想解决的问题,今天给大家介绍一篇学生选课系统的设计与实现。

功能需求

通过计算机技术建设学校学生选课系统,为学校教学提供便捷的服务,前面根据业务需要分析了当代国内教学选课系统建设的研究背景和意义,并了解目前国内外的研究现状,根据目前市场上的需求解决学校教育困难,通过调查和分析各个高校面临的问题和困难,综合评价了我国教育行业当前形势和以后发展趋势,进而提出了比较好的管理方案。

具备以下功能:

学生模块:
(1)登录注册:实现学生通过学校网直接登录成绩管理系统进行查看。
(2)个人信息:对个人学号查看以及个人基本信息的编辑修改。
(3)成绩查询:根据课程查询,并对考试成绩详情查看。
(4)考勤信息管理:学生根据自身上课安排管理个人考勤信息。
(5)请假信息管理:学生添加请假信息。
(6)选课信息管理:学生根据个人需要选择课程信息。
教师模块:
(1)学生信息管理:根据学生班级以及科目考试对成绩录入操作。
(2)班级信息管理:根据班级以及科目对学生成绩进行排名和分析。
(3)个人信息:对教师个人工号、账号信息查看和密码修改操作。
(4)课程信息管理:对教学课程信息查看和添加修改。
(5)选课信息管理:教师对学生选课情况查看和统计。
(6)考勤信息管理:教师根据学生提交的签到统计学生考勤。
(7)请假信息管理:教师可以查看学生的请假申请,并对申请处理操作。
(8)成绩信息管理:管理学生的课程考试分数。
管理员模块:
(1)班级管理:查看班级、搜索班级、添加删除班级信息。
(2)学生信息管理:对班级学生的添加、删除以及修改查看等操作。
(3)教师管理:该模块可以对教师信息进行操作以及教师对班级的任课相关信息。
(4)课程管理:可以查看目前开的课程以及可以添加课程等。
(5)考勤管理:根据年级、班级对学生上课考勤查看。
(6)成绩管理:对所有年级学生的考试成绩查看,并通过不同维度进行成绩分析。
(7)请假信息管理:对所有年级学生的请假情况查看。
(8)学生选课管理:管理员对学生选课情况查看和统计。

系统功能模块框架图

在这里插入图片描述

部分效果图

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

数据库设计

系统中用到了11张表,针对每个表都进行了设计,下面对部分核心表进行汇总罗列展示。
在这里插入图片描述在这里插入图片描述

部分代码

	public void doGet(HttpServletRequest request,HttpServletResponse response) throws IOException{
		doPost(request, response);
	}
	public void doPost(HttpServletRequest request,HttpServletResponse response) throws IOException{
		String method = request.getParameter("method");
		if("toStudentListView".equals(method)){
			studentList(request,response);
		}else if("AddStudent".equals(method)){
			addStudent(request,response);
		}else if("StudentList".equals(method)){
			getStudentList(request,response);
		}else if("EditStudent".equals(method)){
			editStudent(request,response);
		}else if("DeleteStudent".equals(method)){
			deleteStudent(request,response);
		}
	}
	private void deleteStudent(HttpServletRequest request,
			HttpServletResponse response) {
		// TODO Auto-generated method stub
		String[] ids = request.getParameterValues("ids[]");
		String idStr = "";
		for(String id : ids){
			idStr += id + ",";
		}
		idStr = idStr.substring(0, idStr.length()-1);
		StudentDao studentDao = new StudentDao();
		if(studentDao.deleteStudent(idStr)){
			try {
				response.getWriter().write("success");
			} catch (IOException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}finally{
				studentDao.closeCon();
			}
		}
	}
	private void editStudent(HttpServletRequest request,
			HttpServletResponse response) {
		// TODO Auto-generated method stub
		String name = request.getParameter("name");
		int id = Integer.parseInt(request.getParameter("id"));
		String sex = request.getParameter("sex");
		String mobile = request.getParameter("mobile");
		String qq = request.getParameter("qq");
		int clazzId = Integer.parseInt(request.getParameter("clazzid"));
		Student student = new Student();
		student.setClazzId(clazzId);
		student.setMobile(mobile);
		student.setName(name);
		student.setId(id);
		student.setQq(qq);
		student.setSex(sex);
		StudentDao studentDao = new StudentDao();
		if(studentDao.editStudent(student)){
			try {
				response.getWriter().write("success");
			} catch (IOException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}finally{
				studentDao.closeCon();
			}
		}
	}
	private void getStudentList(HttpServletRequest request,
			HttpServletResponse response) {
		// TODO Auto-generated method stub
		String name = request.getParameter("studentName");
		Integer currentPage = request.getParameter("page") == null ? 1 : Integer.parseInt(request.getParameter("page"));
		Integer pageSize = request.getParameter("rows") == null ? 999 : Integer.parseInt(request.getParameter("rows"));
		Integer clazz = request.getParameter("clazzid") == null ? 0 : Integer.parseInt(request.getParameter("clazzid"));
		//获取当前登录用户类型
		int userType = Integer.parseInt(request.getSession().getAttribute("userType").toString());
		Student student = new Student();
		student.setName(name);
		student.setClazzId(clazz);
		if(userType == 2){
			//如果是学生,只能查看自己的信息
			Student currentUser = (Student)request.getSession().getAttribute("user");
			student.setId(currentUser.getId());
		}
		StudentDao studentDao = new StudentDao();
		List<Student> clazzList = studentDao.getStudentList(student, new Page(currentPage, pageSize));
		int total = studentDao.getStudentListTotal(student);
		studentDao.closeCon();
		response.setCharacterEncoding("UTF-8");
		Map<String, Object> ret = new HashMap<String, Object>();
		ret.put("total", total);
		ret.put("rows", clazzList);
		try {
			String from = request.getParameter("from");
			if("combox".equals(from)){
				response.getWriter().write(JSONArray.fromObject(clazzList).toString());
			}else{
				response.getWriter().write(JSONObject.fromObject(ret).toString());
			}
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
	private void addStudent(HttpServletRequest request,
			HttpServletResponse response) {
		// TODO Auto-generated method stub
		String name = request.getParameter("name");
		String password = request.getParameter("password");
		String sex = request.getParameter("sex");
		String mobile = request.getParameter("mobile");
		String qq = request.getParameter("qq");
		int clazzId = Integer.parseInt(request.getParameter("clazzid"));
		Student student = new Student();
		student.setClazzId(clazzId);
		student.setMobile(mobile);
		student.setName(name);
		student.setPassword(password);
		student.setQq(qq);
		student.setSex(sex);
		student.setSn(SnGenerateUtil.generateSn(clazzId));
		StudentDao studentDao = new StudentDao();
		if(studentDao.addStudent(student)){
			try {
				response.getWriter().write("success");
			} catch (IOException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}finally{
				studentDao.closeCon();
			}
		}
	}
	private void studentList(HttpServletRequest request,
			HttpServletResponse response) throws IOException {
		// TODO Auto-generated method stub
		try {
			request.getRequestDispatcher("view/studentList.jsp").forward(request, response);
		} catch (ServletException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
安装部署需求

eclipse、idea运行启动

系统部署

系统开发后,在生产环境配置项目运行环境,具体步骤如下:
安装linux或者windows10操作系统;
安装JDK1.8并配置环境变量;
安装MySQL5.7版本以上版本数据库,创建数据库并执行脚本创建表;
在IDEA中编辑进行打包;
下载并配置Tomcat8.0服务器,配置系统服务,上传项目打包文件

本项目用到的技术和框架

1.开发语言:Java
2.开发模式:B/S
3.数据库:MySQL
4.框架:jsp+servlet+jdbc

本项目中的关键点

此系统的开发采用java语言开发,基于B/S结构,这些开发环境使系统更加完善。使用到的工具和技术都是开源免费的。

环境工具

开发工具 Eclipse/IDEA
语言 JDK1.8 、jsp、CSS、servlet、jdbc
硬件:笔记本电脑;
软件:Tomcat8.0 Web服务器、Navicat数据库客户端、MySQL;
操作系统:Windows 10;
其它软件:截图工具、常用浏览器;

  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
学生选课系统是一个基于网络的应用程序,用于处理学生选课的相关事务。在设计实现这样一个系统时,需要考虑以下几个方面: 1. 概要设计:首先需要确定系统的架构和功能。可以将系统分为学生、课程和管理员三个角色,分别实现相应的功能。 2. 数据库设计学生、课程和管理员的信息需要储存在数据库中。需要设计合适的数据结构,包括表、字段、主键、外键等。 3. 界面设计学生、课程和管理员需要有相应的界面进行交互。需要设计简洁明了的界面,使用户能够轻松地完成操作。 4. 功能实现:根据概要设计实现学生、课程和管理员的功能。例如,学生可以浏览和选择课程,课程管理员可以添加、删除和修改课程信息,系统管理员可以管理用户和角色权限等。 5. 安全性设计学生选课系统中涉及到用户的个人信息,需要保证系统的安全性。需要采用一些安全措施,如对用户输入进行验证、加密存储用户密码等。 6. 性能优化:学生选课系统需要支持大量的并发访问,需要通过一些技术手段来优化系统的性能,如使用缓存、优化数据库访问等。 7. 测试和优化:完成系统开发后,需要进行充分的测试和优化,确保系统的稳定性和可靠性。 综上所述,学生选课系统设计实现需要综合考虑多个方面,需要有一定的技术和开发经验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

程序猿麦小七

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

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

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

打赏作者

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

抵扣说明:

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

余额充值