收藏 分享(赏)

在线答疑系统.docx

上传人:wo7103235 文档编号:6152621 上传时间:2019-03-30 格式:DOCX 页数:64 大小:7.43MB
下载 相关 举报
在线答疑系统.docx_第1页
第1页 / 共64页
在线答疑系统.docx_第2页
第2页 / 共64页
在线答疑系统.docx_第3页
第3页 / 共64页
在线答疑系统.docx_第4页
第4页 / 共64页
在线答疑系统.docx_第5页
第5页 / 共64页
点击查看更多>>
资源描述

1、湖 南 科 技 大 学毕 业 设 计( 论 文 )题目 在线答疑系统作者学院 数学与计算科学专业 信息与计算科学学号指导教师年 月 日摘 要随着信息技术的飞速发展,网络已经越来越普及,如今利用网络进行各种教学活动已成为现实。在线答疑系统利用网络来开展答疑工作,它可以突破时间和空间的限制,提高答疑工作的便捷性和及时性,增加师生之间和学生之间的互动。这对现今高校的教学方法、教学模式的改革具有重要意义。本在线答疑系统是利用 Java Web 技术开发的,采用了目前流行的 B/S 体系结构,选用 MySQL5.0 作为后台数据库,Tomcat6.0 作为服务器。本系统集成了 Struts2 和Spri

2、ng 两个开源框架,将 Struts2 的 Action 作为 Spring 当中的受管 Bean。通过依赖注入,Action 能够非常方便地获得实现业务功能的受管 Bean 的引用。本系统主要实现了如下三方面的功能。学生登录和注册及修改资料,搜索课程和申请课程,提出问题和参与讨论,查看自己的课程和提问,查看申请处理情况;老师登录和注册及修改资料,回答问题和处理申请,添加学生和删除学生,查看老师的课程;管理员的课程管理,提问和回复管理,学生和教师用户的管理,管理员用户管理。关键词:B/S;Java Web;在线答疑系统ABSTRACTWith the rapid development of

3、information technology, networking has become increasingly popular. At present, using network to teach in various teaching activities has become a reality. Online question-answering system takes advantage of the network to implement the answering work, which breaks the limitations of time and space,

4、 conveniently and timely improves answering work, and increases the frequency of interactions among teachers and students. It is of great significance to the reform of teaching methods and teaching models in colleges and universities.Online question-answering system is developed by Java Web technolo

5、gy, adopted the prevalent B/S structure, used MySQL5.0 as the background database and employed Tomcat6.0 as the server. The system integrated two open source frameworks of Struts2 and Spring, and used the Struts2 Action as a managed Bean in Spring. Through dependency injection, Action can easily get

6、 references of the managed Bean that implements business function .The system realized the functions as follows. Students can login, register and modify their information, search and apply for courses, ask questions and participate in discussions, check their courses and questions, check applying pr

7、ocesses; Teachers also can login and register and modify their information, answer questions and process applications, add and delete student, and check their courses; Administrators can manage courses, questions, answers, student users, teacher users and administrator users.Keywords: B/S; Java Web;

8、online question-answering system湖南科技大学本科生毕业设计(论文)-i-目 录第一章 前言 .- 1 -1.1 课题研究背景及意义 - 1 -1.1.1 研究背景 .- 1 -1.1.2 研究意义 .- 1 -1.2 国内外现状 .- 1 -第二章 系统分析 .- 3 -2.1 可行性分析 .- 3 -2.1.1 技术可行性分析 - 3 -2.1.2 经济可行性分析 - 3 -2.1.3 操作可行性分析 - 3 -2.2 需求分析 .- 4 -2.2.1 功能性需求分析 - 4 -2.2.2 非功能性需求分析 - 5 -2.2.3 系统流程图 .- 5 -2.2

9、.4 系统数据流图 - 7 -第三章 系统总体设计 .- 9 -3.1 项目规划 .- 9 -3.2 系统总体结构 .- 9 -3.3 系统功能模块 .- 10 -3.3.1 学生模块功能定义 - 10 -3.3.2 教师模块功能定义 - 10 -3.3.3 管理员功能模块定义 .- 11 -第四章 数据库设计 - 13 -4.1 数据库分析 .- 13 -4.2 项目 E-R 图 .- 13 -4.3 数据库表的设计 - 16 -湖南科技大学本科生毕业设计(论文)-ii-第五章 系统详细设计与实现 - 19 -5.1 界面设计 .- 19 -5.2 系统分层的实现 - 19 -5.2.1 表

