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()连接服务器和数据库。 

基于Java标准化考试系统相关推荐

  1. 基于JAVA模拟考试系统计算机毕业设计源码+数据库+lw文档+系统+部署

    基于JAVA模拟考试系统计算机毕业设计源码+数据库+lw文档+系统+部署 基于JAVA模拟考试系统计算机毕业设计源码+数据库+lw文档+系统+部署 本源码技术栈: 项目架构:B/S架构 开发语言:Ja ...

  2. 如何做一个基于JAVA在线考试系统毕业设计毕设作品(springboot框架)

    分析架构 我们开发系统,常规有两个架构,一个BS架构(浏览器/服务器模式),一个CS(客户端/服务器端模式):基于JAVA的网站开发属于B/S架构(即浏览器和服务器架构模式),架构如图 分析系统功能 ...

  3. java评卷系统_GitHub - Ju5ticeGit/ExamSym: 基于java的考试及阅卷系统

    ExamSym 基于java的考试及阅卷系统 一个基于JAVA的考试及评卷系统 课程:Java程序语言设计(2020年春) 老师姓名:XX 学生姓名:XXX 学号:XXXXXXXXXXXXX 学院:X ...

  4. SSM毕设项目基于线上考试系统t90ic(java+VUE+Mybatis+Maven+Mysql)

    SSM毕设项目基于线上考试系统t90ic(java+VUE+Mybatis+Maven+Mysql) 项目运行 环境配置: Jdk1.8 + Tomcat8.5 + Mysql + HBuilderX ...

  5. java实现标准化考试系统详解(四)-----初始化操作实现

    (一)初始化操作实现 如上图所示当管理员需要更改适用工程.试题数量.考试时间时直接在文本中更改就好我们只需要每次在用户打开程序时初始化这些参数就可以 1.初始化试题模型,这里需要实现随机抽题,方法是用 ...

  6. JAVA语言考试系统的设计与实现(论文+源代码+文献综述+外文翻译+开题报告)

    毕业论文(设计)开题报告 论文题目: java考试系统 学生姓名: 年级(学号): 二级学院: 专业: 指导教师: 职称: 填表日期:20 年 月 日 学 院 教 务 处 制 一.选题依据(背景与意义 ...

  7. 基于Java毕业设计房屋租赁系统源码+系统+mysql+lw文档+部署软件

    基于Java毕业设计房屋租赁系统源码+系统+mysql+lw文档+部署软件 基于Java毕业设计房屋租赁系统源码+系统+mysql+lw文档+部署软件 本源码技术栈: 项目架构:B/S架构 开发语言: ...

  8. 基于JAVA汽车租赁系统计算机毕业设计源码+系统+lw文档+部署

    基于JAVA汽车租赁系统计算机毕业设计源码+系统+lw文档+部署 基于JAVA汽车租赁系统计算机毕业设计源码+系统+lw文档+部署 本源码技术栈: 项目架构:B/S架构 开发语言:Java语言 开发软 ...

  9. 基于JAVA汽车租赁系统计算机毕业设计源码+数据库+lw文档+系统+部署

    基于JAVA汽车租赁系统计算机毕业设计源码+数据库+lw文档+系统+部署 基于JAVA汽车租赁系统计算机毕业设计源码+数据库+lw文档+系统+部署 本源码技术栈: 项目架构:B/S架构 开发语言:Ja ...

最新文章

  1. 网站性能优化思维导图
  2. vc调试 main的参数
  3. 换种方法学操作系统,轻松入门Linux内核
  4. 计算机网络技术教法改革方案,计算机网络实验论文,关于“计算机网络”教学改革相关参考文献资料-免费论文范文...
  5. 【Java每日一题】20170309
  6. 【工作笔记】ElasticSearch —— 常用插件/工具汇总
  7. 史上最详细的IDEA优雅整合Maven+SSM框架(详细思路+附带源码)
  8. (12)FPGA面试技能提升篇(IUS、PT、Leda)
  9. oracle怎么恢复删除数据库数据库文件,Oracle只有数据文件恢复数据库
  10. Node:正则验证手机号和身份证号
  11. Web of science(WOS)引文跟踪
  12. 计算几何02_三次样条曲线
  13. c语言迷宫算法入门,基于C语言实现的迷宫算法示例
  14. java 解析umd文件_Webpack UMD:严重依赖...无法静态提取
  15. 「LOJ#10015」「一本通 1.2 练习 2」扩散(并查集
  16. Gym 101158G Placing Medals on a Binary Tree
  17. python序列的应用
  18. java杨辉三角奇数_杨辉三角中的奇数与偶数
  19. 洛谷-P2550-彩票摇奖
  20. 微信小程序云开发基础版也开始收费了

热门文章

  1. Genetic Fraud
  2. NYOJ 82 迷宫寻宝
  3. linux查看端口pvid,交换机端口及常见问题定位(二)
  4. 方维直播增加三级分销推广功能
  5. 【转载】浮华背后与我的路
  6. 女程序员在IT界的发展方向是什么?
  7. 如何在bat脚本中列出指定目录下的所有文件信息
  8. php保存文件快捷键,word保存快捷键是ctrl加什么
  9. WNDR4300刷OpenWrt手记
  10. 湖北智禾网店指导:入门卖家一定要了解的淘宝宝贝发布规则及注意事项。