JavaEE-jdbc+jsp+servlet应用:作业管理系统(超详细解释代码逻辑)(Version1)

(结尾附有源码地址)

功能需求

老师:添加作业,添加学生,查询作业(查询所有人的作业提交情况、查询某个人的作业情况、查询某次作业的提交情况)
学生:提交作业

系统设计

数据库表结构

总共有三张表
在这里插入图片描述
1.homework表(老师发布作业记录表)
在这里插入图片描述
2.student表(学生信息表)
在这里插入图片描述
3.student_homework表(学生提交作业记录表)
在这里插入图片描述

代码框架

在这里插入图片描述

数据映射类(Model)

新建三个类(homework类、student类、StudentHomework类)
这样可以将表中的一条记录抽象成java中的一个对象。详情了解对象关系映射。
在这里插入图片描述
每个类里面主要是申明与数据库对应的变量以及实现获取属性值修改属性值。结构类似于:

private Long id;
public Long getId() {
        return id;
}
public void setId(Long id) {
        this.id = id; 
}
数据库操作类(Jdbc)

1.Homeworkjdbc类
该类中有6个方法

  • addHomework(Homework th)-增加作业
  • selectAllStudentHomework()-查询所有学生提交的作业
  • selectAllTeacherHomework()-查询所有老师布置的作业
  • List selectAStudentHomework(Long student_id)-查询某位同学提交的所有作业
  • List selectAHomework(Long homework_id)-查询某次作业的提交情况
  • handHomework(StudentHomework sh)-学生提交作业

2.Studentjdbc类
该类中有3个方法

  • addStudent(Student newStudent)-添加学生
  • List selectAllStudent()-查询所有学生
业务逻辑

首页包含四个按钮,下面我会详细介绍四个按钮的跳转功能的实现(建议对照Github的代码食用,效果会更佳)
在这里插入图片描述
这里的每一个按钮其实只是一个类似于超链接的东西,点击后会跳转到相应的注解类。并且为了方便使用我在每一个界面都设置了返回按钮可以退回上级界面。

老师发布作业
点击后会跳转到/searchAllTh对应的注解类TeacherHomeworkServlet,然后在此注解类中我们会做些什么呢?我们先用数据库操作类将所有老师布置的作业查询出来放到一个列表里面,然后将这个列表以键值对的形式通过req发送到Tea_Add_HW.jsp中
在这里插入图片描述
上图是Tea_Add_HW.jsp对应的界面。已发布的作业就是之前我们得到的列表的内容。列出所有作业情况的话方便我们添加发布作业时不会发布错误。下面是一个表单,如果我们要发布作业只需填好信息点击发布按钮就能将信息发布出去。它会跳转到/addhomework注解类-TeacherAddHomeworkServlet中执行操作。
在该类中我们设置了异常处理机制。如果作业编号、作业标题、作业内容中有一者未填都会显示错误并返回到首页。发布作业编号重复也会报出相应错误,添加成功或者失败都会有相应提示。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
老师添加学生
点击后会跳转到/searchStudent对应的注解类TeacherSearchStudentServlet,然后在此注解类中我们会做些什么呢?我们先用数据库操作类将所有已有的学生查询出来放到一个列表里面,然后将这个列表以键值对的形式通过req发送到Tea_Add_Student.jsp中
在这里插入图片描述
上图是Tea_Add_Student.jsp对应的界面。学生列表就是之前我们得到的列表的内容。列出所有学生的话方便我们添加学生学号时不会添加错误。下面是一个表单,如果我们要添加学生只需填好信息点击添加按钮就能将信息发布出去。它会跳转到/addStudent注解类-TeacherAddStudentServlet中执行操作。
在该类中我们同样设置了异常处理机制。如果学生学号、学生姓名中有一者未填都会显示错误并返回到首页。添加的学号重复也会报出相应错误,添加成功或者失败都会有相应提示。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
老师查看作业
点击后会跳转到/searchAllSh对应的注解类TeacherSearchShServlet,然后在此注解类中我们会做些什么呢?我们先用数据库操作类将所有学生提交的作业查询出来放到列表里面,然后将列表以键值对的形式通过req发送到Tea_Query_HW.jsp中
在这里插入图片描述
上图是Tea_Query_HW.jsp对应的界面。作业提交记录就是之前我们得到的列表的内容。而已发布作业的信息我们直接在jsp中调用函数获取。这两种方法都能获取数据。下面是两个表单,在数据量较多时方便老师快速查询,我们只需输入学生学号点击查询按钮就能获取该学生提交的所有作业。它会跳转到/queryStuHW注解类-TeacherSearchAStudentHWServlet中执行操作。这里我们另设了一个JSP来展示,逻辑类似之前的,不细说了。如果要查询某次作业输入作业编号即可查询。都会跳转到AStudentHW.jsp中。
查询学号为17301002的作业提交情况
在这里插入图片描述
要查询的作业记录不存在,可能输错了学号也可能该同学未提交作业或者该作业暂无人提交
在这里插入图片描述
查询作业编号为101的作业提交情况

