图书管理系统的设计与开发

更新时间:2024-07-01 10:05:02 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

学生实验报告书

实验课程名称 开课学院 指导教师姓名

学生姓名 学生专业班级

电子商务应用技术开发

经济学院 傅魁

梁少晴 0121415710101 姜雨竹 0121415710229 阮筱钰 0121415710230 电商1401 电商1402

1

目录

一、系统概述???????????????????????????(3) 二、系统需求分析?????????????????????????(3) 三、系统总体设计?????????????????????????(6) 四、详细设计???????????????????????????(9) 五、页面设计及编码实现??????????????????????(15) 六、测试分析报告?????????????????????????(50) 七、结束语????????????????????????????(56)

图书馆管理系统

一、 系统概述 1.1

系统开发背景和意义

图书管理是每个高校必须切实面对的工作,但如今许多高校的图书馆管理系统还

2

停留在以CS为结构的系统上。随着internet的应用日趋广泛,以及高校内、高校与高校间信息的交流日趋密切,以CS为结构的信息管理系统以不能满足需求,所以,高校图书馆管理系统必须通过更新换代,将BS为结构的系统改为以CS为结构的系统,这样会大大提高系统的维护性以及系统应用的广泛性。

由于图书这用特殊的物品,其表现在数据量非常庞大,所以对数据库的要求比较严格,由于oracle数据库其检索迅速、查找方便、可靠性高、保密性好,所以,选择oracle数据库为其存取数据。

随着java技术在internet上的广泛应用以及java安全性高、执行效率高的优点,同时,java可以在任意平台上应用,所以可以任意组合硬件和操作系统,既可以在windows下开发,部署在linux下,极大了节省了操作系统的费用以及硬件的费用。 1.2 开发环境 硬件环境:

服务器端/客户端:

处理器:Inter Pentium3以上 内存:512M以上推荐1G或更高 硬盘空间:80G以上 软件环境:

服务器端/客户端:

操作系统:Windows XP/Linux

浏览器:Internet Explore7.0以上 开发工具:MyEclipse+Tomcat7.0+MySQL

在MyEclipse集成环境下进行图书管理员系统的界面设计和程序开发,在系统的后台采用MySQL作为数据库支持,使用时打开浏览器。在地址栏中输入网址回车后即可进入图书管理员系统的主页,进行相应的操作。 二、 系统需求分析 2.1 任务概述

1.新书购进后,进行分类、同一编码和入库。 2.学生借阅图书后,记录相关信息。

3. 学生归还时,对比查看该书是否超期,超期后,按规定罚款。 根据以上调查分析,给出业务流程图,如图:

3

2.2 数据描述(数据流图+数据字典)

经过调查,我们了解了基本的业务程序,接下来给出系统的逻辑模型。构造系统的逻辑模型的工具主要是数据流图和数据字典,下面给出图书馆管理系统的基本模型,如图:

根据基本模型,对其逐步细化,得到数据流图,如图:

根据系统流程图,通过数据字典对数据进一步描述: 图书:图书表结构 描述:记录图书的相关信息 定义:图书信息表 图书编号、图书名称、ISBN号、作者、出版社、类型、价格、库存量、副本存量、总量 位置:LibWeb表空间

4

借书登记:借书登记表结构 描述:记录图书的借阅信息 定义:借阅登记表 借阅编号、学生编号、图书编号、借阅时间、归还时间、是否归还 位置:LibWeb表空间 学生信息:学生信息表结构 描述:记录学生信息 定义:学生信息表 学生学号、学生姓名、性别、入校时间、毕业时间 位置:LibWeb表空间 归还登记:归还登记表结构 描述:记录所有已归还图书的借阅情况 定义:归还信息表 编号、图书名称、归还时间、归还学生编号、归还学生姓名 位置:LibWeb数据空间 用户信息:用户表结构 描述:记录所有用户 定义:用户信息表 账号、真实姓名、密码、描述 位置:LibWeb数据空间 角色信息:角色表结构 描述:记录所有角色 定义:角色信息表 角色名称、角色描述 位置:LibWeb数据空间 2.3 功能需求

经过以上详细的调查和分析,在数据流程和数据分析的基础上,确定达到的功能为一下几点:

5

新书入库登记:对与需求入库的书籍,进行数据登记,确认后书籍入库。 图书信息的查询和修改功能:当图书资料发生变化、当图书丢失,应立即修改信息。