10、示层的设计 - 20 -5.2.2 控制层的设计 - 20 -5.3 数据库连接与操作的实现 .- 20 -5.3.1 数据源的配置 - 20 -5.3.2 数据库操作的实现 - 21 -5.4 各个功能模块的设计与实现 - 21 -5.4.1 用户登录和注册 - 21 -5.4.2 学生用户模块 - 23 -5.4.3 教师用户模块 - 29 -5.4.4 管理员模块 .- 32 -第六章 系统测试 .- 37 -6.1 测试目的 .- 37 -6.2 系统关键部分测试分析 .- 37 -6.2.1 注册用户名唯一性验证 .- 37 -6.2.2 分页的实现 .- 38 -6.2.3 利用拦

11、截器实现权限控制 - 38 -第七章 结论 .- 41 -7.1 系统功能总结 .- 41 -7.2 系统的特色之处 - 41 -7.3 系统中仍然存在的问题 .- 41 -7.4 体会与总结 .- 42 -参考文献 .- 43 -致谢 - 45 -附录 - 47 -湖南科技大学本科生毕业设计(论文)- 1 -第一章 前 言1.1 课题研究背景及意义1.1.1 研究背景随着网络技术的快速发展,网络已然与人们生活的方方面面融为了一体。学校计算机网络经过 10 多年的建设,目前,国内大多数高校学生使用校园网已经十分方便。如何有效地使用网络服务于管理,教学,学习,已成为一个重要的课题,非常值得我们关

12、注和研究。答疑是教学活动中一个必要的步骤,主要的工作是解决学生在学习过程中所碰到的难题。答疑工作是否开展的好对教育质量有着直接的影响。高校招生规模的不断扩大,师生人数的倍增,加之上课地点的变动等原因,使传统的答疑方式无法满足现今的答疑需求,答疑方式亟待改进。因此,使用 Java Web 技术开发一个实用的网上答疑系统不仅能够最大化地利用现今教育资源,并且是更好地为学生提供服务的最佳方式。为此,我选择了利用 Java Web 等技术开发在线答疑系统,它可以提高答疑工作的便捷性和及时性,通过计算机网络实现老师与学生之间的交互。1.1.2 研究意义随着网络技术的飞速发展,教学管理网络化已经成为当前教

13、育的一个基本特征,网络教育作为一种新的教学方法,已经走进我们的生活,并且被我们所接受,这对传统教育来说,是一个很好的补充。随着广泛应用的互联网技术的发展,通过互联网进行各种不同的教学活动已经成为现实。在线答疑系统利用校园网来开展答疑工作,主要体现在学生和教师之间“问”与“答”的双向互动,学生依据自己的学习情况利用校园网向教师提出种种疑问,教师通过校园网解答学生遇到的难题,系统在展现个性化学习的同时,也展现了个性化辅导,学生和教师可以冲破存在于时间和空间上的限制性,通过连接上校园网的计算机就能够开展答疑工作。在大学校园里,学生如果能充分利用校园网,针对自身存在的问题及时向教师寻求帮助,以获得所提

14、问题的答案,并能表达自己的观点,彼此间进行自由讨论交流,这必将拉近师生之间的距离,提高答疑工作的效率,增强学校的学习氛围。这对于现今高校的教育形式和教学方式的变革具有非常重大的意义。湖南科技大学本科生毕业设计(论文)- 2 -1.2 国内外现状当前能够实现在线答疑功能的技术有很多种,例如 CGI、PHP、JSP、ASP 和ASP.NET 等,而且主要有 C/S 架构和 B/S 架构,但 C/S 架构受到平台和硬件的限制,不如 B/S 架构方便和大众化。通过对国内不少已经投入使用的高等教育远程教育系统的研究可以发现,在这些系统中,答疑功能有的被放在一个非常次要的位置,有的甚至干脆被忽略。当前,国

