您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 其它文档 > JavaWeb课程设计——图书馆管理系统
1/33JavaWeb课程设计实验报告班级:计算机09-2实验内容:图书馆管理系统成员:赵伯涛44号(组长)张宝红42号黄海清22号实验时间:从2011年12月3日至2011年12月9日指导老师:李启锐2/33一、实验目的。1、在实践中巩固本学习所学的JavaWeb技术。2、在实践中初步使用设计模式(GoF),体验设计模式带来的好处。3、配合数据库的使用,实现一个功能完善的小型系统。二、实验内容。开发一个图书管理系统,实现图书馆的各种管理操作。如图书入库、作废,借书证提供、挂失处理,图书的借出、归还、续借、丢失以及超期处理。s三、业务逻辑。3/33四、数据库设计。根据业务逻辑设计出数据库。表结构及关系如下图:4/33数据库导入文本保存在DataBaseSQL.txt文档中,数据库数据保存在Data.txt文档中。五、框架结构。5/33采用了类似与MVC框架的框架结构,页面端使用了ExtJS技术(包含AJAX),增加了业务层和,数据库操作层。控制器层调用业务层,业务层调用数据库操作层。将控制,业务,数据库操作分别分层。六、技术性代码。(本实验的代码在Library.zip中)1、tomcat数据库连接池技术。在tomcat中的配置文件server.xml文件中配置项目Context标签,再加入Resource标签:Contextpath=LibraryOAdocBase=/home/sea/MyEclipse/LibraryOA/WebRootdebug=0Resourcename=jdbc/webdb6/33auth=Containertype=javax.sql.DataSourcedriverClassName=org.gjt.mm.mysql.Driverurl=jdbc:mysql://localhost:3306/LibraryOAusername=rootpassword=rootmaxActive=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){7/33Thread.sleep((long)(Math.random()*200));synchronized(DataBaseConnectionPond.class){if(dbcp==null){dbcp=newDataBaseConnectionPond();}}}try{conn=dbcp.GetConnettion();}catch(Exceptione){}returnconn;}}该类在整个项目部署的过程中只实例化了一个对象,故称单例。可以通过该类的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){8/33try{conn.rollback();}catch(Exceptionee){}e.printStackTrace();}finally{try{conn.close();}catch(Exceptione){}}returnresult;}}该类是一个抽象类,必须通过继承该类来实现具体的功能,其中的execute()函数是一个模板方法,将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;}9/33@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的部分代码//读者修改密码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;}}10/33注意:使用Dao的时候调用的应该是它的execute()方法(在抽象类中)。4、时间显示varcTime=newDate();//初始化日期varmyYear=cTime.getFullYear();//年varmyMonth=cTime.getMonth()+1;//月varmyDate=cTime.getDate();//日//获得时分秒varmyHour=cTime.getHours();//时varmyMinute=cTime.getMinutes();//分varmySecond=cTime.getSeconds();//秒if(myHour10){//判断如果时钟小于10就显示两位,前一位用0代替myHour='0'+myHour;}if(myMinute10){//判断如果分钟小于10就显示两位,前一位用0代替myMinute='0'+myMinute;}if(mySecond10){//判断如果分秒钟小于10就显示两位,前一位用0代替mySecond='0'+mySecond;}vartime=time=myYear+'/'+myMonth+'/'+myDate+''+myHour+':'+myMinute+':'+mySecond;//格式化时间vartimer=setInterval(function(){//定义一个时钟,周期为1秒varcTime=newDate();varmyYear=cTime.getFullYear();//支持火狐varmyMonth=cTime.getMonth()+1;//外国都是以0开头为一月varmyDate=cTime.getDate();//获得时分秒varmyHour=cTime.getHours();varmyMinute=cTime.getMinutes();varmySecond=cTime.getSeconds();if(myHour10){myHour='0'+myHour;}if(myMinute10){myMinute='0'+myMinute;11/33}if(mySecond10){mySecond='0'+mySecond;}varcmp=Ext.getCmp(timer);time=myYear+'/'+myMonth+'/'+myDate+''+myHour+':'+myMinute+':'+mySecond;cmp.setValue(time);},1000);5、登录控制//登录界面Ext.onReady(function(){Ext.QuickTips.init();varform=newExt.Panel({//登录验证的formautoTabs:true,activeTab:0,deferredRender:false,border:false,bodyStyle:background-color:RGB(193,223,232);padding:0px0px0px0px;,items:[{xtype:'box',width:385,height:80,autoEl:{tag:'img',src:'icons/borrowbook
本文标题:JavaWeb课程设计——图书馆管理系统
链接地址:https://www.777doc.com/doc-6350028 .html