java学生管理系统总结报告Word文件下载.docx
《java学生管理系统总结报告Word文件下载.docx》由会员分享,可在线阅读,更多相关《java学生管理系统总结报告Word文件下载.docx(23页珍藏版)》请在冰豆网上搜索。
学生管理系统还增加了上传照片的功能,每个学生都可以上传自己的照片,老师也可以帮学生上传照片
1.2知识(点)应用以及经验总结
该学生管理系统采用了分层的思想而且参考了MVC设计模式,但是都做得不够完美。
该系统分为业务逻辑层、实体层和显示层:
⏹业务逻辑层(com.ccniit.student.manage)有StudentManage、GradeManage、PasswordNotFountException、StduentNotFountException和GradeNotFountException。
先写了一个工具类(DBConnection),负责与数据库的连接,业务逻辑层联系数据库实体、显示层。
进行综合的控制与处理。
这里自定义了几个异常类,主要是抛出无法找到相应类的异常。
这样就可以返回多个结果。
⏹实体层(com.ccniit.student)有两个类Student和Grade,是根据数据库里面的表来实现的,字段就是实体里面的属性还有所有属性的get和set方法,也可以写几个构造方法,没有其他的方法。
业务逻辑层就操作这两个类。
⏹显示层(com.ccniit.student.view)有Login、StduentGrade、Teacher、ImagePanel、ShowImage、Uploading这六个类。
主要是负责显示给客户,用于和客户交互信息。
所有学生成绩用一个表来显示,Teacher类有另外一个线程来读取所有学生的成绩,在表中教师可以直接在表中修改学生的成绩,修改过后系统会自动修改数据库的数据,来实现动态修改。
⏹显示层主要是添加的内部匿名监听,由于会有重复监听所以大部分监听都分别写了一个方法,来调用这个方法。
⏹每个学生都可以上传自己的照片,在有照片的情况下,老师可以看到学生的照片这样可以让老师更快的认识每一个学生,点击学生的照片可以放大该学生的照片,点击别的地方该放大的照片就会消失
该系统主要用到的知识有:
⏹流程控制
⏹类和对象
⏹类的继承
⏹接口和多态
⏹数组
⏹顺序表
⏹数据库编程
⏹常用的GUI组件
⏹JTable
⏹多线程
⏹事件处理
2.项目实现及关键代码
(各个功能界面截图+代码说明,代码为关键代码并加入注释)
系统流程图
StduentManage/GradeManage
(逻辑处理层)
DBConnection
Login/Teacher/StduentGrade
(显示层)
Stduent/Grade
(数据模型)
Uploading/ShowImage/ImagePanel
(显示层辅助类)
数据库
(数据持久层)
类
包
层
功能
com.ccniit.student.util
逻辑
连接数据库
Student
com.ccniit.student
模型
保存学生对象
Grade
保存成绩对象
StduentManage
com.ccniit.student.manage
操作学生对象
GradeManage
操作成绩对象
StudentNotFoundException
当学生找不到时抛出此异常
GradeNotFoundException
当成绩找不到时抛出此异常
PasswordNotFoundException
当密码找不到时抛出此异常
Login
com.ccniit.student.view
显示
显示登录界面
Teacher
显示教师界面
StudentGrade
显示学生界面
ImagePanel
读取图片
ShowImage
显示放大的图片
Uploading
上传图片
com.ccniit.student..Stduent类
说明:
此类是一个学生的模型类,提供了学生的属性和get、set方法,便于StudentManage来操作还提供了几个构造方法。
com.ccniit.student.Grade类
说明:
此类是成绩模型类,提供了成绩的属性和get、set方法和几个构造方法,便于GradeManage来操作。
com.ccniit.student.util.DBConnection类
这个类的功能是与底层数据库创建连接给逻辑处理层,还有关闭连接的相关功能。
//管理与数据库的连接
publicclassDBConnection{
static{
try{
Class.forName("
com.microsoft.sqlserver.jdbc.SQLServerDriver"
);
}catch(ClassNotFoundExceptione){
e.printStackTrace();
}
}
publicstaticConnectiongetConn()throwsSQLException{
Connectionconn=DriverManager.getConnection(
"
jdbc:
sqlserver:
//localhost:
1433;
databaseName=studentManage"
sa"
"
580000"
returnconn;
//数据库关闭的方法
publicstaticvoidclosePstmt(PreparedStatementpstmt){
if(pstmt!
=null){
try{
pstmt.close();
}catch(SQLExceptione){
e.printStackTrace();
}
publicstaticResultSetexecuteQuery(PreparedStatementpstmt)throwsSQLException{
ResultSetrs=pstmt.executeQuery();
returnrs;
publicstaticvoidcloseRs(ResultSetrs){
if(rs!
rs.close();
}
com.ccniit.student.manage.StudentManage类
此类是逻辑处理层里面的学生管理类,有添加学生、删除学生、修改学生信息、检查学生是否登录成功、查找学生等方法,显示层可以直接调用这些方法来实现需要的功能。
其中查找方法是有方法的组合。
publicclassStudentManage{
//添加学生
publicstaticbooleanadd(Students){
Connectionconn=null;
PreparedStatementpstmt=null;
booleanflag=false;
conn=DBConnection.getConn();
Stringsql="
insertintostudent(studentID,studentName,password,sex,birth,phone,qq,homeAddr,entranceTime)values(?
?
)"
;
pstmt=DBConnection.getPstmt(conn,sql);
pstmt.setString(1,s.getStudentID());
pstmt.setString(2,s.getStudentName());
pstmt.setString(3,s.getPassword());
pstmt.setString(4,s.getSex());
pstmt.setDate(5,s.getBirth());
pstmt.setString(6,s.getPhone());
pstmt.setString(7,s.getQq());
pstmt.setString(8,s.getHomeAddr());
pstmt.setDate(9,s.getEntranceTime());
if(pstmt.executeUpdate()>
0){
flag=true;
}catch(SQLExceptione){
}finally{
DBConnection.closePstmt(pstmt);
DBConnection.closeConn(conn);
returnflag;
//修改学生信息
publicstaticbooleanupdate(Students){
updatestudentsetstudentName=?
password=?
sex=?
birth=?
phone=?
qq=?
homeAddr=?
entranceTime=?
wherestudentID=?
"
pstmt.setString(1,s.getStudentName());
pstmt.setString(2,s.getPassword());
pstmt.setString(3,s.getSex());
pstmt.setDate(4,s.getBirth());
pstmt.setString(5,s.getPhone());
pstmt.setString(6,s.getQq());
pstmt.setString(7,s.getHomeAddr());
pstmt.setDate(8,s.getEntranceTime());
pstmt.setString(9,s.getStudentID());
//检查学生登录是否成功
publicstaticStudentcheck(StringstudentID,Stringpassword)
throwsStudentNotFoundException,PasswordNotCorrectException{
Studentstudent=null;
ResultSetrs=null;
select*fromstudentwherestudentID=?
pstmt.setString(1,studentID);
rs=DBConnection.executeQuery(pstmt);
if(!
rs.next()){
thrownewStudentNotFoundException();
}elseif(!
rs.getString("
password"
).trim().equals(password)){
//System.out.println(rs.getString("
));
//System.out.println(password);
thrownewPasswordNotCorrectException();
}else{
student=newStudent(rs.getString
(1),rs.getString
(2),
rs.getString(3),rs.getString(4),rs.getDate(5),
rs.getString(6),rs.getString(7),rs.getString(8),
rs.getDate(9));
DBConnection.closeRs(rs);
returnstudent;
com.ccniit.student.manage.GradeManage类
此类是逻辑处理层里面的成绩管理类,有添加成绩、删除成绩、修改成绩、查找成绩等方法,显示层可以直接调用这些方法来实现需要的功能。
com.ccniit.student.view.Login类
此类是显示层的登录界面,此界面类似一个对话框,但是他是继承JFrame,分为两个模块:
学生登录和教师登录。
有一个下拉条可以选择是学生登录还是教师登录,当选择学生登录时,会登录进入学生界面,当选择教师登录时会进入教师界面。
//添加登录界面的角色选择监听
jcbPost.addActionListener(newActionListener(){
publicvoidactionPerformed(ActionEvente){
if(jcbPost.getSelectedItem().equals("
学生"
)){
jlLogin.setText("
学生登录"
jlID.setText("
学号:
}else{
教师登录"
教师号:
}
});
add(jcbPost);
//监听登录按钮
jbLogin.addActionListener(newActionListener(){
//由于一般就是一个教师修改学生信息,所以教师没有建表,所有的教师都通过一个id号和密码登录
教师"
if(jtfID.getText().trim().equals("
jiaoshi"
)&
&
String.valueOf(jpfPassword.getPassword()).trim().equals("
setVisible(false);
newTeacher().setVisible(true);
}else{
JOptionPane.showMessageDialog(Login.this,"
登录失败!
jiaoshi密码:
jiaoshi."
}
Stringid=jtfID.getText().trim();
Stringpassword=String.valueOf(jpfPassword.getPassword()).trim();
if("
.equals(id)){
请输入学号!
return;
}elseif("
.equals(password)){
请输入密码!
try{
//检查学生登录是否正确,会抛出下面的两种异常,返回登录的学生信息,传递给StudentGrade类
Studentstudent=StudentManage.check(id,password);
newStudentGrade(student,false).setVisible(true);
}catch(StudentNotFoundExceptione1){
学号不存在!
}catch(PasswordNotCorrectExceptione1){
密码错误!
com.ccniit.student.view.StduentGrade类
此类是显示层的学生成绩界面,有菜单栏、内容窗口、功能按钮,此界面的功能是查询登录学生的成绩,查询学生的个人详细信息,修改个人信息,修改密码等功能。
还新创建了一个线程来读取学生的成绩和信息,此线程是一个内部类,有一个修改密码的小窗口是一个内部类继承了JDialog,修改信息的内部类小窗口继承了JDialog。
学生还可以上传自己的照片,修改自己上传的照片,上传后学生就能看到自己的照片,但是学生不能修改自己的班级和入学时间,这两项老师可以修改。
部分界面如下图所示:
还有一些关键代码:
//声明一个线程来默认读取学生的成绩信息
privateclassLoadThreadimplementsRunnable{
publicvoidrun(){
intrecords=GradeManage.findByID(grades,student.getStudentID());
Object[]columnNames={"
课程名称"
学期"
学年"
分数"
};
Object[][]rowData=newObject[records][columnNames.length];
for(inti=0;
i<
grades.size();
i++){
Gradegrade=grades.get(i);
rowData[i][0]=grade.getCourseName();
rowData[i][1]=grade.getSemester();
rowData[i][2]=grade.getSchoolYear();
rowData[i][3]=grade.getGrade();
table=newJTable(rowData,columnName