15、内的网上答疑系统大多是作为一个包含在教育网站中的子系统而存在,而专门用于进行答疑的独立平台则少之又少。从功能的角度来看,国内的网上答疑系统的功能不仅比较全面而且较丰富,主要含用户信息的管理、问题的查询和统计、答疑、知识管理以及浏览等功能。此外,另有不少答疑系统为了进一步增强其系统的特色而提供了一些额外的功能,如:用户的个性化定制等。在国内,主要是通过人工答疑方式和基于数据库的自动答疑方式来实现答疑系统的功能;从系统的智能化来看,国内的很多答疑系统在提高关键词的匹配上存在较大困难。对于大多数问题和答案的智能管理都不是太完善。而且智能分析、统计功能薄弱,无法根据学生所提出的问题对老师的教学提出建议

16、。在国外,现在有相当多的杰出并且智能化的专门的答疑系统。其从功能的角度看来尽管相对简洁,然而它们全部的功能都是紧紧围绕着答疑这个核心功能来展开设计的,重心明确并且突出;在问题的展现方面,系统将有关人物、地点和时间概念等多种类型的问题作为基本点,为用户提供正确性和简洁性都比较高的答案。湖南科技大学本科生毕业设计(论文)- 3 -第二章 系统分析2.1 可行性分析2.1.1 技术可行性分析技术可行性不仅要考虑使用现有的技术可否完成系统的开发,而且还要考虑软件和硬件的配置可否能够满足开发的需要等。本系统的开发是一个较具代表性的 Java Web 项目,采用 Java 程序语言,如今计算机硬件的配置已

17、经完全可以满足开发过程的需求。从软件方面来看,系统使用 Java Web 技术进行开发,前端界面使用的是 DIV+CSS 技术,所需的软件环境如下:JDK、MyEclipse、Web 应用服务器以及 MySQL 数据库。这些软件都已经有了功能全面、稳定的版本,故软件的开发平台成熟可行,它们不仅可靠性高而且稳定,因此完全可以满足系统的需求。2.1.2 经济可行性分析系统所需要的硬件环境,即计算机及其相关的硬件,从市场上可以很容易地购买到。所需软件环境(JDK+MyEclipse+Tomcat+MySQL)可以从网上免费下载,从而降低了开发成本。本系统主要的开发与维护成本也不会造成太大的经济压力。

18、此系统正式投入使用后,学校的教学质量能够得到大幅度的提高,答疑工作也能更顺利的开展,并且师生之间的在线互动也可以更加方便地进行。同时对于学校学生来说,有问题可以立即登入系统进行提问,只要是该课程下的学生用户都可以参与讨论。对于教师来说,能够很方便地查看学生提出的问题并回答,了解学生对知识的掌握程度,从而把握教学重点,这样学校的教学质量便得到了提高。2.1.3 操作可行性分析本系统主要是为了方便教师与学生之间的答疑工作的开展,提高学生的学习效率。可行性分析(Feasibility Analysis),即可行性研究,它是针对新系统的开发是不是具备必可能性和必要性并基于对系统的调查,对新系统的开发从

19、技术、社会和经济等方面开展分析和研究工作,以避免投资失误,从而保障新系统的开发成功。可行性研究的目标是用最小的代价在尽量短的时间内确定问题是否可以得到解决。其实质上是要进行一次大大压缩简化了的系统分析和设计过程,即以较抽象的方式在较高层次上进行的系统分析和设计的过程。湖南科技大学本科生毕业设计(论文)- 4 -学生将所学习课程的疑问通过系统呈现给教师,待教师解答后,可查看到问题回复。系统界面简洁美观,用户一目了然,只要学生、教师和管理员通过网上浏览就可以自如地使用本系统。因此,用户操作起来会得心应手。2.2 需求分析在开发任何一个系统之前,进行必需的系统分析是非常有必要的,主要是根据对客户的需

