作者主页:夜未央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