Java项目:JSP学生选课管理系统

127 篇文章 14 订阅
111 篇文章 0 订阅

作者主页:夜未央5788

 简介:Java领域优质创作者、Java项目、学习资料、技术互助

文末获取源码

项目介绍

管理员角色包含以下功能:
管理员登录,用户管理,公告管理,课程管理,教室管理,学生信息管理等功能。

教师角色包含以下功能:
教师登录,查看公告,查询课程,查看学生选课信息,修改个人信息等功能。

学生角色包含以下功能:
学生登录,查看公告,选择课程,信息查询,修改个人信息等功能。

由于本程序规模不大,可供课程设计,毕业设计学习演示之用

环境需要

1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可
4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;

5.数据库:MySql 5.7版本;

技术栈

HTML+CSS+JavaScript+jsp+mysql

使用说明

1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;
3. 将项目中application.yml配置文件中的数据库配置改为自己的配置;

4. 运行项目,输入localhost:8080/login.jsp 登录

运行截图

 

 

 

 

 

 

相关代码 

用户管理控制器

public class AdminToTeaServlet extends HttpServlet {

	private BusinessService service = new BusinessServiceImpl();
	private static final long serialVersionUID = 1L;

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		request.setCharacterEncoding("utf-8");
		response.setContentType("text/jsp;charset=utf-8");
		response.setCharacterEncoding("utf-8");
		Admin admin = (Admin) request.getSession().getAttribute("admin");
		if(admin!=null){
			// 此段代码用于防止刷新后的重复提交
			// 时间戳
			String timeStamp = String.valueOf(new java.util.Date().getTime());
			HttpSession session = request.getSession();
			// 创建新令牌值
			String tokenStr = session.getId() + timeStamp;
			// 识别令牌,不合法将中止页面运行
			// 更新令牌
			session.setAttribute("CONTROL_REFRESH", tokenStr);
			// 设置页码
			String pageNum = request.getParameter("pageNum");
			Page page =service.findTeachersRecords(pageNum);
			page.setUrl("/AdminToTeaServlet");
			request.setAttribute("page", page);
			request.getRequestDispatcher("/WEB-INF/admin_teacher.jsp").forward(request,
					response);
		}else{
			request.setAttribute("message",
					"<script type='text/javascript'>alert('请先登录方可操作')</script>");
			request.getRequestDispatcher("/index.jsp").forward(request,
					response);
			return;
		}
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

选课管理系统

public class GetCourseToUpdateServlet extends HttpServlet {

	private BusinessService service = new BusinessServiceImpl();
	private static final long serialVersionUID = 1L;

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		request.setCharacterEncoding("utf-8");
		response.setContentType("text/jsp;charset=utf-8");
		response.setCharacterEncoding("utf-8");
		Admin admin = (Admin) request.getSession().getAttribute("admin");
		if (admin == null) {
			request.setAttribute("message",
					"<script type='text/javascript'>alert('请先登录才可操作')</script>");
			request.getRequestDispatcher("/index.jsp").forward(request,
					response);
			return;
		} else {
			// 时间戳
			String timeStamp = String.valueOf(new java.util.Date().getTime());
			HttpSession session = request.getSession();
			// 创建新令牌值
			String tokenStr = session.getId() + timeStamp;
			// 识别令牌,不合法将中止页面运行
			// 更新令牌
			session.setAttribute("CONTROL_REFRESH", tokenStr);
			String pageNum = request.getParameter("pageNum");
			String cno = request.getParameter("cno");
			Course course = service.queryCourse(cno);
			request.setAttribute("course", course);
			request.setAttribute("pageNum", pageNum);
			request.getRequestDispatcher(
					"/WEB-INF/admin_course_update.jsp").forward(request,
					response);
		}

	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

登录管理控制器

public class LoginServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		request.setCharacterEncoding("utf-8");
		response.setContentType("text/jsp;charset=utf-8");
		response.setCharacterEncoding("utf-8");
		BusinessService service = new BusinessServiceImpl();
		// 获取登录类型
		String type = request.getParameter("cho_Province");
		// 获取session对象
		Student student = (Student) request.getSession()
				.getAttribute("student");
		Admin admin = (Admin) request.getSession().getAttribute("admin");
		Teacher teacher = (Teacher) request.getSession()
				.getAttribute("teacher");