学生提交作业
点击后会跳转到/handInHomework对应的注解类StudentHandInHomeworkServlet,然后在此注解类中我们直接跳转到Stu_HandIn_HW.jsp页面
在这里插入图片描述
上图是Stu_HandIn_HW.jsp对应的界面。在这个表单中,如果我们要提交作业只需填好信息点击提交按钮就能将作业提交出去。它会跳转到/submit注解类-StudentAddHomeworkServlet中执行操作。
在该类中我们同样设置了异常处理机制。如果作业编号、作业标题、学生学号、作业内容中有一者未填都会显示错误并返回到首页。提交成功或者失败都会有相应提示。
在这里插入图片描述
在这里插入图片描述
完整项目GitHub地址:https://github.com/gittxy/JavaEE-HWManageSystem

  • 2
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要实现用户注册和登录功能,需要以下步骤: 1. 创建数据库表 首先需要在数据库中创建一个表,用来存储用户信息,包括用户名、密码、邮箱等。可以使用以下SQL语句创建一个名为user的表: ``` CREATE TABLE user ( id INT(11) NOT NULL AUTO_INCREMENT, username VARCHAR(50) DEFAULT NULL, password VARCHAR(50) DEFAULT NULL, email VARCHAR(50) DEFAULT NULL, PRIMARY KEY (id) ); ``` 2. 创建JavaBean 创建一个JavaBean,用来封装用户信息。可以定义一个User类,包含用户名、密码和邮箱三个属性,以及相应的getter和setter方法。 ``` public class User { private String username; private String password; private String email; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } } ``` 3. 创建JSP页面 创建一个JSP页面,用来显示用户注册和登录的表单。可以创建两个页面,一个是register.jsp用来显示注册表单,另一个是login.jsp用来显示登录表单。 register.jsp: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>用户注册</title> </head> <body> <h1>用户注册</h1> <form action="register.do" method="post"> 用户名:<input type="text" name="username"><br> 密码:<input type="password" name="password"><br> 邮箱:<input type="text" name="email"><br> <input type="submit" value="注册"> </form> </body> </html> ``` login.jsp: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>用户登录</title> </head> <body> <h1>用户登录</h1> <form action="login.do" method="post"> 用户名:<input type="text" name="username"><br> 密码:<input type="password" name="password"><br> <input type="submit" value="登录"> </form> </body> </html> ``` 4. 创建Servlet 创建一个Servlet,用来处理用户注册和登录的请求。可以创建一个名为UserServletServlet,包含doGet和doPost两个方法。doGet方法用来显示注册和登录表单,doPost方法用来处理用户提交的表单数据。 ``` public class UserServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String action = request.getParameter("action"); if ("register".equals(action)) { request.getRequestDispatcher("/register.jsp").forward(request, response); } else if ("login".equals(action)) { request.getRequestDispatcher("/login.jsp").forward(request, response); } } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String action = request.getParameter("action"); if ("register".equals(action)) { String username = request.getParameter("username"); String password = request.getParameter("password"); String email = request.getParameter("email"); User user = new User(); user.setUsername(username); user.setPassword(password); user.setEmail(email); UserDao userDao = new UserDao(); userDao.addUser(user); response.sendRedirect("login.jsp"); } else if ("login".equals(action)) { String username = request.getParameter("username"); String password = request.getParameter("password"); UserDao userDao = new UserDao(); User user = userDao.getUserByUsername(username); if (user != null && user.getPassword().equals(password)) { response.sendRedirect("welcome.jsp"); } else { response.sendRedirect("login.jsp"); } } } } ``` 在doGet方法中,根据action参数的不同,分别显示注册和登录表单。在doPost方法中,如果action为register,则获取用户提交的表单数据,创建一个User对象,并将其保存到数据库中。保存完成后,重定向到登录页面。如果action为login,则获取用户提交的表单数据,根据用户名从数据库中查找对应的User对象,检查密码是否正确。如果登录成功,则重定向到欢迎页面,否则重定向到登录页面。 5. 创建Dao 创建一个Dao,用来操作数据库。可以创建一个名为UserDao的Dao,包含addUser和getUserByUsername两个方法。addUser方法用来将User对象保存到数据库中,getUserByUsername方法用来根据用户名从数据库中查找对应的User对象。 ``` public class UserDao { public void addUser(User user) { Connection conn = null; PreparedStatement pstmt = null; try { conn = DBUtil.getConnection(); String sql = "INSERT INTO user(username, password, email) VALUES(?, ?, ?)"; pstmt = conn.prepareStatement(sql); pstmt.setString(1, user.getUsername()); pstmt.setString(2, user.getPassword()); pstmt.setString(3, user.getEmail()); pstmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { DBUtil.close(conn, pstmt, null); } } public User getUserByUsername(String username) { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; User user = null; try { conn = DBUtil.getConnection(); String sql = "SELECT * FROM user WHERE username=?"; pstmt = conn.prepareStatement(sql); pstmt.setString(1, username); rs = pstmt.executeQuery(); if (rs.next()) { user = new User(); user.setUsername(rs.getString("username")); user.setPassword(rs.getString("password")); user.setEmail(rs.getString("email")); } } catch (SQLException e) { e.printStackTrace(); } finally { DBUtil.close(conn, pstmt, rs); } return user; } } ``` 在addUser方法中,使用PreparedStatement对象执行INSERT语句,将User对象的属性值插入到数据库中。在getUserByUsername方法中,使用PreparedStatement对象执行SELECT语句,从数据库中查找对应的User对象。如果找到了,则创建一个User对象,并将其属性赋值为ResultSet对象中的值。 6. 创建DBUtil 创建一个DBUtil,用来连接数据库。可以创建一个名为DBUtil的类,包含getConnection和close两个静态方法。getConnection方法用来获取一个数据库连接,close方法用来关闭数据库连接和相关的对象。 ``` public class DBUtil { private static final String URL = "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false"; private static final String USER = "root"; private static final String PASSWORD = "123456"; static { try { Class.forName("com.mysql.jdbc.Driver"); } catch (ClassNotFoundException e) { e.printStackTrace(); } } public static Connection getConnection() throws SQLException { return DriverManager.getConnection(URL, USER, PASSWORD); } public static void close(Connection conn, Statement stmt, ResultSet rs) { try { if (rs != null) { rs.close(); } if (stmt != null) { stmt.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } } ``` 在getConnection方法中,使用DriverManager对象获取一个数据库连接。在close方法中,关闭ResultSet、Statement和Connection对象,并捕获可能发生的SQLException异常。 7. 创建欢迎页面 创建一个欢迎页面,用来显示登录成功的消息。可以创建一个名为welcome.jspJSP页面,显示欢迎用户的信息。 ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>欢迎</title> </head> <body> <h1>欢迎您,${param.username}!</h1> <p>您已成功登录。</p> </body> </html> ``` 在页面中使用EL表达式显示用户名,并显示欢迎信息。 8. 配置web.xml 在web.xml文件中配置ServletJSP页面的映射关系,以及其他相关配置信息。 ``` <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"> <servlet> <servlet-name>UserServlet</servlet-name> <servlet-class>com.example.UserServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>UserServlet</servlet-name> <url-pattern>/register.do</url-pattern> <url-pattern>/login.do</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>welcome.jsp</welcome-file> </welcome-file-list> </web-app> ``` 在web.xml文件中配置ServletJSP页面的映射关系,将UserServlet映射到/register.do和/login.do两个URL上。同时,将welcome.jsp设置为欢迎页面。 以上就是基于JSP Servlet JavaBean实现用户注册和登录的全部步骤。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值