23JavaWeb课程设计-图书馆管理系统刘娜_第1页
23JavaWeb课程设计-图书馆管理系统刘娜_第2页
23JavaWeb课程设计-图书馆管理系统刘娜_第3页
23JavaWeb课程设计-图书馆管理系统刘娜_第4页
23JavaWeb课程设计-图书馆管理系统刘娜_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、潍坊科技学院Java Web课程设计报 告 书设计题目 图书管理系统 专业班级 11级软件1班 学生姓名 刘娜 学 号 201101080011 指导教师 日 期 2013.6.32013.6.28 成 绩 课程设计任务书院系:中印计算机软件 专业:软件技术 班级:11软1 学号:201101080011目录正文部分1引言 1.1课程设计目的1.2课程设计背景相关技术Spring框架Struts2框架Hibernate框架需求分析系统功能需求系统开发运行环境总体设计系统体系结构设计系统功能模块设计系统主要JSP页面设计数据库设计系统实现系统运行界面主要代码 5.效果截图课设总结参考文献一、实验

2、目的。1、在实践中巩固本学习所学的JavaWeb技术。2、在实践中初步使用设计模式(GoF),体验设计模式带来的好处。3、配合数据库的使用,实现一个功能完善的小型系统。二、实验内容。开发一个图书管理系统,实现图书馆的各种管理操作。如图书入库、作废,借书证提供、挂失处理,图书的借出、归还、续借、丢失以及超期处理。s三、数据库设计。根据业务逻辑设计出数据库。表结构及关系如下图:数据库导入文本保存在DataBaseSQL.txt文档中,数据库数据保存在Data.txt文档中。四、技术性代码。(本实验的代码在Library.zip中)1、tomcat数据库连接池技术。在tomcat中的配置文件serv

3、er.xml文件中配置项目Context标签,再加入Resource标签:以上代码配置了数据库驱动,数据库地址,数据库用户名、密码,默认提供的连接数,最大提供的连接数,最长等待时间等参数。2、Java中从连接池获取连接的类,使用了单例模式(来自GoF提出的设计模式):/ DataBaseConnectionPond.javapackage library.util;import java.sql.Connection;import javax.sql.DataSource;/作者:赵伯涛public class DataBaseConnectionPond private static Dat

4、aBaseConnectionPond 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/jdbc/webdb);public Connection GetConnettion() throws Exception return ds.getConnecti

5、on();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 = new DataBaseConnectionPond();try conn = dbcp.GetConnettion(); catch (Exception e) return

6、 conn;该类在整个项目部署的过程中只实例化了一个对象,故称单例。可以通过该类的static函数getConnection()获取连接。3、Dao(Data Access Object)的模板化实现,使用了模板方法模式(来自GoF提出的设计模式):/SqlExecute.javapackage library.execute;import java.sql.Connection;import library.util.*;/作者:赵伯涛public abstract class SqlExecute public Connection conn;public Object result;pu

7、blic abstract void setExecute() throws Exception;public Object execute() try conn = DataBaseConnectionPond.getConnection();conn.setAutoCommit(false);setExecute();mit(); catch (Exception e) try conn.rollback(); catch (Exception ee) e.printStackTrace(); finally try conn.close(); catch (Exception e) re

8、turn result;该类是一个抽象类,必须通过继承该类来实现具体的功能,其中的execute()函数是一个模板方法,将try-catch-finaly、获取connection及connection的事务处理提取出来,具体Dao的功能应该写在setExecute()函数中,在具体实现Dao的功能的时候可以不用重复这些代码,方便程序员编码,也方便程序员维护程序。下面举例使用这个模板类:/ReaderChangePasswordDao.javapackage library.dao;import java.sql.PreparedStatement;import library.execute

9、.SqlExecute;import library.model.ReaderModel;/作者:赵伯涛public class ReaderChangePasswordDao extends SqlExecute private ReaderModel rm;/ 传入 readerID, password, password2(旧密码)/ 返回 影响行数public ReaderChangePasswordDao(ReaderModel rm) this.rm = rm;Overridepublic void setExecute() throws Exception String sql

10、= 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(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(

12、);rm.setReaderID(readerID);rm.setPassword(newPassword);rm.setPassword2(oldPassword);ReaderChangePasswordDao rcpd = new ReaderChangePasswordDao(rm);int count = (Integer) rcpd.execute();if (count 0) return true; else return false;注意:使用Dao的时候调用的应该是它的execute()方法(在抽象类中)。五、效果截图六、实验心得。通过本次实验,我们不单单巩固了我们的Jsp技术,同时业务逻辑能力得到了提高,能通过业务逻辑设计一个数据库,并且在实现业务逻辑的过程中初步使用了GoF提出的设计模式,同时也体验到它带来的好处。在共同合作开发的过程中,学会如何分工及沟通七参考文献。刘宝林。Java程序设计与案例【M】。北

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论