用myeclipse创建一个简单班级考勤管理系统网页,给出具体部署过程和代码

时间: 2024-03-04 18:49:13 浏览: 19
好的,我可以提供一些代码和部署过程的指导。首先,我们需要安装MyEclipse和Tomcat服务器。然后,我们可以按照以下步骤进行操作: 1. 创建一个Web项目 在MyEclipse中选择“File” -> “New” -> “Web Project”,填写项目名称和目标运行服务器(Tomcat),并选择Web应用程序版本(3.1或更高版本)。 2. 添加依赖库 在项目上单击鼠标右键,选择“Properties” -> “Java Build Path” -> “Libraries” -> “Add Library”,添加所需的JAR包,例如JDBC驱动程序。 3. 创建数据库 我们可以使用MySQL数据库,创建一个名为“attendance”的数据库和三个表,分别为“student”、“teacher”和“attendance_record”。表结构如下: ``` CREATE TABLE student ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(50) NOT NULL, gender varchar(10) NOT NULL, PRIMARY KEY (id) ); CREATE TABLE teacher ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(50) NOT NULL, PRIMARY KEY (id) ); CREATE TABLE attendance_record ( id int(11) NOT NULL AUTO_INCREMENT, student_id int(11) NOT NULL, teacher_id int(11) NOT NULL, record_date date NOT NULL, is_present tinyint(1) NOT NULL, PRIMARY KEY (id), FOREIGN KEY (student_id) REFERENCES student(id), FOREIGN KEY (teacher_id) REFERENCES teacher(id) ); ``` 4. 编写JSP页面 我们可以创建以下JSP页面: - index.jsp:显示“学生考勤”和“教师考勤”两个链接。 - student.jsp:显示学生列表和考勤记录。 - teacher.jsp:显示教师列表和考勤记录。 index.jsp代码如下: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>班级考勤管理系统</title> </head> <body> <h1>班级考勤管理系统</h1> <ul> <li><a href="student.jsp">学生考勤</a></li> <li><a href="teacher.jsp">教师考勤</a></li> </ul> </body> </html> ``` student.jsp代码如下: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="java.sql.*" %> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>学生考勤</title> </head> <body> <h1>学生考勤</h1> <table> <tr> <th>ID</th> <th>姓名</th> <th>性别</th> <th>考勤记录</th> </tr> <% Class.forName("com.mysql.jdbc.Driver"); Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/attendance", "root", "password"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM student"); while(rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); String gender = rs.getString("gender"); out.println("<tr>"); out.println("<td>" + id + "</td>"); out.println("<td>" + name + "</td>"); out.println("<td>" + gender + "</td>"); out.println("<td><a href=\"attend.jsp?student_id=" + id + "\">查看考勤记录</a></td>"); out.println("</tr>"); } rs.close(); stmt.close(); conn.close(); %> </table> </body> </html> ``` teacher.jsp代码如下: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="java.sql.*" %> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>教师考勤</title> </head> <body> <h1>教师考勤</h1> <table> <tr> <th>ID</th> <th>姓名</th> <th>考勤记录</th> </tr> <% Class.forName("com.mysql.jdbc.Driver"); Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/attendance", "root", "password"); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM teacher"); while(rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); out.println("<tr>"); out.println("<td>" + id + "</td>"); out.println("<td>" + name + "</td>"); out.println("<td><a href=\"attend.jsp?teacher_id=" + id + "\">查看考勤记录</a></td>"); out.println("</tr>"); } rs.close(); stmt.close(); conn.close(); %> </table> </body> </html> ``` attend.jsp代码如下: ``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="java.sql.*" %> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>考勤记录</title> </head> <body> <h1>考勤记录</h1> <table> <tr> <th>日期</th> <th>是否出席</th> </tr> <% Class.forName("com.mysql.jdbc.Driver"); Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/attendance", "root", "password"); PreparedStatement pstmt = null; ResultSet rs = null; if(request.getParameter("student_id") != null) { int student_id = Integer.parseInt(request.getParameter("student_id")); pstmt = conn.prepareStatement("SELECT * FROM attendance_record WHERE student_id=?"); pstmt.setInt(1, student_id); rs = pstmt.executeQuery(); } else if(request.getParameter("teacher_id") != null) { int teacher_id = Integer.parseInt(request.getParameter("teacher_id")); pstmt = conn.prepareStatement("SELECT * FROM attendance_record WHERE teacher_id=?"); pstmt.setInt(1, teacher_id); rs = pstmt.executeQuery(); } while(rs.next()) { Date record_date = rs.getDate("record_date"); boolean is_present = rs.getBoolean("is_present"); out.println("<tr>"); out.println("<td>" + record_date + "</td>"); out.println("<td>" + (is_present ? "出席" : "缺席") + "</td>"); out.println("</tr>"); } rs.close(); pstmt.close(); conn.close(); %> </table> </body> </html> ``` 其中,上述JSP页面中的数据库连接信息需要根据实际情况修改。 5. 编写Java代码 我们可以创建以下Java类: - Student:表示学生,包括id、name和gender等属性,以及获取和设置这些属性的方法。 - Teacher:表示教师,包括id和name等属性,以及获取和设置这些属性的方法。 - AttendanceRecord:表示考勤记录,包括id、student、teacher、recordDate和isPresent等属性,以及获取和设置这些属性的方法。 - AttendanceDao:提供访问数据库的方法,包括获取学生列表、教师列表、考勤记录等操作。 Student代码如下: ``` public class Student { private int id; private String name; private String gender; public Student(int id, String name, String gender) { this.id = id; this.name = name; this.gender = gender; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } } ``` Teacher代码如下: ``` public class Teacher { private int id; private String name; public Teacher(int id, String name) { this.id = id; this.name = name; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } } ``` AttendanceRecord代码如下: ``` public class AttendanceRecord { private int id; private Student student; private Teacher teacher; private Date recordDate; private boolean isPresent; public AttendanceRecord(int id, Student student, Teacher teacher, Date recordDate, boolean isPresent) { this.id = id; this.student = student; this.teacher = teacher; this.recordDate = recordDate; this.isPresent = isPresent; } public int getId() { return id; } public void setId(int id) { this.id = id; } public Student getStudent() { return student; } public void setStudent(Student student) { this.student = student; } public Teacher getTeacher() { return teacher; } public void setTeacher(Teacher teacher) { this.teacher = teacher; } public Date getRecordDate() { return recordDate; } public void setRecordDate(Date recordDate) { this.recordDate = recordDate; } public boolean isPresent() { return isPresent; } public void setPresent(boolean isPresent) { this.isPresent = isPresent; } } ``` AttendanceDao代码如下: ``` public class AttendanceDao { private static final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; private static final String DB_URL = "jdbc:mysql://localhost:3306/attendance"; private static final String USER = "root"; private static final String PASS = "password"; public List<Student> getStudentList() { List<Student> studentList = new ArrayList<Student>(); Connection conn = null; Statement stmt = null; ResultSet rs = null; try { Class.forName(JDBC_DRIVER); conn = DriverManager.getConnection(DB_URL, USER, PASS); stmt = conn.createStatement(); rs = stmt.executeQuery("SELECT * FROM student"); while(rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); String gender = rs.getString("gender"); Student student = new Student(id, name, gender); studentList.add(student); } } catch (SQLException se) { se.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { try { if(rs != null) rs.close(); if(stmt != null) stmt.close(); if(conn != null) conn.close(); } catch (SQLException se) { se.printStackTrace(); } } return studentList; } public List<Teacher> getTeacherList() { List<Teacher> teacherList = new ArrayList<Teacher>(); Connection conn = null; Statement stmt = null; ResultSet rs = null; try { Class.forName(JDBC_DRIVER); conn = DriverManager.getConnection(DB_URL, USER, PASS); stmt = conn.createStatement(); rs = stmt.executeQuery("SELECT * FROM teacher"); while(rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); Teacher teacher = new Teacher(id, name); teacherList.add(teacher); } } catch (SQLException se) { se.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { try { if(rs != null) rs.close(); if(stmt != null) stmt.close(); if(conn != null) conn.close(); } catch (SQLException se) { se.printStackTrace(); } } return teacherList; } public List<AttendanceRecord> getAttendanceRecordList(int studentId, int teacherId) { List<AttendanceRecord> recordList = new ArrayList<AttendanceRecord>(); Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; try { Class.forName(JDBC_DRIVER); conn = DriverManager.getConnection(DB_URL, USER, PASS); if(studentId > 0) { pstmt = conn.prepareStatement("SELECT * FROM attendance_record WHERE student_id=?"); pstmt.setInt(1, studentId); } else if(teacherId > 0) { pstmt = conn.prepareStatement("SELECT * FROM attendance_record WHERE teacher_id=?"); pstmt.setInt(1, teacherId); } rs = pstmt.executeQuery(); while(rs.next()) { int id = rs.getInt("id"); int student_id = rs.getInt("student_id"); int teacher_id = rs.getInt("teacher_id"); Date record_date = rs.getDate("record_date"); boolean is_present = rs.getBoolean("is_present"); Student student = getStudentById(student_id); Teacher teacher = getTeacherById(teacher_id); AttendanceRecord record = new AttendanceRecord(id, student, teacher, record_date, is_present); recordList.add(record); } } catch (SQLException se) { se.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { try { if(rs != null) rs.close(); if(pstmt != null) pstmt.close(); if(conn != null) conn.close(); } catch (SQLException se) { se.printStackTrace(); } } return recordList; } private Student getStudentById(int id) { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; Student student = null; try { Class.forName(JDBC_DRIVER); conn = DriverManager.getConnection(DB_URL, USER, PASS); pstmt = conn.prepareStatement("SELECT * FROM student WHERE id=?"); pstmt.setInt(1, id); rs = pstmt.executeQuery(); if(rs.next()) { String name = rs.getString("name"); String gender = rs.getString("gender"); student = new Student(id, name, gender); } } catch (SQLException se) { se.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { try { if(rs != null) rs.close(); if(pstmt != null) pstmt.close(); if(conn != null) conn.close(); } catch (SQLException se) { se.printStackTrace(); } } return student; } private Teacher getTeacherById(int id) { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; Teacher teacher = null; try { Class.forName(JDBC_DRIVER); conn = DriverManager.getConnection(DB_URL, USER, PASS); pstmt = conn.prepareStatement("SELECT * FROM teacher WHERE id=?"); pstmt.setInt(1, id); rs = pstmt.executeQuery(); if(rs.next()) { String name = rs.getString("name"); teacher = new Teacher(id, name); } } catch (SQLException se) { se.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { try { if(rs != null) rs.close(); if(pstmt != null) pstmt.close(); if(conn != null) conn.close(); } catch (SQLException se) { se.printStackTrace(); } } return teacher; } } ``` 6. 部署项目 将上述代码保存到相应的文件中,并将JAR包放入WEB-INF/lib目录下。然后,将整个项目打包成WAR文件,并将其部署到Tomcat服务器中。 现在,我们可以访问http://localhost:8080/attendance/index.jsp,进入班级考勤管理系统,浏览学生和教师列表,以及查看他们的考勤记录。 以上是一个简单的班级考勤管理系统的实现过程和代码,你可以根据自己的需要进行修改和优化。