20、求和本系统的一些特点和模块的分析等来确定如何有效地进行实际的开发。需求分析是软件设计的一个重要组成部分。为了确定系统的目标,应在本阶段对系统的应用情况进行全面的调查。2.2.1 功能性需求分析本系统包含学生、教师和后台管理员这 3 类用户,其各用户的具体功能如下。 学生用户功能 注册和登录,学生不仅可以很方便地进行用户注册,也能够登录在线答疑系统。 资料的修改,注册后学生可以修改自己的注册资料。 查看提问,学生发起问题后,可以查看该问题的回复情况。 申请课程,如果学生还不能修某课程,可提交该课程的申请表。 查询课程,搜索自己感兴趣的课程,支持模糊检索。 查看参与的提问,学生不仅可以对自己参与课

21、程下的问题进行讨论,而且还可以 查看这些问题。 教师用户功能 用户的登录,老师可自由地登录在线答疑系统。 资料的修改,老师可以修改自己的资料。 查看未回答的提问,老师登录后,可以查看待回答问题的列表。 查看已回答的提问,对于已经回答的问题,老师不仅可查看,而且还可以继续回 复讲解。 添加学生,老师能够将学生添加到自己所教授的某门课程。 删除学生,老师能够删除自己所教课程下的学生。 管理员功能 课程管理,管理员可以对课程信息进行维护。 内容管理,管理员可以对提问内容和回复内容进行管理。 用户管理,管理员可以对学生用户和老师用户进行管理。湖南科技大学本科生毕业设计(论文)- 5 - 管理员管理,主

22、要是超级管理员对普通管理员的管理。 2.2.2 非功能性需求分析(1)系统安全性需求在软件使用方面,学生用户和教师用户通过系统主界面登录进入系统,但必须通过必要的身份验证。管理员则通过专门的登录页面来进入系统,一旦管理员登录成功就可以对系统进行常规管理。用户登录的角色不同,从系统获得的操作权限也不同。(2)系统开发运行环境需求 JDK:作为整个 Java 的核心包含了 Java 的基础类库、运行环境和 Java 工 具,是 Java 语言的软件开发工具包。 MyEclipse:是一个非常杰出的 Java 开发工具,对各种开源产品的支持非常好。它不仅功能非常强大,而且具备非常广泛的支持性能。 T

23、omcat 服务器:适用于中小型系统开发的 web 应用服务器,开放源代码且免费。其性能稳定、技术先进,因此不但博得了 Java 开发人员的喜爱,而且也得到了 一些软件开发商的肯定,是当今较流行的 Web 应用服务器。 MySQL 数据库:是目前小型应用开发中比较流行的数据库,且从 MySQL5.0 版本开始支持事务,保证了数据库的完整性和安全性。 2.2.3 系统流程图用户进入系统主界面后,会显示所有课程列表,成功登录后才能查看课程的提问以及进行其它操作。如果是学生用户,则可以查看个人资料、自己的课程、提问、参与的问题和申请处理情况,还可以进行课程的申请,修改资料和登录密码。如果是老师用户,

24、则可以查看个人资料、自己的课程和申请列表,并能对学生进行管理(添加或删除学生) ,修改资料和登录密码,系统会提示老师未回答问题和未处理申请的个数。管理员经由后台登录界面进入系统,成功地登录以后,系统会根据管理员角色(超级管理员和普通管理员)的不同来显示相应的操作权限列表。管理员能够对课程、提问和回复、学生和老师用户以及管理员用户进行管理。本系统的流程图如下页图 2.1 所示。湖南科技大学本科生毕业设计(论文)- 6 -湖南科技大学本科生毕业设计(论文)- 7 -在线答疑系统系统首页 后台登录界面用户登录 否 否 用户登录 登录成功? 登录成功?是 是 老师用户 学生用户 管理员 图 2.1 系

25、统流程图修改资料回答问题和处理申请添加和删除学生 查看老师的课程课程管理提问和回复管理学生和老师用户的管理管理员用户的管理修改资料搜索课程和申请课程 提出问题和参与讨论 查看自己的课程和提问查看申请处理情况湖南科技大学本科生毕业设计(论文)- 8 -2.2.4 系统数据流图本系统数据流的设计主要包括在线答疑信息管理、课程管理和用户管理等的实现,其相应的数据流图分别如下图 2.2 所示。图 2.2 系统顶层数据流图管理员管理部分主要实现了课程管理、提问和回复管理以及学生和老师用户管理,其数据流图如图 2.3 所示。图 2.3 第一层数据流图管理员管理湖南科技大学本科生毕业设计(论文)- 9 -教