图书借阅和归还登记:学生借阅图书时需要登记,学生归还图书时也需要登记。

学生的增加、修改、删除等:新生入学时的信息和直接导入。 用户的增加、修改、删除等:用户可根据权限来操作。 2.4 性能需求

为了保证系统能够长期、高效、安全、稳定、可靠的运行,图书馆管理系统应满足一下性能需求:

1.系统处理数据的准确性和及时性:

系统处理的准确性和及时性是系统的必要性能。在系统设计阶段,就应该充分考虑到,包括数据存储量、访问量等,是系统能够满足图书管管理系统对数据的处理量。 2.系统的开放性和系统的可扩充性:

可扩充性是系统健壮性的重要体现,系统开发中应充分考虑到系统的可扩充性。可扩充性包括系统设计和测试阶段的扩充以及系统使用后的扩充。任何系统在开发阶段对需求都是完全明确的,即使系统交付使用后,用户也会提出增加功能,所以,在系统设计阶段就应该考虑到系统的可扩充性。 3. 系统的易用性和易维护性:

图书馆管理系统由图书馆管理员和学生使用,而使用者对系统结构并不了解,这就要求系统提供良好的用户接口和友好的界面设计。要实现这一点,要求操作简洁明了,数据校验通俗易懂。 4. 系统的响应速度:

图书管管理系统的响应速度要求比较高,这就需要从一下几个方面入手解决:校园网的带宽、数据库的快速稳定、SQL语句执行的高效率、浏览器的选择。无论是哪方面,都会影响系统的响应速度,所以,图书馆管理系统能够拥有快速的响应速度,必须做好其中的没一点。

三、 系统总体设计

系统架构设计:

本系统的整体架构如图所示,从逻辑上来看主要分为三层:模型层、控制层、视图层。

6

1.1

业务流程

根据需求分析,以及反复的研究和探讨,确认其流程图如下:

根据流程图,现具体功能描述如下:

1.用户登录:系统对用户的合法性进行校验,登录后,系统会根据用户所拥有的权限来分配权限。

2.书籍入库:填写书籍信息,可通过excel批量导入到数据库中。 3.图书借阅:对已经入库的数据,学生可借阅。 4.图书归还:对已经归还的书籍进行登记。

5.管理措施:对定义系统规定的超期时间、超期处罚办法、丢失赔偿办法。 3.2 系统功能模块图

依据需求分析阶段得到的数据流图,在保证系统基本功能的前提下,结合系统设

7

计流程,给出系统功能模块图,如图:

3.3 系统的流程图

四、详细设计

8

4.1 程序流程图

该设计阶段的任务是根据需求具体实现所需要的程序。经过这个阶段的设计,应该得出目标系统的精确描述,从而在系统实现阶段可以把这个描述直接翻译某种程序设计语言书写的程序。总体来说就是把各个模块的细节加以描述。

由于本系统采用的是j2ee来设计程序,java是面向对象的变成语言,所以给出系统的主程序流程图,如图:

4.2 程序输入输出描述 4.2.1 用户角色模块

1.输入项目:用户相关信息、角色相关信息 2.输出项目:相应的页面 4.2.2 学生管理模块

1.输入项目:用户相关信息、角色相关信息 2.输出项目:相应的页面 4.2.3 图书管理模块

1.输入项目:图书相关信息

9

2.输出项目:图书信息 4.2.4 借阅管理模块

1.输入项目:学生学号、图书编号 2.输出项目:借阅信息页面 4.2.5 归还管理模块

1.输入项目:学生学号、图书编号 2.输出项目:归还信息页面 4.3 程序接口描述 4.3.1 外部接口

由于该系统可以部署在任何操作系统,且系统界面采用浏览器方式实现,所以该系统是跨平台、跨操作系统的。

4.3.2 内部接口

通过面向对象程序设计模式实现低耦合高内聚的程序设计思想,通过与数据库之间的数据交换,实现对数据的处理和保存。

4.4 数据库的设计 4.4.1 数据库的逻辑设计

在需求阶段已经完成该系统所有的数据分析。根据该阶段建立的概念模型,已经得出满足系统设计要求的几个关系描述,该阶段的主要工作就是把前一阶段的成果转化为具体的数据库。下面给出概念结构设计的E-R图,如图所示:

图(一)

图(二)

10

图(三) 实体:

