资源描述
贵州航天职业技术学院
Java课程设计报告
专 业:
班 级:
学 号:
姓 名:
指导老师:
时 间:
摘要 - 3 -
标准化考试系统 - 4 -
1.设计内容及要求 - 4 -
1.1 标准化考试系统的基本要求 - 4 -
1.2 需实现的主要功能 - 5 -
2.需求分析 - 5 -
2.1数据库设计 - 5 -
2.2服务器端和客户端的数据传输方式 - 5 -
2.3 服务器端功能设计 - 6 -
2.4客户端功能设计 - 7 -
3.总体设计 - 8 -
3.1 总体功能图 - 8 -
3.2 总体流程图 - 9 -
4.数据库设计 - 10 -
4.1 数据库及表结构的建立 - 10 -
4.2 JAVA 数据库的连接 - 11 -
5. 主要功能设计流程 - 11 -
5.1服务器端设计流程图 - 11 -
5.2客户端设计流程图 - 12 -
6.代码实现 - 13 -
6.1类之间关系图 - 13 -
6.2 运行效果图 - 14 -
7. 总结与说明 - 19 -
附录 标准化考试系统部分源代码 - 21 -
摘要
【摘要】
随着信息技术的飞速发展和日趋激烈的商业竞争,企业已不再满足于独立、零散的办公自动化应用,企业需要的是协同工作、综合、集成化的解决方案。而网络是解决由于物理距离造成的信息交流不畅、协商沟通不便的办公瓶颈问题的最佳方式。企业网上办公自动化通过对各办公自动化要素的闭环整合,实现了工作流、信息流、知识流和办公自动化系统的整合管理,提供了一个科学、开放、先进的信息化办公平台,实现办公自动化,并进行远程办公或在家办公。企业网上办公自动化将人从繁琐、无序、低序、低端的工作中解放出来从事核心事务,整体提高了单位办事效率和对信息的可控性,降低办公成本,提高执行力,使管理趋于完善。
【关键词】 办公自动化管理、ADO连接、数据源、办公管理
标准化考试系统
1.设计内容及要求
1.1 标准化考试系统的基本要求
设计C/S模式的标准化考试系统,即客户端和服务器端都是Java应用程序,具体要求如下:
(1) 开始运行程序后,出现连接服务器界面,用户输入服务器IP地址,并请求服务器建立套接字连接,程序可以判断用户输入的服务器IP是否正确,并给出连接提示,使客户端与服务器端分离。
(2) 正确连接服务器后,有用户登录验证功能,用户可以选择自己的登录身份,是学生还是教师。用户在登录界面输入用户名,密码以及登录身份后,客户端会把用户的相关信息通过套接字发送到服务器端,服务器端根据客户端传来的信息对用户的身份进行验证,并发送相关信息到客户端。
(3) 学生正确登录后,进入考试主界面,用户可以选择试题进行考试,点击开始按钮开始考试,考试考试后,有计时功能,考试完成以后用户可以查看自己的分数,可以查看原题目、正确答案以及该道题目的分值,用户还可以查看自己所选的答案,用户考试完成后可以选择退出系统。
(4) 教师登录成功后,进入后台管理界面,教师可以对标准化考试系统进行管理,教师有以下管理功能:1.可以增加、查询、修改和删除试题;2.可以查看所有考生的考试成绩,而且可以对考生进行排名查看;3.可以增加、查询、修改和删除学生信息;4.可以增加、修改、查询和删除教师信息;
(5) 试卷名字、学生信息、教师信息、试题全都用SQL Server数据库存储,并且采用JDBC连接数据库。每一道题都必须提供正确答案以及分值。
1.2 需实现的主要功能
① C/S模式,即客户端与服务器端都是Java应用程序;
② 输入服务器IP地址,连接服务器功能;
③ 登录验证功能;
④ 学生可以选择所要做的试题;
⑤ 开始考试后,有计时功能,当时间结束时考试结束;
⑥ 完成考试后,学生可以查看自己的分数、试题、正确答案、分值以及自己所选择的答案;
⑦ 教师可以增加、修改、查询、删除试题;
⑧ 教师可以查看所有考生的成绩,并且可以按成绩降序查看成绩;
⑨ 教师可以增加、修改、查询、删除学生信息;
⑩ 教师可以增加、修改、查询、删除教师信息;
2.需求分析
根据标准化考试系统的设计要求和所要实现的功能,对标准化考试系统的需求分析如下:
2.1数据库设计
此标准化考试系统采用的是数据库来存储试题的,而不是采用文件最主要的一个原因是数据库的读取速度比文件读取速度快。该系统采用的是SQL Server 2005数据库,SQL Server数据库是一个非常强大的数据库,在各方面应用比较广泛,是一些中小型项目开发首选数据库。该标准化考试系统需要创建kaoshi数据库文件,在该数据库中需要创建student、teachter、shijuan和Test1四个表。Student数据表是用来存储学生信息;teachter数据表用来存储教师信息;shijuan数据表用来存储试卷名字;Test1用来存储试题。
2.2服务器端和客户端的数据传输方式
服务器端和客户端的数据时用套接字来传输的。IP地址表示Internet上的计算机,端口号标识正在计算机运行的进程。端口号与IP地址的组合得出一个网络套接字。客户端使用Socket类建立到服务器的套接字连接,具体实现:
try{
Socket sock=new Socket(String host,int port);
}catch(IOException e){}
当套接字连接sock建立后,sock使用getInputStream()方法获得一个输入流,然后把获得的输入流接到另一个数据流上,然后就可以从这个数据流读取服务器来的信息,同样sock使用getOutputStream()方法获得一个输出流,然后把获得的输出流接到另一个DataOutputStram()数据流上,然后向这个数据流写入信息,发送给服务器。客户负责建立客户端到服务器的套接字连接,即客户端负责呼叫,因此服务器必须建立一个等待接收客户的套接字的ServerSocket对象,具体实现:
try{
ServerSocket server_socket=new ServerSocket(int port);
}catch(IOException e){}
当服务器的ServerSocket对象建立后,就可以使用accept()方法接收客户的套接字。
2.3 服务器端功能设计
服务器端是接受客户端传来的信息,并作出相应的处理。标准化考试系统服务器端最主要是实现试题的读取。为了完成这个标准化考试系统还需要服务器有一些其他的功能,比如:计算学生考试分数,用户登录验证,教师对系统管理的实现等。
2.3.1试题读取功能
本系统是采用数据库来存储试题的,所以要读取试题必须首先建立与Test1数据表的连接,然后利用ResultSet的对象rs的getString()方法得到试题的内容,然后把试题内容发给客户端。
2.3.2 用户登录验证功能
当用户登录时,客户端会获取用户输入的用户名和密码,并且会把信息发送给服务器,服务器会根据客户端发来的信息对用户的身份进行验证。
kaoshi数据库有两个数据表是用来存储用户信息的,student数据表存储学生信息,teachter数据表存储教师信息,当用户以学生身份登录系统时,服务器会在student数据表中查询有没有这个用户,并根据查询的信息判断学生是否成功登陆,把信息发送给客户端,当用户以教师身份登录系统时,服务器会在student数据表中查询有没有这个用户,并根据查询的信息判断教师是否成功登陆,把信息发送给客户端。
2.4客户端功能设计
客户端是提供学生进行考试和教师对系统进行管理,由于该系统是C/S模式,所以客户端必须有连接服务器功能,连接服务器后有用户登录功能,用户正确登录后,学生用户进入考试界面,所以客户端必须有考试功能,教师用户正确登录后进入教室管理界面,客户端必须有试题管理功能,查询学生成绩功能,学生信息管理功能,教师信息管理功能。
2.4.1连接服务器功能
客户端与服务器端连接时通过套接字实现的,本系统采用的是把套接字放在一个线程中,就是使用Socket类不带参数的构造方法Socket()创建一个套接字对象,该对象需调用public void connect(SocketAddress endpoint) throws IOException ,请求和参数SocketServer指定的套接字建立连接。为了使用connect方法,可以使用SocketAddress的子类InetSocketAddress创建一个对象, InetSocketAddress的构造方法如下:public InetSocketAddress(InetAddress addr,int port)。
2.4.2用户登录功能
用户在进入系统前必须经过用户登录,用户登录功能是为了保护系统的安全,当用户写入用户名和密码,并且选择了登陆身份后,客户端会获取用户的信息发送给服务器端,让服务器度昂对用户的身份进行验证,并传来登录是否成功的信息,客户端根据服务器端传来的信息进行判断,如果登录成功,弹出对话框显示用户登录成功,学生进入考试界面,教师进入后台管理界面;如果登录失败,弹出对话框显示用户名或密码错误或者显示你已经登录了。
2.4.3考试功能
学生正确登录后就进入考试界面,学生进入考试界面后,必须选择试卷,客户端会通知服务器端列出所有的试卷名称,在客户端的下拉列表中会显示所有试卷的名字,用户选择了试卷后,客户端会通知服务器端学生所选的试卷名称,学生点击开始考试按钮就可以开始考试了,同时计时器开始计时,当用户完成考试或者时间用完了考试结束,考试结束后用户可以点击查询成绩按钮,用户可以看到题目,答案以及自己所选的答案,还有你的成绩,查询成绩是用对话框实现,玩了后用户可以退出系统。
2.4.4后台管理功能
后台管理功能就是对试题进行管理,查询学生成绩,对学生信息进行管理,对教师信息进行管理,试题管理有对尸体进行增加,删除,查询,修改,当用户在客户端输入试题信息后,点击这些按钮,客户端就会发送信息给服务器,服务器来查询或者修改数据库,其他的也一样,总是通过服务器端对数据库进行数据库操作
3.总体设计
3.1 总体功能图
根据分析,标准化考试系统必须实现以下功能:1.连接服务器功能;2.用户登录功能;3.考试功能;4.管理功能;
根据系统需求,标准化考试系统的总体功能图如图3-1所示:
图3-1总体功能图
3.2 总体流程图
图3-2 总体流程图
4.数据库设计
4.1 数据库及表结构的建立
该标准化考试系统共创建了一个kaoshi数据库,该数据库中创建了student、teachter、shijuan和Test1四个表。
表3-1 kaoshi数据库
逻辑名称
文件类型
文件组
初始大小
自动增长
路径
文件名
kaoshi
数据
PRIMARY
3MB
不限制
D:\...
Kaoshi_log
日志
不适用
1MB
不限制
D:\...
student数据表是用来保存学生信息,该数据表包含用户名,密码,性别,年龄,班级和分数六个字段,具体设计如表3-2所示:
表3-2 student数据表
列名
数据类型
允许空
用户名
varchar(50)
否
密码
varchar(50)
否
性别
varchar(50)
否
年龄
varchar(50)
否
班级
varchar(50)
否
分数
int
是
teachter数据表是用来存储教师信息,该数据表包含教工ID,教工姓名,教工密码,教工性别和教工职称5个字段,具体设计如表3-3所示:
表3-3 teachter数据表
列名
数据类型
允许空
教工ID
varchar(50)
否
教工姓名
varchar(50)
否
教工密码
varchar(50)
否
教工性别
varchar(50)
否
教工职称
varchar(50)
否
Test1数据表是用来存储试题信息的,该数据表包含题目编号,内容,A选项,B选项,C选项,D选项,正确答案和分值8个字段,具体设计如表3-4所示:
表3-4 Test1数据表
列名
数据类型
允许空
题目编号
varchar(50)
否
内容
varchar(500)
否
A选项
varchar(100)
否
B选项
varchar(100)
否
C选项
varchar(100)
否
D选项
varchar(100)
否
正确答案
varchar(50)
否
分值
varchar(50)
否
4.2 JAVA 数据库的连接
该系统是用JDBC连接数据库。首先必须加载JDBC驱动,然后利用DriverManager.getConnection()连接服务器和数据库。具体实现如下:
String driverName = "com.microsoft.sqlserver.jdbc.SQLServerDriver"; //加载JDBC驱动
String dbURL = "jdbc:sqlserver://localhost:1433; DatabaseName=kaoshi";
//连接服务器和数据库kaoshi
String userName = "sa"; //默认用户名
String userPwd = "123"; //密码
try {
Class.forName(driverName);
dbConn = DriverManager.getConnection(dbURL, userName, userPwd);
System.out.println("Connection Successful!"); //如果连接成功 控制台输出Connection Successful!
}
catch (Exception e) {e.printStackTrace();}
}
5. 主要功能设计流程
5.1服务器端设计流程图
根据对服务器端功能的分析,得到服务器设计流程图如图3-3所示:
图3-3 服务器端设计流程图
5.2客户端设计流程图
根据客户端功能分析,得到客户端设计流程图如图3-4所示:
图3-4 客户端设计流程图
6.代码实现
6.1类之间关系图
在编写标准化考试系统时,编写了8个java源文件:Main.Java,ChaChengji.Java,ClientTestArea.Java,DengluPanel.Java,Guanli.Java,Lianjie.Java,ChatServer.Java,ReadTestquestion.Java其中ChatServer.Java,ReadTestquestion.Java为服务器端java程序编译产生所需要的类;Main.Java,ChaChengji.Java,ClientTestArea.Java,DengluPanel.Java,Guanli.Java,Lianjie.Java为客户端java程序编译产生所需要的类。标准化考试系统除了需要编写的8个java源文件所编译产生的类外,还需要java系统提供的一些重要的类。如ServerSocket,Socket,JTabbedPane等类。标准化考试系统所用到的一些重要的类以及它们之间的关系如图3-5和图3-6所示。
图3-5 服务器端类之间的关系图
图3-6 客户端类之间的关系图
6.2 运行效果图
连接服务器界面:
图3-7 连接服务器界面
学生登录界面:
图3-8 学生登录界面
考试主界面:
图3-9 考试主界面
开始考试后界面:
图3-10 开始考试后界面
成绩查询界面:
图3-11 成绩查询界面
教师登录界面:
图3-12 教师登录界面
试题管理界面:
图3-13 试题管理界面
查看学生成绩界面:
图3-14 查看学生成绩界面
学生信息管理界面:
图3-15 学生信息管理界面
教师信息管理界面:
图3-16 教师信息管理界面
服务器端效果图:
图3-17 服务器端效果图
7. 总结与说明
该标准化考试系统采用的是C/S模式,客户端和服务器端都是应用程序。客户端与服务器端是用Socket和ServerSocket进行通信,服务器端根据客户端传来的信息来进行相应的操作,客户端根据服务器传来的信息把信息显示给用户。该系统有学生考试功能和教师管理功能,两个功能都是在客户端,数据库存放在服务器端。本系统有3个特点:
① 本系统采用的全都是null布局。空布局容器可以准确地定位组件在容器中的位置和大小,setBounds(int a,int b,int width,int height)方法是所有组件都拥有的一个方法,组件调用该方法可以设置本身的大小和在容器中的位置。
② 本系统用了大量的图片。这些图片作为窗口的背景和按钮的背景,加入背景图片必须采用null布局,这些图片不是用drawImage()方法绘制的,而是用把背景图片加到JLabel,然后在容器中加入其它组件并设置这些组件的大小和位置,最后在该容器中加入JLabel组件,把JLabel组件的大小设置成窗口一样大,这样就实现了背景图片的加入。因为本系统采用了大量的图片,所以界面不会很难看。有人说用java做出来的界面很难看,我看不一定,java不是提供了图片功能吗,只要应用好java的这个特性就行。所以不管那一种编程语言,只要它提供了图片功能,那么用它编写的界面就不会很难看。
③ 本系统采用SQL Server存储数据,并且用JDBC连接数据库。用JDBC连接SQL Server数据库首先必须加载JDBC驱动,然后利用DriverManager.getConnection()连接服务器和数据库。
附录 标准化考试系统部分源代码
ClientTestArea.java
import java.awt.*;
import javax.swing.*;
import java.awt.event.*;
import java.io.*;
import .*;
import java.util.StringTokenizer;
public class ClientTestArea extends JFrame implements ActionListener,ItemListener,Runnable
{
Socket sock=null;
DataInputStream in=null;
DataOutputStream out=null;
Thread thread1=null;
JButton shiti;
JComboBox li;
JLabel label1;
JTextField fenshu;
JButton chakan;
JLabel tm;
JTextField timeShow;
JCheckBox box[];
JPanel panel1,panel2,panel3,panel4;
long time1=0;
Timer T;
JButton duqu,tijiao;
JScrollPane panel5;
JTextArea text;
JSplitPane sp1,sp2,sp3,sp4;
JLabel beijing;
Toolkit tool;
Image img,img1,img2,img3;
Dimension dim;
boolean 完成考试=false;
boolean success=false;
// boolean isSelected=true;
JButton kaishi,chengji,tuichu;
ChaChengji cj;
String slb="",szx="",slz="";
ClientTestArea()
{
super("学生考试主界面");
setLayout(null);
tool=getToolkit();
img=tool.getImage("images/zhu.png");
img1=tool.getImage("images/kaishi1.png");
img2=tool.getImage("images/chengji1.png");
img3=tool.getImage("images/tuichu1.png");
dim=tool.getScreenSize();
//加入三个按钮
kaishi=new JButton(new ImageIcon(img1));
chengji=new JButton(new ImageIcon(img2));
tuichu=new JButton(new ImageIcon(img3));
kaishi.addActionListener(this);
chengji.addActionListener(this);
tuichu.addActionListener(this);
kaishi.addMouseListener(new MouseAdapter()
{
public void mouseEntered(MouseEvent e)
{
kaishi.setIcon(new ImageIcon(tool.getImage("images/kaishi.png")));
}
public void mouseExited(MouseEvent e)
{
kaishi.setIcon(new ImageIcon(img1));
}
});
chengji.addMouseListener(new MouseAdapter()
{
public void mouseEntered(MouseEvent e)
{
chengji.setIcon(new ImageIcon(tool.getImage("images/chengji.png")));
}
public void mouseExited(MouseEvent e)
{chengji.setIcon(new ImageIcon(img2)); }});
tuichu.addMouseListener(new MouseAdapter()
{ public void mouseEntered(MouseEvent e)
{tuichu.setIcon(new ImageIcon(tool.getImage("images/tuichu.png"))); }
public void mouseExited(MouseEvent e)
{tuichu.setIcon(new ImageIcon(img3)); }});
add(kaishi);
add(chengji);
add(tuichu);
kaishi.setBounds(151,70,80,30);
chengji.setBounds(285,40,80,30);
tuichu.setBounds(407,60,80,30);
//试卷选择区
shiti=new JButton("加入试题到列表");
shiti.addActionListener(this);
li=new JComboBox();
li.addItemListener(this);
panel1=new JPanel();
panel1.setLayout(null);
panel1.add(shiti);
panel1.add(li);
shiti.setBounds(30,20,130,30);
li.setBounds(40,60,100,25);
panel1.setBorder(BorderFactory.createTitledBorder("试卷选择区"));
//查看分数
label1=new JLabel("你的分数:");
fenshu=new JTextField(12);
chakan=new JButton("查看分数");
chakan.addActionListener(this);
panel2=new JPanel();
panel2.setLayout(null);
panel2.add(label1);
panel2.add(fenshu);
panel2.add(chakan);
label1.setBounds(10,20,80,25);
fenshu.setBounds(85,20,80,25);
fenshu.setEditable(false);
chakan.setBounds(40,55,100,30);
panel2.setBorder(BorderFactory.createTitledBorder("查看分数"));
//计时器
T=new Timer(1000,this);
tm=new JLabel("剩余时间:");
timeShow=new JTextField(12);
timeShow.setHorizontalAlignment(SwingConstants.RIGHT);
timeShow.setEditable(false);
panel3=new JPanel();
panel3.setLayout(null);
panel3.add(tm);
panel3.add(timeShow);
tm.setBounds(10,30,80,25);
timeShow.setBounds(80,30,80,25);
panel3.setBorder(BorderFactory.createTitledBorder("计时器"));
//操作区
String s1[]={" A "," B "," C "," D "};
box=new JCheckBox[4];
for(int i=0;i<4;i++)
{ box[i]=new JCheckBox(s1[i]);}
duqu=new JButton("读取第一题");
tijiao=new JButton("提交");
tijiao.addActionListener(this);
duqu.addActionListener(this);
tijiao.setEnabled(false);
duqu.setEnabled(false);
JLabel xz;
xz=new JLabel("选择答案:");
panel4=new JPanel();
panel4.setLayout(null);
panel4.add(xz);
panel4.add(box[0]);
panel4.add(box[1]);
panel4.add(box[2]);
panel4.add(box[3]);
panel4.add(tijiao);
panel4.add(duqu);
xz.setBounds(50,30,80,30);
box[0].setBounds(120,30,40,30);
box[1].setBounds(170,30,40,30);
box[2].setBounds(220,30,40,30);
box[3].setBounds(270,30,40,30);
tijiao.setBounds(350,30,60,30);
duqu.setBounds(450,30,100,30);
panel4.setBorder(BorderFactory.createTitledBorder("操作区"));
//试题显示区
text=new JTextArea(20,10);
text.setLineWrap(true);
text.setWrapStyleWord(true);
text.setFont(new Font("TimesRoman",Font.PLAIN,14));
text.setForeground(Color.blue);
text.setEditable(false);
panel5=new JScrollPane(text);
panel5.setBorder(BorderFactory.createTitledBorder("试题显示区"));
//把几个面板加到JSplitPane中
sp1=new JSplitPane(JSplitPane.VERTICAL_SPLIT,true,panel1,panel2);
sp1.setDividerLocation(100);
sp2=new JSplitPane(JSplitPane.VERTICAL_SPLIT,true,sp1,panel3);
sp2.setDividerLocation(210);
sp3=new JSplitPane(JSplitPane.HORIZONTAL_SPLIT,true,panel5,sp2);
sp3.setDividerLocation(400);
sp4=new JSplitPane(JSplitPane.VERTICAL_SPLIT,true,sp3,panel4);
sp4.setDividerLocation(300);
add(sp4);
sp4.setBounds(0,150,600,400);
beijing=new JLabel(new ImageIcon(img));
add(beijing);
beijing.setBounds(0,0,600,500);
thread1=new Thread(this);
addWindowListener(new WindowAdapter()
{ public void windowClosing(WindowEvent e)
{ System.exit(0); } });
setBounds(dim.width/2-300,dim.height/2-250,600,570);
//setResizable(false);
setVisible(true);
validate(); }
public void setSocketConnection(Socket sock,DataInputStream in,DataOutputStream out)
{ this.sock=sock;
this.in=in;
this.out=out;
try{ thread1.start(); }
catch(Exception e)
{//b=false;}}
public void actionPerformed(ActionEvent e)
{…… }
public void itemStateChanged(ItemEvent e)
{ int n=li.getItemCount();
if(n>=1)
{String listItem=(String)li.getSelectedItem();
try{out.writeUTF("试卷的名字:"+listItem);}
catch(IOException ee){}
success=true;}}
public void run()
{ String s=null;
li.removeAll();
while(true)
{
try{ s=in.readUTF();
…… }
catch(Exception ee){}
展开阅读全文