26、师管理部分主要实现了学生管理、回答问题、处理申请以及查看课程信息,其数据流图如图 2.4 所示。图 2.4 第一层数据流图教师管理学生管理部分主要实现了搜索课程和申请课程、提出问题和参与讨论、查看自己的课程和提问以及产看申请处理情况,其数据流图如图 2.5 所示。图 2.5 第一层数据流图学生管理湖南科技大学本科生毕业设计(论文)- 10 -第 3 章 系统总体设计3.1 项目规划总体规划:在线答疑系统是一个非常典型的 Java Web 项目,它由系统前台展示模块和后台数据管理模块等两大模块构成。前台展示模块主要提供身份登录验证,提出问题与回复、参与讨论,查看课程和提问,申请课程和处理申请、修

27、改资料以及添加/删除学生等功能模块。后台管理模块:该模块主要进行数据库的管理和维护,包含对学生和教师用户的管理、课程的管理、提问和回复的管理、管理员用户的管理等。3.2 系统总体结构系统总体结构是系统总体设计的核心部分,通过系统结构图可以很清楚地看出整个系统的结构。根据各个结构模块分别进行分析,从而为将来的设计和实现打下良好的基础。根据前面对系统所做出的分析,本系统总体上包括 3 类用户,即学生用户、老师用户和后台管理员用户。系统总体结构如图 3.1 所示。图 3.1 系统结构图总体设计,也可以称为概要设计或者初步设计,其基本目的便是回答“概括地说,应当如何实现系统”这个问题。经过这个阶段,将

28、划分出构成系统的物理元素(数据库、程序、文件、文档和人工过程等) ,然而所有的物理元素依旧处于黑盒子级,这些黑盒子里的具体内容将在之后进行详细的设计。总体设计阶段的另外一项重要任务是确定系统中的每一个程序由哪些模块构成以及这些模块相互之间的关系,即设计软件的结构。湖南科技大学本科生毕业设计(论文)- 11 -3.3 系统功能模块 在线答疑系统依据用户的类别共分成三个模块:学生模块、教师模块和管理员模块。3.3.1 学生模块功能定义 表 3.1 学生模块功能列表功能名称 定义学生注册 用于注册学生信息学生登录 用于学生登录系统的身份验证修改资料 用于学生修改个人资料搜索课程 用于学生搜索所有可提

29、问的课程申请课程 用于学生申请感兴趣的课程提问问题 用于学生提出对课程内出现的疑问参与讨论 用户学生之间针对问题进行交流讨论我的提问 用于学生查看自己所提出问题的回复情况我的课程 用于学生查看自己已经申请的课程我的申请 用于学生查看自己的申请处理情况退出 学生退出系统登录3.3.2 教师模块功能定义表 3.2 教师模块功能列表功能名称 定义教师注册 用于注册教师信息教师登录 用于教师登录系统的身份验证修改资料 用于教师修改个人资料回答问题 用于教师回答学生所提出的问题申请处理 用于教师处理学生的课程申请添加学生 用于教师为自己的课程添加学生删除学生 用于教师删除自己课程下的学生查看课程 用于教

30、师查看自己的课程湖南科技大学本科生毕业设计(论文)- 12 -退出 教师退出系统登录3.3.3 管理员功能模块定义表 3.3 管理员模块功能列表功能名称 定义管理员登录 用于管理员登录系统的身份验证课程管理 用于对课程信息进行添加、修改和删除提问管理 用于问题信息的维护,对过时答疑信息的删除回复管理 用于回复信息的维护,对不良回复信息的删除学生管理 用于对学生用户的信息进行修改和删除教师管理 用于教师用户信息的修改和删除管理员管理 用于管理用户信息的修改、添加和删除退出 管理员退出系统登录湖南科技大学本科生毕业设计(论文)- 13 -湖南科技大学本科生毕业设计(论文)- 14 -第四章 数据库