图书(图书编号,书名,作者,出版社,定价,图书类别,图书ISBN号,图书存量)

学生(学生学号,学生姓名,性别,入校时间,毕业时间) 用户(用户名,真实姓名,密码,描述) 角色(角色名,角色描述)

序号 1 1 2 3 4 5 6 字段名称 id bookId name ISBN author 字段说明 类型 id 编号 名称 ISBN 作者 位数 属性 备注 和数据字典相关 7 8 9 10 11 12 price 价格 number 10 可为空 number 10 可为空 number 19 非空 varchar 50 非空 Varchar 100 非空 varchar 50 可为空 varchar 100 可为空 varchar 100 可为空 number 2 可为空 publisher 出版商 type 类型 storeQuan 存量 leftQuan 副本存量 number 10 可为空 number 10 可为空 非空 可为空 totleQuan 总量 createTime 创建时间 date operateTim修改时间 date e 13

creator 创建者 number 19 非空 11

14 15 16 operate status version 操作人 状态 版本 number 19 可为空 varchar 1 number 非空 非空 N or Y 图书信息表 序号 1 2 3 4 5 6 7 8 字段名称 id userId bookId broTime retime ifReturn 字段说明 类型 编号 number 位数 10 10 50 1 属性 非空 非空 非空 可为空 可为空 非空 非空 可为空 备注 用户编号 number 图书编号 varcher 结束时间 date 还书时间 date 是否归还 number createTime 创建时间 date operateTim修改时间 date e 9 10 11 12 creator operate status version 创建者 操作人 状态 number number varchar 19 19 1 非空 可为空 非空 N or Y 图书归还登记表 序号 1 2 3 字段名称 id 字段说明 id 类型 number date date 位数 19 属性 非空 非空 可为空 备注 createTime 创建时间 operateTime 修改时间 4 5 6 7 8 9

creator operate status version name relName 创建者 操作人 状态 版本 用户名 真实姓名 number number 19 19 非空 可为空 非空 非空 非空 可为空 N or Y varchar 1 number varchar 60 varchar 60 12

11 12 password description 密码 描述 varchar 64 varchar 1024 非空 可为空 用户表 序号 1 2 3 字段名称 id 字段说明 id 类型 number date date 位数 19 属性 非空 非空 可为空 备注 createTime 创建时间 operateTime 修改时间 4 5 6 7 8 12 creator operate status version name description 创建者 操作人 状态 版本 角色名 number number 19 19 非空 可为空 非空 非空 非空 非空 N or Y varchar 1 number varchar 32 varchar 1024 角色表 序号 1 2 3 字段名称 id 字段说明 id 类型 number date date 位数 19 属性 非空 非空 可为空 备注 createTime 创建时间 operateTime 修改时间 4 5 6 7 8 12 8 12

creator operate status version stuId name sex addTime 创建者 操作人 状态 版本 学生编号 学生姓名 性别 入学时间 number number 19 19 非空 可为空 非空 非空 非空 非空 非空 非空 N or Y varchar 1 number varchar 50 varchar 100 number date 13

1 12 endTime 毕业时间 date 非空 学生表

图书表

用户表 五、页面设计及编码实现

UI页面设计

14

系统登录

用户注册

15

注册成功

图书管理员登录主界面

16

编辑书目信息

编辑书目信息

17

删除操作

图书管理参数维护主界面

18

图书管理参数编辑

删除操作

19

图书借阅审批主界面

图书借阅审批界面

20

审批完成界面

图书类型管理主界面

21

图书类型编辑

删除操作

22

图书条码管理主界面

图书条码编辑

23

删除操作

菜单管理主界面(系统管理)

24

菜单编辑界面

删除操作

25

登录后主页面

示例代码如下所示:

1)注册代码:package servlet;

import java.io.IOException; import java.io.PrintWriter; import java.sql.SQLException;

import javax.servlet.ServletException; import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;

import bean.userBean;

import dao.user;

31