相关推荐

最新推荐

recommend-type

用java做的新闻网站设计实现(包含后台管理系统)

系统由登录模块,注册模块,俱乐部管理,球员管理,战报管理,新闻公告管理,角色管理,系统管理模块等模块组成。每个模块都实现了增加、删除、修改,查询等相关操作。为了保证系统的安全性,在用户登录系统设计时,...
recommend-type

Weblogic 8.1 + MyEclipse的配置及其Java Web应用的部署和测试.doc

Weblogic 8.1 + MyEclipse的配置及其Java Web应用的部署和测试.doc。介绍很详细
recommend-type

MyEclipse连接Mysql数据库的方法(一)

主要介绍了MyEclipse连接Mysql数据库的方法(一)的相关资料,非常实用,具有参考价值,需要的朋友可以参考下
recommend-type

用MyEclipse开发jsp网页连接MySQL数据库

使用myeclipse开发网站使用tomcat作为服务器MySQL为数据库链接办法
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解答下列问题:S—>S;T|T;T—>a 构造任意项目集规范族,构造LR(0)分析表,并分析a;a

对于这个文法,我们可以构造以下项目集规范族: I0: S -> .S S -> .T T -> .a I1: S -> S. [$ T -> T. [$ I2: S -> T. I3: S -> S.;S S -> S.;T T -> T.;a 其中,点(.)表示已经被扫描过的符号,;$表示输入串的结束符号。 根据项目集规范族,我们可以构造出LR(0)分析表: 状态 | a | $ ---- | - | - I0 | s3| I1 | |acc I2 | | 其中s3表示移进到状态3,acc表示接受。在分析字符串a;a时,我们可以按照以下步骤进行
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依