31、设计4.1 数据库分析由于本系统的规模不是很大,因此选用 MySQL 数据库,该数据库为开源免费产品,可以直接通过网上下载得到,从而大大节约了开发成本。MySQL 数据库是现今小型应用开发中比较流行的数据库,且从其 5.0 版本开始支持事务,能够确保数据的完整性和安全性。4.2 项目 E-R 图在线答疑系统作为学生和老师之间针对于学生所提出的问题进行沟通和交流的桥梁,所包含的实体有提问信息、回答信息、课程、用户、申请信息和关系。下面将依次介绍各个实体所对应的 E-R 图。 用户的 E-R 图主要包括用户的编号、用户名、密码和电子邮件等信息,具体如图 4.1所示。图 4.1 用户 E-R 图数据

32、库技术是管理信息资源的最佳方式。数据库设计是针对一个特定的应用环境构造出最优的数据库模式来创建数据库及其应用系统,从而实现对数据的有效存储,以满足用户对信息和处理的要求。数据库结构的设计将直接影响到应用系统的效率和实现的效果。因此,合理的数据库设计不但能够提升数据存储的效率,而且可以有效的确保数据的完整性和一致性。确定了系统需要开发的功能之后,接下来应该进行数据库的设计工作,分析该系统的各个实体之间的关系,做好数据库的设计对后期的开发有着非常重要的作用。湖南科技大学本科生毕业设计(论文)- 15 - 课程实体包含课程名、课程编号和课程描述,具体如下图 4.2 所示。图 4.2 课程 E-R 图

33、 提问信息实体主要包括提问的编号、提问用户的 ID、提问标题等信息,具体如图 4.3所示。图 4.3 提问信息 E-R 图 回复信息实体主要包括所回复问题的编号、回复标题和内容等信息,其 E-R 图如图4.4 所示。图 4.4 回复信息 E-R 图 申请信息实体主要包含申请人编号、所申请课程编号、是否处理以及申请理由等的湖南科技大学本科生毕业设计(论文)- 16 -一些标志信息,其 E-R 图如图 4.5 所示。图 4.5 申请信息 E-R 图 学生和课程之间存在学习的关系,该关系记录了学生的 ID 和课程的 ID 信息,具体如图 4.6 所示。图 4.6 关系信息 E-R 图 实体之间存在着

34、一定的关系,如一个老师能教授多门课程,并且一门课程也能被多个学生学习,具体关系如图 4.7 所示。湖南科技大学本科生毕业设计(论文)- 17 -4.3 数据库表的设计系统数据库设计的好坏不仅对今后网站连接数据库的速度有着非常重要的影响,而且也对查询更新的复杂度有着非常重要的影响。本节介绍对本系统的数据库表进行的设计,是在完成系统功能分析的基础上根据系统的需求目标而进行的设计。根据前面所介绍的实体所拥有的属性以及实体之间的关系描述,下面将介绍数据库中这些实体对应的表的设计,分别是课程表、提问表、回复表、用户表、申请表和关系表,具体设计如下所示。(1)用户表:主要包含用户名、用户 ID、登录密码、

35、电子邮件和其它相关信息,表中各字段的详细信息如下表 4.1 所示。表 4.1 用户信息表 DY_User字段名称 数据类型 字段大小 是否主/外键 字段说明 备注UID int N/A 主键 用户编号 非空UName varchar 20 否 用户名 唯一且非空UPwd varchar 20 否 登录密码 非空UGender char 2 否 用户性别 无UEmail varchar 40 否 电子邮件 无URole int N/A 否 用户角色 默认值UHead varchar 50 否 图像 URL 默认值URegDate date N/A 否 注册日期 无ULastLogin datet

36、ime N/A 否 最后登录时间 无ULastEmit datetime N/A 否 最后发表时间 无UPermit int N/A 否 用户权限 默认值(2)课程信息表:包含课程名、课程 ID 以及课程描述信息,表中各字段的详细信息如下表 4.2 所示。表 4.2 课程信息表 DY_Topic_Group字段名称 数据类型 字段大小 是否主/外键 字段说明 备注TGID int N/A 主键 课程编号 非空TGName varchar 50 否 课程名 非空TDetail varchar 200 否 课程描述 非空湖南科技大学本科生毕业设计(论文)- 18 -(3)提问信息表:该表主要包括提

