您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 其它文档 > JavaWeb课程设计——图书馆管理系统-刘娜
1/11潍坊科技学院JavaWeb课程设计报告书设计题目图书管理系统专业班级11级软件1班学生姓名刘娜学号201101080011指导教师日期2013.6.3~2013.6.28成绩2/11课程设计任务书院系:中印计算机软件专业:软件技术班级:11软1学号:201101080011目录(1)正文部分1引言1.1课程设计目的1.2课程设计背景1相关技术1.1Spring框架1.2Struts2框架1.3Hibernate框架2需求分析2.1系统功能需求2.2系统开发运行环境3总体设计3.1系统体系结构设计3.2系统功能模块设计3.3系统主要JSP页面设计3.4数据库设计4系统实现3/114.1系统运行界面4.2主要代码5.效果截图5课设总结6参考文献一、实验目的。1、在实践中巩固本学习所学的JavaWeb技术。2、在实践中初步使用设计模式(GoF),体验设计模式带来的好处。3、配合数据库的使用,实现一个功能完善的小型系统。二、实验内容。开发一个图书管理系统,实现图书馆的各种管理操作。如图书入库、作废,借书证提供、挂失处理,图书的借出、归还、续借、丢失以及超期处理。s三、数据库设计。根据业务逻辑设计出数据库。表结构及关系如下图:4/11数据库导入文本保存在DataBaseSQL.txt文档中,数据库数据保存在Data.txt文档中。四、技术性代码。(本实验的代码在Library.zip中)1、tomcat数据库连接池技术。在tomcat中的配置文件server.xml文件中配置项目Context标签,再加入Resource标签:Contextpath=LibraryOAdocBase=/home/sea/MyEclipse/LibraryOA/WebRootdebug=0Resourcename=jdbc/webdbauth=Containertype=javax.sql.DataSourcedriverClassName=org.gjt.mm.mysql.Driverurl=jdbc:mysql://localhost:3306/LibraryOAusername=rootpassword=root5/11maxActive=50maxIdle=20maxWait=10000//Context以上代码配置了数据库驱动,数据库地址,数据库用户名、密码,默认提供的连接数,最大提供的连接数,最长等待时间等参数。2、Java中从连接池获取连接的类,使用了单例模式(来自GoF提出的设计模式)://DataBaseConnectionPond.javapackagelibrary.util;importjava.sql.Connection;importjavax.sql.DataSource;//作者:赵伯涛publicclassDataBaseConnectionPond{privatestaticDataBaseConnectionPonddbcp=null;privateDataSourceds=null;privateDataBaseConnectionPond()throwsException{javax.naming.Contextctx=newjavax.naming.InitialContext();ds=(DataSource)ctx.lookup(java:/comp/env/jdbc/webdb);}publicConnectionGetConnettion()throwsException{returnds.getConnection();}publicstaticConnectiongetConnection()throwsException{Connectionconn=null;if(dbcp==null){Thread.sleep((long)(Math.random()*200));synchronized(DataBaseConnectionPond.class){if(dbcp==null){dbcp=newDataBaseConnectionPond();}}}try{conn=dbcp.GetConnettion();}catch(Exceptione){}6/11returnconn;}}该类在整个项目部署的过程中只实例化了一个对象,故称单例。可以通过该类的static函数getConnection()获取连接。3、Dao(DataAccessObject)的模板化实现,使用了模板方法模式(来自GoF提出的设计模式)://SqlExecute.javapackagelibrary.execute;importjava.sql.Connection;importlibrary.util.*;//作者:赵伯涛publicabstractclassSqlExecute{publicConnectionconn;publicObjectresult;publicabstractvoidsetExecute()throwsException;publicObjectexecute(){try{conn=DataBaseConnectionPond.getConnection();conn.setAutoCommit(false);setExecute();conn.commit();}catch(Exceptione){try{conn.rollback();}catch(Exceptionee){}e.printStackTrace();}finally{try{conn.close();}catch(Exceptione){}}returnresult;}}该类是一个抽象类,必须通过继承该类来实现具体的功能,其中的execute()函数7/11是一个模板方法,将try-catch-finaly、获取connection及connection的事务处理提取出来,具体Dao的功能应该写在setExecute()函数中,在具体实现Dao的功能的时候可以不用重复这些代码,方便程序员编码,也方便程序员维护程序。下面举例使用这个模板类://ReaderChangePasswordDao.javapackagelibrary.dao;importjava.sql.PreparedStatement;importlibrary.execute.SqlExecute;importlibrary.model.ReaderModel;//作者:赵伯涛publicclassReaderChangePasswordDaoextendsSqlExecute{privateReaderModelrm;//传入readerID,password,password2(旧密码)//返回影响行数publicReaderChangePasswordDao(ReaderModelrm){this.rm=rm;}@OverridepublicvoidsetExecute()throwsException{Stringsql=updateReaderssetpassword=?wherereaderID=?andpassword=?;PreparedStatementps=conn.prepareStatement(sql);ps.setString(1,rm.getPassword());ps.setInt(2,rm.getReaderID());ps.setString(3,rm.getPassword2());this.result=ps.executeUpdate();}}上面的类继承了SqlExecute类,重写了它的setExecute()函数,通过构造函数传入操作时需要的参数,在写代码的时候可以更加专注于数据库的操作,因为其它操作由模板类做好了。这对写一个数据库操作或许没什么大不了的,但是一个项目里边数据库操作肯定是几十个,几百个,甚至几千个,使用模板类减少的编码量是非常客观的。下面举例使用ReaderChangePasswordDao类://来自UserCommonService.java的部分代码8/11//读者修改密码publicbooleanreaderChangePassword(intreaderID,StringnewPassword,StringoldPassword){ReaderModelrm=newReaderModel();rm.setReaderID(readerID);rm.setPassword(newPassword);rm.setPassword2(oldPassword);ReaderChangePasswordDaorcpd=newReaderChangePasswordDao(rm);intcount=(Integer)rcpd.execute();if(count0){returntrue;}else{returnfalse;}}注意:使用Dao的时候调用的应该是它的execute()方法(在抽象类中)。五、效果截图9/1110/11六、实验心得。通过本次实验,我们不单单巩固了我们的Jsp技术,同时业务逻辑能力得到了提高,能通过业务逻辑设计一个数据库,并且在实现业务逻辑的过程中初步使用了GoF提出的设计模式,同时也体验到它带来的好处。在共同合作开发的过程中,学会如何分工及沟通11/11七·参考文献。【1】刘宝林。Java程序设计与案例【M】。北京。高等教育出版社。2004.11【2】吴亚峰。纪超。JavaSE。6.6编程指南【M】。北京。人民邮局出版社。2007.11【3】刘精华。JavaWeb整合开发王者归来【M】。北京。高等教育出版社。2003.9【4】孙伟琴。《Tomcat与javaweb开发技术讲解(第二版)》【M】北京:电子工业出版社、2009.1-220【5】黄嘉辉《java网络程序设计》【M】北京。清华大学出版社。2002:445-470
本文标题:JavaWeb课程设计——图书馆管理系统-刘娜
链接地址:https://www.777doc.com/doc-5200924 .html