姓 名: 学 号: 班 级: 院 系: 日 期: 任课教师:
引言
第一章系统概述
1。1 系统功能 1。2 技术背景
1。2。1 JSP 2 1.2.2 J2EE 1。2.3 MVC 1.3 开发工具介绍
1。3.1 Myeclipse定义及特征1.3。2 Apache Tomcat 6.0 1。3。3 MySQL数据库
第二章 需求分析
2.1功能需求
课程报告
目 录
1
图书馆管理系统 2。2 系统需求 2。3 维护需求
第三章 系统设计
3。1系统总体功能模块 3.2 系统功能模块设计
3。2.1公共模块设计 3.2。2管理员模块设计
3。2。2。1管理员登录模块 3.2。2。2管理员系统设置模块 3。2。2。3管理员读者管理模块 3.2.3图书管理模块设计 3.2.4图书借还模块设计
第四章 详细设计与实现
4.1数据库设计
4。1.1 数据表
4。1。2整个数据看关系图 4。1。3 E-R图
4.2用户界面的实现和功能代码的实现
第五章 开发遇到的困难与解决方案 第六章 总结体会 36
参考文献
37
引言
管理现代化,办公自动化和决策科学化,是现代化办公管理发展的必然趁势。图书管理比较烦琐,复杂,产生的文档比较多,并且由于手工的操作,使这些文档无法有效地核对和管理,在汇总以及分析方面更加困难。因此,迫切需要计算机技术来辅助管理。在使用图书管理系统后,可以提高图书的各类信息的准确性,将信息准确无误地输入计算机并在数据库中存储起来。按照规范设定标准代码,大大保证了统计原始数据的准确性,在进行分析设计时可以最大限度地减少人为影响,大大提高工作效率。图书管理系统可以集存储,分析,统计,打印一身,节省人力物力而且调用方便,统计快捷,准确性高可以充分发挥管理系统的统计分析功能。
因此,本系统开发的总体目标就是在图书馆信息管理中实现管理的系统化、自动化,减少工作量,增加效率及可靠性,将图书馆书库内杂乱无序的信息变为有序信息,并对图书的借阅和归还进行有序的管理。
当今时代是飞速发展的信息时代。在各行各业中离不开信息处理,这正是计算机被广泛应用于信息管理系统的环境。计算机的最大好处在于利用它能够进行信息管理。使用计算机进行信息控制,不仅提高了工作效率,而且大大的提高了其安全性,尤其对于复杂的信息管理,计算机能够充分发挥它的优越性。计算机进行信息管理与信息管理系统的开发密切相关,系统的开发是系统管理的前提。本系统就是为了管理好图书馆信息而设计的。
图书馆作为一种信息资源的集散地,图书和用户借阅资料繁多,包含很多的信息数据的管理,现今,有很多的图书馆都是初步开始使用,甚至尚未使用计算机进行信息管理。根据调
2
查得知,他们以前对信息管理的主要方式是基于文本、表格等纸介质的手工处理,对于图书借阅情况(如借书天数、超过限定借书时间的天数)的统计和核实等往往采用对借书卡的人工检查进行,对借阅者的借阅权限、以及借阅天数等用人工计算、手抄进行。数据信息处理工作量大,容易出错;由于数据繁多,容易丢失,且不易查找.总的来说,缺乏系统,规范的信息管理手段。尽管有的图书馆有计算机,但是尚未用于信息管理,没有发挥它的效力,资源闲置比较突出,这就是管理信息系统的开发的基本环境。
数据处理手工操作,工作量大,出错率高,出错后不易更改。图书馆采取手工方式对图书借阅情况进行人工管理,由于信息比较多,图书借阅信息的管理工作混乱而又复杂;一般借阅情况是记录在借书证上,图书的数目和内容记录在文件中,图书馆的工作人员和管理员也只是当时对它比较清楚,时间一长,如再要进行查询,就得在众多的资料中翻阅、查找了,造成查询费时、费力.如要对很长时间以前的图书进行更改就更加困难了.
基于这个问题,我认为有必要建立一个图书管理系统,使图书管理工作规范化,系统化,程序化,避免图书管理的随意性,提高信息处理的速度和准确性,能够及时、准确、有效的查询和修改图书情况。
第一章系统概述
1。1系统功能
本图书管理系统实现图书查询,图书借阅,管理员对图书的管理,对用户的管理。经过授权的用户可以通过Web浏览器,以人机交互式的客户端程序实现对图书的查询、图书的借阅、实时的进行行为统计和记录。
1。2技术背景
1。2。1 JSP
JSP技术使用Java编程语言编写类XML的tags和scriptlets,来封装产生动态网页的处理逻辑.网页还能通过tags和scriptlets访问存在于服务端的资源的应用逻辑。JSP将网页逻辑与网页设计和显示分离,支持可重用的基于组件的设计,使基于Web的应用程序的开发变得迅速和容易。
Web服务器在遇到访问JSP网页的请求时,首先执行其中的程序段,然后将执行结果连同JSP文件中的HTML代码一起返回给客户。插入的Java程序段可以操作数据库、重新定向网页等,以实现建立动态网页所需要的功能。
JSP与Java Servlet一样,是在服务器端执行的,通常返回该客户端的就是一个HTML文本,因此客户端只要有浏览器就能浏览。
JSP的1。0规范的最后版本是1999年9月推出的,12月又推出了1。1规范.目前较新的是JSP1。2规范,JSP2。0规范的征求意见稿也已出台。
JSP页面由HTML代码和嵌入其中的Java代码所组成。服务器在页面被客户端请求以后对这些Java代码进行处理,然后将生成的HTML页面返回给客户端的浏览器。Java Servlet 是JSP的技术基础,而且大型的Web应用程序的开发需要Java Servlet和JSP配合才能完成。JSP具备了Java技术的简单易用,完全的面向对象,具有平台无关性且安全可靠,主要面向因特网的所有特点。
自JSP推出后,众多大公司都支持JSP技术的服务器,如IBM、Oracle、Bea公司
3
等,所以JSP迅速成为商业应用的服务器端语言。
JSP可用一种简单易懂的等式表示为:HTML+Java=JSP.
1.2。2 J2EE
一、J2EE的概念
J2EE Java2平台企业版(Java 2 Platform,Enterprise Edition)
J2EE是一套全然不同于传统应用开发的技术架构,包含许多组件,主要可简化且规范应用系统的开发与部署,进而提高可移植性、安全与再用价值。
J2EE核心是一组技术规范与指南,其中所包含的各类组件、服务架构及技术层次,均有共通的标准及规格,让各种依循J2EE架构的不同平台之间,存在良好的兼容性,解决过去企业后端使用的信息产品彼此之间无法兼容,,企业内部或外部难以互通的窘境.
二。 J2EE的优势
J2EE为搭建具有可伸缩性、灵活性、易维护性的商务系统提供了良好的机制: 1。 保留现存的IT资产: 由于企业必须适应新的商业需求,利用已有的企业信息系统方面的投资,而不是重新制定全盘方案就变得很重要.这样,一个以渐进的(而不是激进的,全盘否定的)方式建立在已有系统之上的服务器端平台机制是公司所需求的.J2EE架构可以充分利用用户原有的投资,如一些公司使用的BEA Tuxedo、IBM CICS, IBM Encina,、Inprise VisiBroker 以及Netscape Application Server。这之所以成为可能是因为J2EE拥有广泛的业界支持和一些重要的’企业计算’领域供应商的参与。每一个供应商都对现有的客户提供了不用废弃已有投资,进入可移植的J2EE领域的升级途径。由于基于J2EE平台的产品几乎能够在任何操作系统和硬件配置上运行,现有的操作系统和硬件也能被保留使用。
2。 高效的开发: J2EE允许公司把一些通用的、很繁琐的服务端任务交给中间件供应商去完成。这样开发人员可以集中精力在如何创建商业逻辑上,相应地缩短了开发时间。高级中间件供应商提供以下这些复杂的中间件服务: o 状态管理服务 —- 让开发人员写更少的代码,不用关心如何管理状态,这样能够更快地完成程序开发。 o 持续性服务 —— 让开发人员不用对数据访问逻辑进行编码就能编写应用程序,能生成更轻巧,与数据库无关的应用程序,这种应用程序更易于开发与维护。 o 分布式共享数据对象CACHE服务 —- 让开发人员编制高性能的系统,极大提高整体部署的伸缩性。 3. 支持异构环境: J2EE能够开发部署在异构环境中的可移植程序。基于J2EE的应用程序不依赖任何特定操作系统、中间件、硬件.因此设计合理的基于J2EE的程序只需开发一次就可部署到各种平台.这在典型的异构企业计算环境中是十分关键的。J2EE标准也允许客户订购与J2EE兼容的第三方的现成的组件,把他们部署到异构环境中,节省了由自己制订整个方案所需的费用.
4. 可伸缩性: 企业必须要选择一种服务器端平台,这种平台应能提供极佳的可伸缩性去满足那些在他们系统上进行商业运作的大批新客户.基于J2EE平台的应用程序可被部署到各种操作系统上.例如可被部署到高端UNIX与大型机系统,这种系统单机可支持至256个处理器.(这是NT服务器所望尘莫及的)J2EE领域的供应商提供了更为
4
广泛的负载平衡策略。能消除系统中的瓶颈,允许多台服务器集成部署。这种部署可达数千个处理器,实现可高度伸缩的系统,满足未来商业应用的需要。
5.稳定的可用性: 一个服务器端平台必须能全天候运转以满足公司客户、合作伙伴的需要。因为INTERNET是全球化的、无处不在的,即使在夜间按计划停机也可能造成严重损失.若是意外停机,那会有灾难性后果。J2EE部署到可靠的操作环境中,他们支持长期的可用性。一些J2EE部署在WINDOWS环境中,客户也可选择健壮性能更好的操作系统如Sun Solaris、IBM OS/390。最健壮的操作系统可达到99。999%的可用性或每年只需5分钟停机时间。这是实时性很强商业系统理想的选择. 三。 J2EE 的四层模型
J2EE使用多层的分布式应用模型,应用逻辑按功能划分为组件,各个应用组件根据他们所在的层分布在不同的机器上.事实上,sun设计J2EE的初衷正是为了解决两层模式(client/server)的弊端,在传统模式中,客户端担当了过多的角色而显得臃肿,在这种模式中,第一次部署的时候比较容易,但难于升级或改进,可伸展性也不理想,而且经常基于某种专有的协议??通常是某种数据库协议。它使得重用业务逻辑和界面逻辑非常困难。现在J2EE 的多层企业级应用模型将两层化模型中的不同层面切分成许多层。一个多层化应用能够为不同的每种服务提供一个的层,以下是 J2EE 典型的四层结构:
运行在客户端机器上的客户层组件 运行在J2EE服务器上的Web层组件
运行在J2EE服务器上的业务逻辑层组件
运行在EIS服务器上的企业信息系统(Enterprise information system)层软件 J2EE应用程序组件
J2EE应用程序是由组件构成的.J2EE组件是具有功能的软件单元,它们通过相关的类和文件组装成J2EE应用程序,并与其他组件交互.J2EE说明书中定义了以下的J2EE组件:
应用客户端程序和applets是客户层组件。
Java Servlet和JavaServer Pages(JSP)是web层组件. Enterprise JavaBeans(EJB)是业务层组件. 客户层组件
J2EE应用程序可以是基于web方式的,也可以是基于传统方式的。
web 层组件
J2EE web层组件可以是JSP 页面或Servlets。按照J2EE规范,静态的HTML页面和Applets不算是web层组件.
正如下图所示的客户层那样,web层可能包含某些 JavaBean 对象来处理用户输入,并把输入发送给运行在业务层上的enterprise bean 来进行处理。 业务层组件
业务层代码的逻辑用来满足银行,零售,金融等特殊商务领域的需要,由运行在业务层上的enterprise bean 进行处理。 下图表明了一个enterprise bean 是如何从
5
客户端程序接收数据,进行处理(如果必要的话), 并发送到EIS 层储存的,这个过程也可以逆 向进行。
有三种企业级的bean: 会话(session) beans, 实体(entity) beans, 和消息驱动(message-driven) beans。 会话bean 表示与客户端程序的临时交互. 当客户端程序执行完后, 会话bean 和相关数据就会消失。 相反, 实体bean 表示数据库的表中一行永久的记录。 当客户端程序中止或服务器关闭时, 就会有潜在的服务保证实体bean 的数据得以保存.消息驱动 bean 结合了会话bean 和 JMS的消息的特性, 允许一个业务层组件异步接收JMS 消息. 企业信息系统层
企业信息系统层处理企业信息系统软件包括企业基础建设系统例如企业资源计划 (ERP), 大型机事务处理, 数据库系统,和其它的遗留信息系统. 例如,J2EE 应用组件可
能为了数据库连接需要访问企业信息系统 四。 J2EE 的结构
这种基于组件,具有平台无关性的J2EE 结构使得J2EE 程序的编写十分简单,因为业务逻辑被封装成可复用的组件,并且J2EE 服务器以容器的形式为所有的组件类型提供后台服务。 因为你不用自己开发这种服务, 所以你可以集中精力解决手头的业务问题.
容器和服务容器设置定制了J2EE服务器所提供得内在支持,包括安全,事务管理,JNDI(Java Naming and Directory Interface)寻址,远程连接等服务,以下列出最重要的几种服务:
J2EE安全(Security)模型可以让你配置 web 组件或enterprise bean ,这样只有被授权的用户才能访问系统资源. 每一客户属于一个特别的角色,而每个角色只允许激活特定的方法.你应在enterprise bean的布置描述中声明角色和可被激活的方法。由于这种声明性的方法,你不必编写加强安全性的规则。
J2EE 事务管理(Transaction Management)模型让你指定组成一个事务中所有方法间的关系,这样一个事务中的所有方法被当成一个单一的单元. 当客户端激活一个enterprise bean中的方法,容器介入一管理事务。因有容器管理事务,在enterprise bean中不必对事务的边界进行编码。要求控制分布式事务的代码会非常复杂。你只需在布置描述文件中声明enterprise bean的事务属性,而不用编写并调试复杂的代码。容器将读此文件并为你处理此enterprise bean的事务。 JNDI 寻址(JNDI Lookup)服务向企业内的多重名字和目录服务提供了一个统一的接口,这样应用程序组件可以访问名字和目录服务。
J2EE远程连接(Remote Client Connectivity)模型管理客户端和enterprise bean间的低层交互。 当一个enterprise bean创建后, 一个客户端可以调用它的方法就象它和客户端位于同一虚拟机上一样.
生存周期管理(Life Cycle Management)模型管理enterprise bean的创建和移除,一个enterprise bean在其生存周期中将会历经几种状态。容器创建enterprise b
6
ean,并在可用实例池与活动状态中移动他,而最终将其从容器中移除.即使可以调用enterprise bean的create及remove方法,容器也将会在后台执行这些任务。
数据库连接池(Database Connection Pooling)模型是一个有价值的资源.获取数据库
连接是一项耗时的工作,而且连接数非常有限。容器通过管理连接池来缓和这些问题。enterprise bean可从池中迅速获取连接。在bean释放连接之可为其他bean使用.
容器类型
J2EE应用组件可以安装部署到以下几种容器中去:
EJB 容器管理所有J2EE 应用程序中企业级bean 的执行。 enterprise bean 和它们的容
器运行在J2EE 服务器上。
Web 容器管理所有J2EE 应用程序中JSP页面和Servlet组件的执行。 Web 组件和它们的容器运行在J2EE 服务器上。 应用程序客户端容器管理所有J2EE应用程序中应用程序客户端组件的执行。 应用程序客户端和它们的容器运行在J2EE 服务器上. Applet 容器是运行在客户端机器上的web浏览器和 Java 插件的结合。。 五. J2EE的核心API与组件
J2EE平台由一整套服务(Services)、应用程序接口(APIs)和协议构成,它对开发基于Web的多层应用提供了功能支持,下面对J2EE中的13种技术规范进行简单的描述(限于篇幅,这里只能进行简单的描述):
1。 JDBC(Java Database Connectivity):
JDBC API为访问不同的数据库提供了一种统一的途径,象ODBC一样,JDBC对开发者屏蔽了一些细节问题,另外,JDCB对数据库的访问也具有平台无关性。 2。 JNDI(Java Name and Directory Interface):
JNDI API被用于执行名字和目录服务。它提供了一致的模型来存取和操作企业级的资源如DNS和LDAP,本地文件系统,或应用服务器中的对象. 3. EJB(Enterprise JavaBean):
J2EE技术之所以赢得媒体广泛重视的原因之一就是EJB。它们提供了一个框架来开发和实施分布式商务逻辑,由此很显著地简化了具有可伸缩性和高度复杂的企业级应用的开发。EJB规范定义了EJB组件在何时如何与它们的容器进行交互作用。容器负责提供公用的服务,例如目录服务、事务管理、安全性、资源缓冲池以及容错性.但这里值得注意的是,EJB并不是实现J2EE的唯一途径。正是由于J2EE的开放性,使得有的厂商能够以一种和EJB平行的方式来达到同样的目的. 4。 RMI(Remote Method Invoke):
正如其名字所表示的那样,RMI协议调用远程对象上方法。它使用了序列化方式在客户端和服务器端传递数据。RMI是一种被EJB使用的更底层的协议. 5。 Java IDL/CORBA:
在Java IDL的支持下,开发人员可以将Java和CORBA集成在一起.他们可以创建Java对象并使之可在CORBA ORB中展开, 或者他们还可以创建Java类并作为和其它O
7
RB一起展开的CORBA对象的客户.后一种方法提供了另外一种途径,通过它Java可以被用于将你的新的应用和旧的系统相集成。 6。 JSP(Java Server Pages):
JSP页面由HTML代码和嵌入其中的Java代码所组成。服务器在页面被客户端所请求以后对这些Java代码进行处理,然后将生成的HTML页面返回给客户端的浏览器。 7。 Java Servlet:
Servlet是一种小型的Java程序,它扩展了Web服务器的功能。作为一种服务器端的应用,当被请求时开始执行,这和CGI Perl脚本很相似。Servlet提供的功能大多与JSP类似,不过实现的方式不同.JSP通常是大多数HTML代码中嵌入少量的Java代码,而servlets全部由Java写成并且生成HTML。 8。 XML(Extensible Markup Language):
XML是一种可以用来定义其它标记语言的语言。它被用来在不同的商务过程享数据。
XML的发展和Java是相互的,但是,它和Java具有的相同目标正是平立性。通过将Java和XML的组合,您可以得到一个完美的具有平立性的解决方案. 9。 JMS(Java Message Service):
MS是用于和面向消息的中间件相互通信的应用程序接口(API).它既支持点对点的域,有支持发布/订阅(publish/subscribe)类型的域,并且提供对下列类型的支持:经认可的消息传递,事务型消息的传递,一致性消息和具有持久性的订阅者支持。JMS还提供了另
一种方式来对您的应用与旧的后台系统相集成。 10. JTA(Java Transaction Architecture):
JTA定义了一种标准的API,应用系统由此可以访问各种事务监控。 11. JTS(Java Transaction Service):
JTS是CORBA OTS事务监控的基本的实现。JTS规定了事务管理器的实现方式。该事务管理器是在高层支持Java Transaction API (JTA)规范,并且在较底层实现OMG OTS specification的Java映像。JTS事务管理器为应用服务器、资源管理器、的应用以及通信资源管理器提供了事务服务. 12。 JavaMail:
JavaMail是用于存取邮件服务器的API,它提供了一套邮件服务器的抽象类。不仅支持SMTP服务器,也支持IMAP服务器。
13。 JAF(JavaBeans Activation Framework): JavaMail利用JAF来处理MIME编码的邮件附件。MIME的字节流可以被转换成Java对象,或者转换自Java对象。大多数应用都可以不需要直接使用JAF。
1。2.3 MVC
MVC本来是存在于Desktop程序中的,M是指数据模型,V是指用户界面,C则是控制器。使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表
8
现形式.比如一批统计数据你可以分别用柱状图、饼图来表示.C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。
模型-视图-控制器(MVC)是Xerox PARC在八十年代为编程语言Smalltalk-80发明的一种软件设计模式,至今已被广泛使用。最近几年被推荐为Sun公司J2EE平台的设计模式,并且受到越来越多的使用 ColdFusion 和 PHP 的开发者的欢迎。模型-视图-控制器模式是一个有用的工具箱,它有很多好处,但也有一些缺点。
1.3 开发工具介绍
1.3。1 Myeclipse定义及特征
MyEclipse企业级工作平台(MyEclipse Enterprise Workbench ,简称MyEclipse)是对Eclipse IDE的扩展,利用它我们可以在数据库和JavaEE的开发、发布,以及应用程序服务器的整合方面极大的提高工作效率。它是功能丰富的JavaEE集成开发环境,包括了完备的编码、调试、测试和发布功能,完整支持HTML, Struts, JSF, CSS, Javascript, SQL, Hibernate
在结构上,MyEclipse的特征可以被分为7类: 1。 JavaEE模型 2。 WEB开发工具 3. EJB开发工具
4. 应用程序服务器的连接器 5. JavaEE项目部署服务
6. 数据库服务
7. MyEclipse整合帮助
对于以上每一种功能上的类别,在Eclipse中都有相应的功能部件,并通过一系列的插件来实现它们。MyEclipse结构上的这种模块化,可以让我们在不影响其他模块的情况下,对任一模块进行单独的扩展和升级。
简单而言,MyEclipse是Eclipse的插件,也是一款功能强大的JavaEE集成开发环境,支持代码编写、配置、测试以及除错,MyEclipse6。0以前版本需先安装Eclipse。MyEclipse6.0以后版本安装时不需安装Eclipse。
1。3.2 Apache Tomcat 6。0
Tomcat 很受广大程序员的喜欢,因为它运行时占用的系统资源小,扩展性好,支持负载平衡与邮件服务等开发应用系统常用的功能;而且它还在不断的
改进和完善中,任何一个感兴趣的程序员都可以更改它或在其中加入新的功能 Tomcat 是一个小型的轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。对于一个初学者来说,可以这样认为,当在一台机器上配置好Apache 服务器,可利用它响应对HTML 页面的访问请求。
9
实际上Tomcat 部分是Apache 服务器的扩展,但它是运行的,所以当你运行tomcat 时,它实际上作为一个与Apache 的进程单独运行的。
1。3.3MySQL数据库
与其他的大型数据库例如Oracle、DB2、SQL Server等相比,MySQL自有它的不足之处,如规模小、功能有限(MySQL Cluster的功能和效率都相对比较差)等,但是这丝毫也没有减少它受欢迎的程度。对于一般的个人使用者和中小型企业来说,MySQL提供的功能已经绰绰有余,而且由于MySQL是开放源码软件,因此可以大大降低总体拥有成本。
目前Internet上流行的网站构架方式是LAMP(Linux+Apache+MySQL+PHP),即使用Linux作为操作系统,Apache作为Web服务器,MySQL作为数据库,PHP作为服务器端脚本解释器。由于这四个软件都是自由或开放源码软件(FLOSS),因此使用这种方式不用花一分钱就可以建立起一个稳定、免费的网站系统。
第二章需求分析
2.1功能需求
在图书管理系统中,管理员要为每个读者建立借阅账户,并給读者发放不同类别的借阅卡,账户内存储读者的个人信息和借阅记录信息.持有借阅卡的读者可以通过管理员借阅、归还图书,不同类别的读者可借阅图书的范围、数量和期限不同,可通过互联网或图书馆内查询终端查询图书信息和个人借阅情况,以及续借图书.
借阅图书时,先输入读者条形码,系统验证借阅卡的有效性和读者是否可继续借阅图书,无效则提示其原因,有效则显示读者的基本信息,供管理员人工核对。然后输入要借阅的书号,系统查阅图书信息数据库,显示图书的基本信息,供管理员人工核对.最后提交借阅请求,若被系统接受则存储借阅纪录,并修改可借阅图书的数量.归还图书时,输入读者借阅卡号和图书号,系统验证是否有此借阅纪录以及是否超期借阅,无则提示,有则显示读者和图书的基本信息供管理员人工审核。如果有超期借阅或丢失情况,先转入过期罚款或图书丢失处理。然后提交还书请求,系统接受后删除借阅纪录,并登记并修改可借阅图书的数量。
图书管理员定期或不定期对图书信息进行入库、修改、删除等图书信息管理以及注销,包括图书类别和出版社管理.
为系统维护人员提供权限管理、数据备份等通用功能。
10
2.2 系统需求
将图书管理对系统的需求分为系统设置,读者管理,图书管理,图书借还,系统查询等功能。
2.3系统维护需求
本系统采用J2EE设计模式,使用了struts+Hibernian框架结构,struts主要对控制命令进行管理,Hibernian则对数据持久化进行管理,极其方便维护.
第三章 系统设计
3.1系统总体功能模块
系统总体功能模块如图3.1所示:
图3。1
本系统的业务流程图如图3.2所示:
图3.2
3.2 系统功能模块设计
3。2.1公共模块设计
在开发过程中经常会用到一些公共模块,图书管理系统中涉及到的公共模块包括数据库连接及操作的类;字符串处理的类和struts的配置等. 1.所以此模块设计包括数据库连接及操作的类;
publicclass ConnDB;此类是连接数据库和操作数据库的类,包括数据库的查询,更新,关闭数据库连接的操作。
public static Connection getConnection();是连接数据库的方法. public ResultSet executeQuery(String sql);是数据库查询的方法。 publicint executeUpdate(String sql);是数据库更新的方法。 publicvoid close();是关闭数据库连接方法.
11
2。字符串处理的类;
publicclass ChStr;是字符串处理的类
public static String toChinese(String strvalue);将字符串转换为GBK编码的方法。 public static final String nullToString(String v, String toV);去除字符串中的空格地方法。
public static final String filterStr(String str); 过滤危险字符的方法. 3。配置struts.
配置struts就是配置系统中的web.xml文件,将文件配置成如下内容:
〈?xml version=”1。0” encoding=\"UTF-8\"?>
〈servlet-name〉action 〈param-name〉config〈param—value>/WEB—INF/struts-config。xml〈/param—value> 〈/init-param> 〈load—on-startup>0 〈!-- 设置默认文件名称 -—> 〈/web-app> 3。2.2管理员模块设计 3。2.2。1管理员登录模块 一、管理员登录模块说明 这一模块是用于对管理员登录用户名和密码进行验证并根据其权限赋予相应的功能的处理。对用户所输入的用户名及密码进行加密认证,并将登录信息传递给管理系统,从而进行管理.如果输入的用户名和密码无法得到认证,即使是了解网站构成的专业人士也无法进入系统。管理员的用户信息可以得到十足的保障,使得即使作为远程系统也拥有如同本地系统一样的安全性.保障了系统数据的安全。 二、管理员登录模块功能图 管理员登录模块包括:正常登录、重置信息、密码认证、退出。如下图3.3所示: 管理员登录 正常登录 重置信息 密码认证 退出系统 图3。3 三、管理员登录模块流程图 管理员登录模块流程图如下图3。4所示: 13 进入登录首页 输入验证信息 是否通 过验证 N Y 进入管理首页 图3.4 3.2.2。2管理员系统设置模块 一、管理员系统设置模块说明 该模块是管理员对于系统的基本设置,还有管理员本身的添加修改等操作。 二、管理员系统设置模块功能图 管理员系统设管理模块如下图3.5所示: 系统设置 图书馆信息管理员设置参数设置书架设置口令更改 三、管理员系统设置模块流程图: 管理员系统设置管理模块流程图如图3.6所示: 14 图3。5 图3.6 3。2。2。3管理员读者管理模块 一、管理员读者管理模块说明 该模块是管理员用于对所有读者进行管理的平台,基本包括查找、修改、删除等操作。 二、管理员读者管理模块功能图 管理员读者管理模块如下图3.7所示: 读者管理 查询读者信息 读者信息分类 修改读者信息 删除读者信息 图3。7 三、管理员读者管理模块流程图 管理员读者管理模块如下图3。8所示: 进入读者管理 选择操作 查看 处理 删除 Y 继续操作 N 退出 图3。8 15 3.2.3图书管理模块设计 一、图书管理模块说明 此模块是管理员对图书类型的设置和图书的档案管理,包括对图书条形码,图书名称,图书类型,作者,译者,出版社,价格等信息的设置与修改。 二、图书管理模块功能功能图 图书管理模块如下图3。9所示: 图书类型设置 三、管理员图书管理模块流程图图书档图3。9 案管理图书管理 图书管理模块如下图3.10所示: 图3.10 3.2。4图书借还模块设计 一、图书借还模块说明 此模块是对图书借阅,图书续借,图书归还的管理。 二、图书借还模块功能功能图 图书借还模块如下图3.11所示: 图3。11 三、管理员图书借还模块流程图 图书借还模块如下图3.12所示: 图3。12 第四章 详细设计与实现 16 4。1数据库设计 本系统数据库中包含图书类型信息表,出版社信息表,书架信息表,管理员信息表,图书信息表,权限信息表,借书信息表,还书信息表,读者类型信息表,读者信息表,图书馆信息表和系统参数信息表。以下分别详细介绍各表的内容。 4.1。1 数据表: 1图书类型信息表 图书类型信息表包括: id: 类型为integer,图书的id号,是主键; typename:类型为varchar,图书的名称; days:类型为integer,图书可借的天数。 2 出版社信息表 出版社信息表包括: ISBN:类型为varchar,出版社的ISBN号; pubname:类型为varchar,出版社的名称。 3 书架信息表 书架信息表包括: id:类型为integer,书架的id号,主键; name:类型为 varchar,书架的名称; 4 管理员信息表 管理员信息表包括: id:类型为integer,管理员的id号,主键; name:类型为varchar,管理员名称; PWD:类型为varchar,管理员密码。 5 图书信息表 图书信息表包括: id:类型为integer,图书的id号,主键; barcode:类型为int,图书的条形码; bookname:类型为varchar,图书的名称; typeid:类型为integer,图书的类型id号; author:类型为varchar,图书的作者名; translator:类型为varchar,图书的译者; ISBN:类型为varchar,图书的isbn号; price:类型为float,图书的价格; page:类型为integer,图书的页数; bookcase:类型为integer,图书书架信息; intime:类型为date,录入时间; operator:类型为varchar,操作员; del:类型为tinyint,是否删除; 6 权限信息表 权限信息表包括: id:类型为integer,权限的id号,主键; 17 syset:类型为tinyint,系统设置; readerset:类型为tinyint,读者设置; bookset:类型为tinyint,图书设置; borrowback:类型为tinyint,是否归还 sysquery:类型为tinyint,系统查询; 7 借书信息表 借书信息表包括: id:类型为integer,借书的id号,主键; readerid:类型为integer,读者id号; bookid:类型为integer,图书的id号; borrowTime:类型为date,借书的日期; backTime:类型为date,还书的日期; operator:类型为varchar,操作员; ifback:类型为tinyint,是否还书。 8 还书信息表 还书信息表包括: id:类型为integer,还书的id号,主键; readerid:类型为integer,读者id号; bookid:类型为integer,图书的id号; backTime:类型为date,还书的日期; operator:类型为varchar,操作员; 9 读者类型信息表 读者类型信息表包括: id:类型为integer,读者类型的id号,主键; name:类型为varchar,读者的名称; number:类型为integer,可借数量。 10 读者信息表 读者信息表包括: id:类型为integer,读者的id号,主键; name:类型为varchar,读者的名称; sex:类型为varchar,读者的性别 barcode:类型为varchar,读者的条形码; vocation:类型为varchar,读者的职业; birthday:类型为date,读者的生日; paperType:类型为varchar,读者的有效证件; paperNO:类型为varchar,读者的证件号码; tel:类型为varchar,读者的联系电话; email:类型为varchar,读者的邮箱地址; craeteday:类型为date,读者的账号创建日期; operator:类型为varchar,操作员; remark:类型为text,备注; typeid:类型为integer,类型。 11 图书馆信息表 图书馆信息表包括: id:类型为integer,图书馆的id号,主键; 18 libraryname:类型为varchar,图书馆名称; curator:类型为varchar,馆长名; tel:类型为varchar,图书馆的联系电话; address:类型为varchar,图书馆地址; email:类型为varchar,图书馆的邮箱地址; url:类型为varchar,图书馆网址; craeteday:类型为date,图书馆创建日期; introduct:类型为text,图书馆介绍。 12系统参数信息表 系统参数信息表包括: id:类型为integer,系统参数的id号,主键; cost:类型为integer,费; validity:类型为integer,有效期限。 4。1.2整个数据库关系图 关系图如图4。1所示: 图4。1 4。2用户界面的实现和功能代码的实现 包的命名: com。action 存放了所有类的动作和方法; com.actionForm 存放了所有类的声明 com。core 存放了所有公共模块中的类 com。dao 存放了所的DAO类; 类的功能: com.action.Book类 该类实现了关于图书的所有的增删改查的动作。 com。action。BookCase类 该类实现了关于书架的所有的增删改查的动作. com.action。BookType类 该类实现了关于图书类型的所有的增删改查的动作. com.action.Borrow类 该类实现了图书借阅排行,图书借阅查询,到期提醒,图书借阅,图书续借,图书归还操作。 com.action.Library类 该类实现了图书信息设置与修改. com.action.Manager类 该类实现了对管理员的增删改查以及对管理员验证和密码的修改。 com。action.Parameter类 该类实现了对参数的修改与查询。 19 com.action.Publishing类 该类实现了对出版社的查询。 com。action。Reader类 该类实现了对读者信息的增删改查功能。 com。action。ReaderType类 该类实现了对读者类型信息的增删改查功能。 com。core.ChStr类 该类实现了对字符串传换成gbk. com.core.ConnDB类 该类实现了数据库的连接. 主要界面图片如下: 登录页面如图4.2所示: 主页面如图4.3所示: 管理员设置页面如图4.4所示: 书架设置界面如图4。5所示: 图书借阅界面如图4。6所示: 图书续借页面如图4。7所示: 图书档案查询界面如图4。8所示:图书借阅查询页面如图4。9所示:更改口令页面如图4.10所示:: 图4.2 图4。3 图4.4 图4.5 图4.6 图4.7 图4。8 图4。9 图4.10 20 第五章 开发遇到的困难与解决方案 自己遇到了很多问题和困难,从后台数据库的设计到应用界面的设计与制作遇到了许多困难,这只有自己亲身经历才能真正体会到的,我想这也是提高自己思考、解决问题的能力最有效的方法,从实践中提高自己. 1连接问题 数据库和MyEclipse的连接,对jdbc的语法不是很清楚,有时候还会出现一些异常现象,例如时间类型的定义要重新修改,否则系统会提示错误. 解决方法:借阅相关书籍以及请教老师和同学,对java的语法有了初步的了解,最终解决了问题. 2 搜索问题 当要查找图书信息时会出现异常,与数据库连接不上。 解决方法:借阅相关书籍以及请教老师 具体代码如下: private ActionForward bookifQuery(ActionMapping mapping, ActionForm form,HttpServletRequest request, HttpServletResponse response){ String str=null; if(request。getParameter(\"f”)!=null){ str = request.getParameter(\"f\") + ” like '%” + request.getParameter(”key\") + \"%\"; } request.setAttribute(”ifbook”,bookDAO.query(str)); System.out。print(”条件查询图书信息时的str:”+str); return mapping。findForward(”bookifQuery”);} 第六章 心得体会 通过这次设计使我明白了自己原来知识还比较欠缺。自己要学习的东西还太多,以前老是觉得自己什么东西都会,什么东西都懂,有点眼高手低。通过这次设计,我才明白学习是一个长期积累的过程,在以后的工作、生活中都应该不断的学习,努力提高自己知识和综合素质. 总之,不管学会的还是学不会的的确觉得困难比较多,真是万事开头难,不知道如何入手。最后终于做完了有种如释重负的感觉。此外,还得出一个结论:知识必须通过应用才能实现其价值!有些东西以为学会了,但真正到用的时候才发现是两回事,所以我认为只有到真正会用的时候才是真的学会了。 21 在此要感谢我的指导老师庄老师对我悉心的指导,感谢老师给我的帮助。在设计过程中,我通过查阅大量有关资料,与同学交流经验和自学,并向老师请教等方式,使自己学到了不少知识,也经历了不少艰辛,但收获同样巨大.在整个设计中我懂得了许多东西,也培养了我工作的能力,树立了对自己工作能力的信心,相信会对今后的学习工作生活有非常重要的影响。而且大大提高了动手的能力,使我充分体会到了在创造过程中探索的艰难和成功时的喜悦。虽然这个设计做的也不太好,但是在设计过程中所学到的东西是这次最大收获和财富,使我终身受益。 参考文献 ⑴轻量级J2EE企业应用实践-struts+Spring+Hibernian整合开发,李刚著 , 电子工业出版社 ,2008年 ⑵J2EE开发过程实录,杨中科,清华大学出版社 ,2007年 ⑶J2EE经典案例设计与实现,王毅 周峰 孙更新著 ,2007年 ⑷J2EE应用与IBM WebSphere (美),Dale R。 Nilsson, Louis E. Mauget著,电子工业出版社,2004年 ⑸Java 2技术内幕(美),波茨[等],机械工业出版社,2003年 ⑹JDBC数据库编程与J2EE (美), Art Taylor著,电子工业出版社,2004年 22
因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- huatuo0.cn 版权所有 湘ICP备2023017654号-2
违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务