37、问标题、内容和所属课程等提问信息,表中各字段的详细信息如下表 4.3 所示。表 4.3 提问信息表 DY_Topic字段名称 数据类型 字段大小 是否主/外键 字段说明 备注TID int N/A 主键 提问编号 非空UID int N/A 外键 提问人 ID 无TGID int N/A 外键 所属课程 ID 无TTitle varchar 200 否 提问标题 非空TContent text N/A 否 提问内容 非空TDate datetime N/A 否 提问时间 非空TReadCount int N/A 否 阅读次数 默认值(4)回复信息表:该表主要包含所回复问题 ID、回复标题、回复

38、 ID 以及回复内容等信息,各字段的详细信息如下表 4.4 所示。表 4.4 回复信息表 DY_Revert字段名称 数据类型 字段大小 是否主/外键 字段说明 备注RID int N/A 主键 回复编号 非空TID int N/A 外键 所回复提问 ID 无UID int N/A 外键 回复人 ID 无RTitle varchar 200 否 回复标题 无RContent text N/A 否 回复内容 非空RDate datetime N/A 否 回复时间 非空(5)申请信息表:该表主要包含申请编号、申请人编号和所申请课程编号等,表中各字段的详细信息如下表 4.5 所示。表 4.5 申请信

39、息表 DY_Apply字段名称 数据类型 字段大小 是否主/外键 字段说明 备注AID int N/A 主键 申请编号 非空UID int N/A 外键 申请人 ID 无TGID int N/A 外键 所申请课程 ID 无AReason varchar 200 否 申请理由 非空AFlag int N/A 否 申请处理标志 默认值AStatus char 10 否 申请处理状态 默认值湖南科技大学本科生毕业设计(论文)- 19 -(6)用户-课程关系表:用于记录存在于用户和课程之间的关系,包含用户编号、课程编号和关系编号等信息,表中各字段的详细信息如下表 4.6 所示。表 4.6 用户-课程关

40、系表 DY_TU字段名称 数据类型 字段大小 是否主/外键 字段说明 备注TUID int N/A 主键 关系 ID 非空UID int N/A 外键 用户 ID 无TGID int N/A 外键 课程 ID 无湖南科技大学本科生毕业设计(论文)- 20 -第五章 系统详细设计与实现通过这一阶段的工作进行了详细的设计,我们将会确切地描述所要开发的目标系统,其基本任务是要确定能够具体地实现所要求的系统的方法途径。5.1 界面设计对于任何系统来讲,设计用户界面都是相当重要的。因为一个交互良好的界面不仅可以使浏览者对系统的印象更深刻,而且可以为与客户进行沟通提供方便。本系统的界面使用 JSP 页面来

41、实现,并采用 DIV+CSS 技术对界面进行美化。在页面的实现过程中,主要遵循了以下两个原则:(1)统一连贯。页面的整体风格要与自己所要表达的内容相符,本系统是在线答疑系统,采用草绿色为界面的颜色基调,能凸显学生的活力和知识学习生机勃勃的景象。(2)布局合理、和谐。整个页面要符合大众人群的审美观念。布局是一个页面显示的主体框架,一个设计良好的布局,能给用户很好的使用效果和深刻的浏览记忆。本系统的主界面如下图 5.1 所示。图 5.1 系统主界面5.2 系统分层的实现根据 MVC 设计思想,本系统以 Struts2 框架为控制器,用来管理各页面传过来的湖南科技大学本科生毕业设计(论文)- 21

42、-请求,从而发给相应的 action 处理;各 JSP 页面作为动态页面表示层来进行显示;DBUtil 和各个 Action 等均作为 Spring 当中的受管 Bean。5.2.1 表示层的设计JSP 技术能够将普通静态的 HTML 技术和动态的 HTML 技术相结合起来进行编码。它具有运行效率高、跨平台性等优点。根据系统的分层情况,表示层选用的是 JSP 动态页面技术。 5.2.2 控制层的设计控制层的采用的是 Struts2 框架。因为能够使用 Struts2 的控件上传文件,并且其拦截器机制也能够对特定信息进行拦截。该系统中 Struts2 的工作原理体现如下:当用户从前台 JSP 页