		// 如果session存在则刷新页面
		if (student != null || admin != null || teacher != null) {
			if (student != null) {
				String pageNum = request.getParameter("pageNum");
				Page page = service
						.findScoresRecords(student.getSno(), pageNum);
				page.setUrl("/LoginServlet");
				request.setAttribute("page", page);
				request.getRequestDispatcher("/WEB-INF/student_main.jsp")
						.forward(request, response);
			}
			if (admin != null) {
				String pageNum = request.getParameter("pageNum");
				Page page = service.findStudentsRecords(pageNum);
				page.setUrl("/LoginServlet");
				request.setAttribute("page", page);
				request.getRequestDispatcher("/WEB-INF/admin_main.jsp")
						.forward(request, response);
			}
			if (teacher != null) {
				String pageNum = request.getParameter("pageNum");
				Page page = service.findScoresRecordsByTno(teacher.getTno(), pageNum);
				page.setUrl("/LoginServlet");
				request.setAttribute("page", page);
				request.getRequestDispatcher("/WEB-INF/teacher_main.jsp")
						.forward(request, response);
			}

		} else {

			if ("管理员".equals(type)) {
				String username = request.getParameter("username");
				String password = request.getParameter("password");

				admin = service.queryAdmin(username);
				if (admin == null) {
					request.setAttribute("message",
							"<script type='text/javascript'>alert('账号不存在')</script>");
					request.getRequestDispatcher("/index.jsp").forward(request,
							response);
					return;
				}
				admin = service.queryAdmin(username, password);
				if (admin == null) {
					request.setAttribute("message",
							"<script type='text/javascript'>alert('密码错误')</script>");
					request.getRequestDispatcher("/index.jsp").forward(request,
							response);
					return;
				}
				request.getSession().setAttribute("admin", admin);
				// 此段代码用于防止刷新后的重复提交
				// 时间戳
				String timeStamp = String.valueOf(new java.util.Date().getTime());
				HttpSession session = request.getSession();
				// 创建新令牌值
				String tokenStr = session.getId() + timeStamp;
				// 识别令牌,不合法将中止页面运行
				// 更新令牌
				session.setAttribute("CONTROL_REFRESH", tokenStr);
				// 设置页码
				String pageNum = request.getParameter("pageNum");
				Page page = service.findStudentsRecords(pageNum);
				page.setUrl("/LoginServlet");
				request.setAttribute("page", page);
				request.getRequestDispatcher("/WEB-INF/admin_main.jsp")
						.forward(request, response);
			} else if ("教师".equals(type)) {
				String username = request.getParameter("username");
				String password = request.getParameter("password");

				teacher = service.queryTeacher(username);
				if (teacher == null) {
					request.setAttribute("message",
							"<script type='text/javascript'>alert('账号不存在')</script>");
					request.getRequestDispatcher("/index.jsp").forward(request,
							response);
					return;
				}
				teacher = service.queryTeacher(username,password);
				if (teacher == null) {
					request.setAttribute("message",
							"<script type='text/javascript'>alert('密码错误')</script>");
					request.getRequestDispatcher("/index.jsp").forward(request,
							response);
					return;
				}
				request.getSession().setAttribute("teacher", teacher);
				// 此段代码用于防止刷新后的重复提交
				// 时间戳
				String timeStamp = String.valueOf(new java.util.Date().getTime());
				HttpSession session = request.getSession();
				// 创建新令牌值
				String tokenStr = session.getId() + timeStamp;
				// 识别令牌,不合法将中止页面运行
				// 更新令牌
				session.setAttribute("CONTROL_REFRESH", tokenStr);
				// 设置页码
				String pageNum = request.getParameter("pageNum");
				Page page = service.findScoresRecordsByTno(teacher.getTno(), pageNum);
				page.setUrl("/LoginServlet");
				request.setAttribute("page", page);
				request.getRequestDispatcher("/WEB-INF/teacher_main.jsp")
						.forward(request, response);
			} else if ("学生".equals(type)) {
				String username = request.getParameter("username");
				String password = request.getParameter("password");

				student = service.queryStudent(username);
				if (student == null) {
					request.setAttribute("message",
							"<script type='text/javascript'>alert('账号不存在')</script>");
					request.getRequestDispatcher("/index.jsp").forward(request,
							response);
					return;
				}
				student = service.queryStudent(username, password);
				if (student == null) {
					request.setAttribute("message",
							"<script type='text/javascript'>alert('密码错误')</script>");
					request.getRequestDispatcher("/index.jsp").forward(request,
							response);
					return;
				}
				request.getSession().setAttribute("student", student);
				// 此段代码用于防止刷新后的重复提交
				// 时间戳
				String timeStamp = String.valueOf(new java.util.Date().getTime());
				HttpSession session = request.getSession();
				// 创建新令牌值
				String tokenStr = session.getId() + timeStamp;
				// 识别令牌,不合法将中止页面运行
				// 更新令牌
				session.setAttribute("CONTROL_REFRESH", tokenStr);
				// 设置页码
				String pageNum = request.getParameter("pageNum");
				Page page = service
						.findScoresRecords(student.getSno(), pageNum);
				page.setUrl("/LoginServlet");
				request.setAttribute("page", page);
				request.getRequestDispatcher("/WEB-INF/student_main.jsp")
						.forward(request, response);
			} else if("请选择身份".equals(type)){
				request.setAttribute("message",
						"<script type='text/javascript'>alert('请先选择登录类型')</script>");
				request.getRequestDispatcher("/index.jsp").forward(request,
						response);
				return;
			}else{
				request.setAttribute("message",
						"<script type='text/javascript'>alert('信息已过期,请重新登录')</script>");
				request.getRequestDispatcher("/index.jsp").forward(request,
						response);
				return;
			}
		}

	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

如果也想学习本系统,下面领取。关注并回复:035jsp

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

夜未央5788

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

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

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

打赏作者

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

抵扣说明:

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

余额充值