1、JavaWeb课程设计图书馆管理系统刘娜潍坊科技学院Java Web课程设计报 告 书设计题目 图书管理系统 专业班级 11级软件1班 学生姓名 刘娜 学 号 201101080011 指导教师 日 期 2013.6.32013.6.28 成 绩 课程设计任务书院系:中印计算机软件 专业:软件技术 班级:11软1 学号:201101080011(1) 正文部分1引言 1.1课程设计目的1.2课程设计背景1 相关技术1.1 Spring框架1.2 Struts2框架1.3 Hibernate框架2 需求分析2.1 系统功能需求2.2 系统开发运行环境3 总体设计3.1 系统体系结构设计3.2 系
2、统功能模块设计3.3 系统主要JSP页面设计3.4 数据库设计4 系统实现4.1 系统运行界面4.2 主要代码 5.效果截图5 课设总结6 参考文献一、实验目的。1、在实践中巩固本学习所学的JavaWeb技术。2、在实践中初步使用设计模式(GoF),体验设计模式带来的好处。3、配合数据库的使用,实现一个功能完善的小型系统。二、实验内容。开发一个图书管理系统,实现图书馆的各种管理操作。如图书入库、作废,借书证提供、挂失处理,图书的借出、归还、续借、丢失以及超期处理。s三、数据库设计。根据业务逻辑设计出数据库。表结构及关系如下图:数据库导入文本保存在DataBaseSQL.txt文档中,数据库数据
3、保存在Data.txt文档中。四、技术性代码。(本实验的代码在Library.zip中)1、tomcat数据库连接池技术。在tomcat中的配置文件server.xml文件中配置项目Context标签,再加入Resource标签: 以上代码配置了数据库驱动,数据库地址,数据库用户名、密码,默认提供的连接数,最大提供的连接数,最长等待时间等参数。2、Java中从连接池获取连接的类,使用了单例模式(来自GoF提出的设计模式):/ DataBaseConnectionPond.javapackage library.util;import java.sql.Connection;import jav
4、ax.sql.DataSource;/作者:赵伯涛public class DataBaseConnectionPond private static DataBaseConnectionPond dbcp = null; private DataSource ds = null; private DataBaseConnectionPond() throws Exception javax.naming.Context ctx = new javax.naming.InitialContext(); ds = (DataSource) ctx.lookup(java:/comp/env/jd
5、bc/webdb); public Connection GetConnettion() throws Exception return ds.getConnection(); public static Connection getConnection() throws Exception Connection conn = null; if (dbcp = null) Thread.sleep(long) (Math.random() * 200); synchronized (DataBaseConnectionPond.class) if (dbcp = null) dbcp = ne
6、w DataBaseConnectionPond(); try conn = dbcp.GetConnettion(); catch (Exception e) return conn; 该类在整个项目部署的过程中只实例化了一个对象,故称单例。可以通过该类的static函数getConnection()获取连接。3、Dao(Data Access Object)的模板化实现,使用了模板方法模式(来自GoF提出的设计模式):/SqlExecute.javapackage library.execute;import java.sql.Connection;import library.util.
7、*;/作者:赵伯涛public abstract class SqlExecute public Connection conn; public Object result; public abstract void setExecute() throws Exception; public Object execute() try conn = DataBaseConnectionPond.getConnection(); conn.setAutoCommit(false); setExecute(); mit(); catch (Exception e) try conn.rollback
8、(); catch (Exception ee) e.printStackTrace(); finally try conn.close(); catch (Exception e) return result; 该类是一个抽象类,必须通过继承该类来实现具体的功能,其中的execute()函数是一个模板方法,将try-catch-finaly、获取connection及connection的事务处理提取出来,具体Dao的功能应该写在setExecute()函数中,在具体实现Dao的功能的时候可以不用重复这些代码,方便程序员编码,也方便程序员维护程序。下面举例使用这个模板类:/ReaderCha
9、ngePasswordDao.javapackage library.dao;import java.sql.PreparedStatement;import library.execute.SqlExecute;import library.model.ReaderModel;/作者:赵伯涛public class ReaderChangePasswordDao extends SqlExecute private ReaderModel rm; / 传入 readerID, password, password2(旧密码) / 返回 影响行数 public ReaderChangePass
10、wordDao(ReaderModel rm) this.rm = rm; Override public void setExecute() throws Exception String sql = update Readers set password = ? where readerID = ? and password = ?; PreparedStatement ps = conn.prepareStatement(sql); ps.setString(1, rm.getPassword(); ps.setInt(2, rm.getReaderID(); ps.setString(
11、3, rm.getPassword2(); this.result = ps.executeUpdate(); 上面的类继承了SqlExecute类,重写了它的setExecute()函数,通过构造函数传入操作时需要的参数,在写代码的时候可以更加专注于数据库的操作,因为其它操作由模板类做好了。这对写一个数据库操作或许没什么大不了的,但是一个项目里边数据库操作肯定是几十个,几百个,甚至几千个,使用模板类减少的编码量是非常客观的。下面举例使用ReaderChangePasswordDao类:/来自UserCommonService.java的部分代码 / 读者修改密码 public boolean
12、 readerChangePassword(int readerID, String newPassword, String oldPassword) ReaderModel rm = new ReaderModel(); rm.setReaderID(readerID); rm.setPassword(newPassword); rm.setPassword2(oldPassword); ReaderChangePasswordDao rcpd = new ReaderChangePasswordDao(rm); int count = (Integer) rcpd.execute(); i
13、f (count 0) return true; else return false; 注意:使用Dao的时候调用的应该是它的execute()方法(在抽象类中)。五、效果截图六、实验心得。通过本次实验,我们不单单巩固了我们的Jsp技术,同时业务逻辑能力得到了提高,能通过业务逻辑设计一个数据库,并且在实现业务逻辑的过程中初步使用了GoF提出的设计模式,同时也体验到它带来的好处。在共同合作开发的过程中,学会如何分工及沟通七参考文献。【1】 刘宝林。Java程序设计与案例【M】。北京。高等教育出版社。2004.11【2】 吴亚峰。纪超。Java SE。6.6编程指南【M】。北京。人民邮局出版社。2007.11【3】 刘精华。Java Web整合开发王者归来【M】。北京。高等教育出版社。2003.9【4】 孙伟琴。Tomcat与java web开发技术讲解(第二版)【M】北京:电子工业出版社、2009.1-220【5】 黄嘉辉java网络程序设计【M】北京。清华大学出版社。2002:445-470
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1