43、面选择操作后,通过 Struts2 控制器转发给相应的 action 进行处理,各 action 通过 Spring 的依赖注入的 DBUtil 来实现对数据库的各项操作,最后将得到的数据传到 JSP 页面进行显示。本系统在项目结构中 WEB-INF 文件夹下的 web.xml文件中对 Struts2 进行的配置如下:5.3 数据库连接与操作的实现5.3.1 数据源的配置 由于系统采用数据库连接池技术访问数据库,所以在连接数据库之前要对数据源进行配置,本系统在项目结构中 WEB-INF 文件夹下的 web.xml 文件中对其进行的配置如下:struts2org.apache.struts2.d

44、ispatcher.FilterDispatcherstruts2/*DB Connectionjdbc/zxdyjavax.sql.DataSourceContainer湖南科技大学本科生毕业设计(论文)- 22 -5.3.2 数据库操作的实现本项目中的 DBUtil 类包含全部要用到的数据库方法,需要将 DBUtil 类的资源注入到项目中开发的 Action,并将 Action 配置成为 Spring 框架中的受管 Bean。DBUtil类的具体实现代码见附录 1,其大致结构如下:5.4 各个功能模块的设计与实现根据系统分析和系统的总体设计,基本确定了该系统所包含的模块,下面具体介绍各个模

45、块的基本功能的设计与实现。5.4.1 用户登录和注册依据系统分析和功能的需求,用户在没有登录的情形下,除了对系统首页进行浏览外无法执行其它操作。只有在登陆成功的情况下,才能够发表疑问和回复并执行其它操作。学生和老师用户通过系统首页登录系统,而管理员则通过后台登录界面进入系统。在利用 Struts2 框架进行开发的过程中,有时一个动作要与一个 Action 对应,可是这些 Action 中有些属性或方法是通用的,倘若在每一个 Action 里面反复书写相同public class DBUtilprivate JdbcTemplate jt; /声明JdbcTemplate对象引用private

46、List rl = null; /声明List对象引用private String sql = null; /声明SQL字符串引用private DataSource ds; /声明DataSource引用private DataSourceTransactionManager dtm; /声明数据源事务管理类引用private DefaultTransactionDefinition dtd; /声明DefaultTransactionDefinition引用public void setJt(JdbcTemplate jt) /jt成员的setter方法this.jt = jt; /设置j

47、t属性的值public void setDs(DataSource ds)this.ds=ds;/对数据库进行操作的各个方法湖南科技大学本科生毕业设计(论文)- 23 -的属性或方法就会导致代码看起来不仅冗长并且枯燥。因此,首先要定义一个可以让之后的所有 Action 继承的一个包含通用属性和方法的基类 Action,即 BaseAction 类。其具体实现类是 DYBaseAction,DYBaseAction 类的主要源代码如下。(1)用户注册用户通过系统首页进入注册页面,注册页面如下图 5.2 所示。public class DYBaseAction extends ActionSupp

48、ortpublic String execute()throws ExceptionString result = SUCCESS;if(“logout“.equals(actionStr) String role = (String)getSession().get(“role“);getSession().clear();System.out.println(“role:=“+role);if(“0“.equals(role)|“1“.equals(role)url = “IndexAction.action“;message = “退出成功,现在将跳转到主页“; elseurl = “a

49、dminLogin.jsp“;message = “退出成功,现在将要跳转到登陆页“; result = LOGIN; return result;湖南科技大学本科生毕业设计(论文)- 24 -图 5.2 用户注册页面因为注册的用户有很多,本模块使用了 Ajax 技术,在客户端还未提交注册表之前可以对信息进行验证,倘若注册信息不符合要求则禁止提交,这样不但使得网络流量在很大程度上得到减少,而且也使得服务器的负担得到极大的减轻。采用 Ajax 技术向服务器发送异步请求,在创建好 XmlHttpRequest 对象后要获取用户注册时所填写的用户名,而后再把验证请求发送到服务器端,其相应的JavaScript 源代码见附录 2。(2)用户登录 学生和老师用户通过系统主页登录,如下图 5.3 所示。湖南科技大学本科生毕业设计(论文)- 25 -图 5.3 用户登录页面 管理员通过后台的登录页面进入系统。5.4.2 学生用户模块学生用户成功登录系统后,主页面显示了所有的课程列表,学生可以搜索课

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 学术论文 > 毕业论文

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报