JavaWeb课程设计——图书馆管理系统 (精选可编辑)

上传人:1728****196 文档编号:159955647 上传时间:2021-01-08 格式:DOCX 页数:33 大小:1.61MB
返回 下载 相关 举报
JavaWeb课程设计——图书馆管理系统 (精选可编辑)_第1页
第1页 / 共33页
JavaWeb课程设计——图书馆管理系统 (精选可编辑)_第2页
第2页 / 共33页
亲,该文档总共33页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《JavaWeb课程设计——图书馆管理系统 (精选可编辑)》由会员分享,可在线阅读,更多相关《JavaWeb课程设计——图书馆管理系统 (精选可编辑)(33页珍藏版)》请在金锄头文库上搜索。

1、JavaWeb课程设计实验报告班级:计算机09-2实验内容:图书馆管理系统成员:赵伯涛 44号(组长)张宝红 42号黄海清 22号实验时间:从 2011年12月3日至 2011年12月9日指导老师:李启锐一、实验目的。1、在实践中巩固本学习所学的JavaWeb技术。2、在实践中初步使用设计模式(GoF),体验设计模式带来的好处。3、配合数据库的使用,实现一个功能完善的小型系统。二、实验内容。开发一个图书管理系统,实现图书馆的各种管理操作。如图书入库、作废,借书证提供、挂失处理,图书的借出、归还、续借、丢失以及超期处理。s三、业务逻辑。四、数据库设计。根据业务逻辑设计出数据库。表结构及关系如下图

2、:数据库导入文本保存在DataBaseSQL.txt文档中,数据库数据保存在Data.txt文档中。五、框架结构。采用了类似与MVC框架的框架结构,页面端使用了ExtJS技术(包含AJAX),增加了业务层和,数据库操作层。控制器层调用业务层,业务层调用数据库操作层。将控制,业务,数据库操作分别分层。六、技术性代码。(本实验的代码在Library.zip中)1、tomcat数据库连接池技术。在tomcat中的配置文件server.xml文件中配置项目Context标签,再加入Resource标签:以上代码配置了数据库驱动,数据库地址,数据库用户名、密码,默认提供的连接数,最大提供的连接数,最长等

3、待时间等参数。2、Java中从连接池获取连接的类,使用了单例模式(来自GoF提出的设计模式):/ DataBaseConnectionPond.javapackage library.util;import java.sql.Connection;import javax.sql.DataSource;/作者:赵伯涛public class DataBaseConnectionPond private static DataBaseConnectionPond dbcp = null;private DataSource ds = null;private DataBaseConnection

4、Pond() throws Exception javax.naming.Context ctx = new javax.naming.InitialContext();ds = (DataSource) ctx.lookup(java:/comp/env/jdbc/webdb);public Connection GetConnettion() throws Exception return ds.getConnection();public static Connection getConnection() throws Exception Connection conn = null;i

5、f (dbcp = null) Thread.sleep(long) (Math.random() * 200);synchronized (DataBaseConnectionPond.class) if (dbcp = null) dbcp = new DataBaseConnectionPond();try conn = dbcp.GetConnettion(); catch (Exception e) return conn;该类在整个项目部署的过程中只实例化了一个对象,故称单例。可以通过该类的static函数getConnection()获取连接。3、Dao(Data Access

6、Object)的模板化实现,使用了模板方法模式(来自GoF提出的设计模式):/SqlExecute.javapackage library.execute;import java.sql.Connection;import library.util.*;/作者:赵伯涛public abstract class SqlExecute public Connection conn;public Object result;public abstract void setExecute() throws Exception;public Object execute() try conn = Dat

7、aBaseConnectionPond.getConnection();conn.setAutoCommit(false);setExecute();mit(); catch (Exception e) try conn.rollback(); catch (Exception ee) e.printStackTrace(); finally try conn.close(); catch (Exception e) return result;该类是一个抽象类,必须通过继承该类来实现具体的功能,其中的execute()函数是一个模板方法,将try-catch-finaly、获取connect

8、ion及connection的事务处理提取出来,具体Dao的功能应该写在setExecute()函数中,在具体实现Dao的功能的时候可以不用重复这些代码,方便程序员编码,也方便程序员维护程序。下面举例使用这个模板类:/ReaderChangePasswordDao.javapackage library.dao;import java.sql.PreparedStatement;import library.execute.SqlExecute;import library.model.ReaderModel;/作者:赵伯涛public class ReaderChangePasswordDa

9、o extends SqlExecute private ReaderModel rm;/ 传入 readerID, password, password2(旧密码)/ 返回 影响行数public ReaderChangePasswordDao(ReaderModel rm) this.rm = rm;Overridepublic void setExecute() throws Exception String sql = update Readers set password = ? where readerID = ? and password = ?;PreparedStatement

10、 ps = conn.prepareStatement(sql);ps.setString(1, rm.getPassword();ps.setInt(2, rm.getReaderID();ps.setString(3, rm.getPassword2();this.result = ps.executeUpdate();上面的类继承了SqlExecute类,重写了它的setExecute()函数,通过构造函数传入操作时需要的参数,在写代码的时候可以更加专注于数据库的操作,因为其它操作由模板类做好了。这对写一个数据库操作或许没什么大不了的,但是一个项目里边数据库操作肯定是几十个,几百个,甚至

11、几千个,使用模板类减少的编码量是非常客观的。下面举例使用ReaderChangePasswordDao类:/来自UserCommonService.java的部分代码/ 读者修改密码public boolean readerChangePassword(int readerID, String newPassword,String oldPassword) ReaderModel rm = new ReaderModel();rm.setReaderID(readerID);rm.setPassword(newPassword);rm.setPassword2(oldPassword);Rea

12、derChangePasswordDao rcpd = new ReaderChangePasswordDao(rm);int count = (Integer) rcpd.execute();if (count 0) return true; else return false;注意:使用Dao的时候调用的应该是它的execute()方法(在抽象类中)。4、时间显示var cTime=new Date();/初始化日期var myYear=cTime.getFullYear();/年var myMonth=cTime.getMonth()+1;/月var myDate=cTime.getDate();/日/获得时分秒var myHour=cTime.getHours();/时var myMinute=cTime.getMinutes();/分var mySecond=cTime.getSeconds();/秒if(myHour 10)/判断如果时钟小于10就显示两位,前一位用0代替myHour = 0 + myHour;if(myMinute 10)/判断如果分钟小于10就显示两位,前一位用0代替myMinute = 0 + myMinute;if(mySecond 10)/判断如果分秒钟小于10就显示两位,前一位用0代替

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > PPT模板库 > 总结/计划/报告

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号