public class ZhuceServlet extends HttpServlet {

/**

* Constructor of the object. */

public ZhuceServlet() { super(); }

/**

* Destruction of the servlet.
*/

public void destroy() {

super.destroy(); // Just puts \ // Put your code here }

/**

* The doGet method of the servlet.
*

* This method is called when a form has its tag value method equals to get. *

* @param request the request send by the client to the server * @param response the response send by the server to the client * @throws ServletException if an error occurred * @throws IOException if an error occurred */

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException { }

/**

* The doPost method of the servlet.
*

* This method is called when a form has its tag value method equals to post. *

* @param request the request send by the client to the server * @param response the response send by the server to the client * @throws ServletException if an error occurred * @throws IOException if an error occurred */

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

32

String name=request.getParameter(\ String pwd=request.getParameter(\ user test=new user(); try {

userBean user=test.check(name); if(user==null){

userBean user1=new userBean(name,pwd); test.register(user1); response.sendRedirect(\ }else{

response.sendRedirect(\ }

} catch (Exception e) {

// TODO Auto-generated catch block e.printStackTrace(); }

}

/**

* Initialization of the servlet.
*

* @throws ServletException if an error occurs */

public void init() throws ServletException { // Put your code here } }

2)登陆代码: package servlet;

import java.io.IOException; import java.io.PrintWriter; import java.sql.SQLException; import java.util.List;

import javax.servlet.ServletException; import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;

import dao.library; import dao.user;

import bean.libraryBean;

33

import bean.userBean;

public class LoginServlet extends HttpServlet {

/** * */

private static final long serialVersionUID = 1L;

/**

* Constructor of the object. */

public LoginServlet() { super(); }

/**

* Destruction of the servlet.
*/

public void destroy() {

super.destroy(); // Just puts \ // Put your code here }

/**

* The doGet method of the servlet.
*

* This method is called when a form has its tag value method equals to get. *

* @param request the request send by the client to the server * @param response the response send by the server to the client * @throws ServletException if an error occurred * @throws IOException if an error occurred */

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

response.setContentType(\ String name=request.getParameter(\ String pwd=request.getParameter(\ //userBean user = new userBean(name,pwd); user test=new user(); try {

userBean user = test.check(name); if (user!=null){

34

if (pwd.equals(user.getPWD())){

library bookinfo=new library();//Dao涓殑library List list=bookinfo.selectall(); request.getSession().setAttribute(\

// response.sendRedirect(request.getContextPath() + \

request.getRequestDispatcher(\ }else{

response.sendRedirect(\ } }else{

response.sendRedirect(\ } } catch (Exception e) {

// TODO Auto-generated catch block e.printStackTrace(); } }

/**

* The doPost method of the servlet.
*

* This method is called when a form has its tag value method equals to post. *

* @param request the request send by the client to the server * @param response the response send by the server to the client * @throws ServletException if an error occurred * @throws IOException if an error occurred */

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

response.setContentType(\ doGet(request,response); }

/**

* Initialization of the servlet.
*

* @throws ServletException if an error occurs */

public void init() throws ServletException { // Put your code here } }

35

2.系统首页设计及实现 登录后主页面

3.图书管理模块设计及实现

图书管理员登录系统后可以进行图书管理,图书管理模块包含了图书增、删、改、查管理和图书管理参数等子功能。下面分别进行介绍: 图书的增、删、改、查管理截图如下所示: 1) 添加图书信息

36

2)删除图书信息

3)以图书类应编号为主键,修改图书信息:

37

4)输入书名,查询图书信息:

38

示例代码如下所示: 1)增加代码: package servlet;

import java.io.IOException; import java.sql.SQLException;

import javax.servlet.ServletException; import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;

import bean.libraryBean; import dao.library;

public class AddBookServlet extends HttpServlet {

/**

* Constructor of the object. */

public AddBookServlet() { super(); }

/**

* Destruction of the servlet.
*/

public void destroy() {

super.destroy(); // Just puts \ // Put your code here }

39

public void doPost(HttpServletRequest request, HttpServletResponse response) {

library library = new library();

libraryBean book = new libraryBean(request.getParameter(\ request.getParameter(\

Integer.parseInt(request.getParameter(\ request.getParameter(\

Integer.parseInt(request.getParameter(\ Integer.parseInt(request.getParameter(\ try {

library.add(book);

request.getRequestDispatcher(\response);

} catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (Exception e) {

e.printStackTrace(); } }

/**

* Initialization of the servlet.
*

* @throws ServletException if an error occurs */

public void init() throws ServletException { // Put your code here } }

2)删除代码: package servlet;

import java.io.IOException; import java.io.PrintWriter; import java.sql.SQLException;

import javax.servlet.ServletException; import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;

40

本文来源:https://www.bwwdw.com/article/oec.html

Top