基于WEB和Oracle的仓库管理系统的设计与实现

攀登者ing

发布日期: 2020-07-16 16:41:57 浏览量: 2005
评分:
star star star star star star star star star star_border
*转载请注明来自write-bug.com

摘 要

仓库物品的管理是与我们的日常生活息息相关的一个重大问题。随着我国经济飞速的发展,改革开放的不断深入,企业要想在激烈的市场竞争中立于不败之地,要想继续的发展与生存,没有现代化的管理方式与方法是万万不行的,仓库管理的全面信息化、自动化则是在其中占有极其重要的地位。仓库管理信息系统则是在此需求背景下开始研制并开发的。在此篇文章中严格按照软件工程思想,设计并实现了一个仓库信息管理系统。介绍了系统从需求分析,逻辑设计,总体设计,详细设计以及系统测试、实施各阶段的主要内容和成果,包括系统结构图、业务流程图数据流程图、物理表实现及其关系、功能模块算法流程、界面设计等等。

关键字仓库;软件工程;系统开发

Abstract

Warehouse management is a major issue is closely related to our daily life. With China’s rapid economic development and the deepening of reform and opening up, the enterprise to be in an invincible position in the fierce market competition, want to continue development and survival, no modern management methods and methods is absolutely out, warehouse management and comprehensive information, automation is where you play a very important role. Warehouse management information system is started research and development in the context of this demand. This article strictly according to the software engineering, design and implementation of a warehouse management system.Introduced from requirements analysis, logic design, General design, detailed design and system testing, implementation of the content and results of each stage, including charts, business process data flow chart, functional modules algorithms, physical form and its process, interface design and so on.

Keywords: warehouse Software engineering; System development

1.绪论

现如今,计算机技术飞速发展,社会经济也在伴随着不断发展,各行各业也面临着各种各样的挑战与困难。为了能够在这个信息化的时代继续发展下去,就必须紧跟上时代的脚步。在这个计算机技术飞速发展的年代里,智能化的商品存储管理技术也在随着不断地发展。之前的那些古老的仓库管理化的方法已经难以满足现代化发展的需求,因为许多些原因,企业要想在这个现代化的社会中生存下去都必须有一个良好的仓库管理系统。仓库是每个企业都必须谨慎管理的地方,一个企业的最基本是货物,所以一个企业的货物必须得得到很好的保管,在这片竞争激烈的土地上面才能谋得一块生地。本课题正是根据这一理念,开发了一个功能比较完善,基本能满足企业要求的仓库管理系统。

1.1 系统背景

在这个科学技术不断发展的年代里,世界已经变的越来越高科技化越来越智能化,一个智能化的时代已经到来。到现在为止,在我们生活的周围你可以随处见到各种各样的智能化管理的系统[7]。

一个企业所拥有的商品是他所生存发展的根本,而仓库是企业用来保存商品的所在。所以说,一个好的仓库对于企业来说占有举足轻重的地位。总而言之,一个成功的企业必定会有一个好的仓库,但是一个好的仓库没有一个合理的管理系统是不完美的[7]。可是一个静态化的简单的仓库管理的系统,因为他不具备信息共享的功能,而且还不能够保证货物的正常运转中所遇到的一些问题,还不能保证企业所拥有资源的正常的运转与利用;还有一些传统的仓库管理系统在维护时非常的困难开发起来也是十分复杂,所以在人力物力上有极大的浪费,已经远远的脱离了时代的轨道。因此,一个成功的企业,如果拥有了一个现代化的仓库管理的系统,会大大的提高企业生产的效率,降低使用的成本。

1.2 开发目的

仓库是所有企业都不可缺少的部分,对于一个成功的企业来说,想要在未来的市场中获得发展得优势,拥有一个完善的仓库管理系统是十分重要的。可是企业中的商品总是在不断地流动的,仓库中的商品也随之不断变化。所以,商品就需要不停的被记录保存。在使用传统的人工记录时存在着各种各样的问题,查询的效率低下,而且保密性不高。因此,对于一个想要不断发展的企业来说,这种人工记录的方式必须淘汰。

在现代化科技的不断发展前景之下,智能化的东西已经遍布各地,电脑更是遍布在各个角落。计算机技术的应用对库存信息进行管理与人工管理技术相比较拥有无可比拟的优势,如:添加删除快捷、安全性高、查询便捷等。

在以上这些社会与技术的背景之下,我决定开始开发了这个系统。在开发的这个系统能够保证对货物进行正确的出库与入库擦偶哦、库存控制和发货。而且,这个系统比较小维护起来简单,能够节省一定的人力物力,对企业中仓库的管理是百利的。

1.3 开发工具

1.3.1 Eclipse

Eclipse 开发工具是一款源代码完全开放的、主要用于可扩展性开发Java语言的一种开发工具。对Eclipse本身来说,他仅仅只是一种服务和框架,主要是通过一些插件与组件来组成开发的环境。主要的优势有Eclipse自身带有一种标准化的组件集合,含有Java的主要开发工具JDK。Eclipse具有十分丰富的开发环境,主要包括有超强的编码能力、拥有玩备的调试功能、发布能力与测试功能等,全部支持了Hibernet、Struts、Mybatis、JSP、Spring、SQLPlus等等的一系列的框架。

1.3.2 Oracle

oracle是一家公司的名字(甲骨文公司),世界上屈指可数的,是国际上非常大的巨型IT公司,是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989年正式进入中国市场。2013年,甲骨文已超越 IBM ,成为继 Microsoft 后全球第二大软件公司最有名的产品是DB,database,RDBMS,关系型数据库系统。

1998年9月,ORACLE公司正式发布ORACLE 8i。“i”代表Internet,这一版本中添加了大量为支持Internet而设计的特性。这一款版本为数据库的用户提供了更加全面的全方位的Java技术支持。ORACLE 8i成为第一个完全整合了本地Java运行时环境的数据库。

然后有9i,10g。在这个版本更新的最佳看点是一起加入了网格,然后是11g,现在发展到12c,c代表cloud,也是现在炒的非常火的概念。

1.3.3 PowerDesigner

在数据库的设计过程中,运用Power Designer作为数据库模型的主要的建模工具。在庞大的赛贝斯公司旗下的主要的CASE开发工具集之一就是PowerDesinger,运用这个工具的最大看点是更加快捷并且方便的对仓库管理系统进行开发,数据库开发所需要的模型与需要的经历基本全部都能实现。例如数据流程图、概念数据模型、物理数据模型等一系列的模型都可以通过使用PowerDesigner来实现,可以生产出各种各样的PC端开发出来的应用软件,也可以给系统的设计制作出系统的结构模型,也能够为一些开发团队的系统模型进行调控。Power Designer还可以跟各种现如今使用比较多的用来设计数据库的软件,比如:Power Builder,StartUML,VB等相互配合来使用,以便于用来减少开发的时间与优化系统的设计。

1.4 相关技术介绍

1.4.1 JSP技术

JSP技术使用起来是非常灵活的,可以用来便携JAVA程序的。本技术还可以用来对一些编程的动态的网页来进行封装。网页还可以访问一些在服务器端的各种资源的一些逻辑应用。JSP技术还可以将一些网页的逻辑与网页的设计和还有显示进行分离,对于一些可重用的基础的组件的开发进行支撑,更加容易的对基于Web的应用程序进行设计。

在现今,计算机技术在不断发展,Web 技术也随之不断的发展,产生了许多方法来解决动态页面的生成问题,目前用于声称动态网页的技术有CGI、ASP、PHP及JSP。JSP技术可以为做动态网页的创建提供一个更加方便快捷的方法。JSP 是Java Server Page 的缩写,是Sun 公司于1999年6月推出的新技术,该技术由Sun 公司主导,采取了了一些在电脑的软件与硬件、数据库、还有通信等领域的多个家厂家的建议与意见而一起制定出来的一种在Java与Web基础上的一种动态的网页技术。

JSP技术与之前传统的网页制作技术相比较,它有着明显的优点。JSP 不像CGI、ISAPIH 和NSAPI 那样难于编写和维护,不像PHP 那样只能适应中小流量的网站,也不像ASP 那样受到跨平台的限制,JSP 体现了当今最先进的网站开发思想。

在服务器端接收到客户端发送出来的请求时,开始运行的程序段,接下来将JSP文件中的代码还有代码在运行之后效果同时回馈给用户。通过Java文件的插入能够对数据库、网页的一系列多重的定向等运行,从而满足构建动态网页所需要的程序。JSP是Servle的一种动态表现,而且都可以通过服务器端来运行。由于能够将一个HTML文本返回给用户端,所以用户端具备浏览器就可以进行浏览。HTML程序与穿插在其内部的Java程序可以共同构建动态的JSP网页。在服务器被用户的客户端访问的时侯,能够同时处理相应的Java代码,然后将产生的HTML页面再返回给用户端的浏览器。JSP的设计关键是Servlet,通常大型的Web应用程序的设计成果也通过Java Servlet与JSP相结合来实现的。JSP既拥有了方便快捷的Java程序,又统统的面向用户,既实现了平台的无关性危险还比较小,可以具备互联网的全部优势。JSP技术的优点:

  • 能够一次性完成编写,到处运行。不包括系统在内,代码基本不需要在写

  • 系统的多平台支持。通常情况下,能够在所有情况下的全部平台上进行设计,能够安排在任一情况中,也能够在所有的情况下进行发展。相比ASP/.net来说,优点是十分明显的

  • 强大的可塑性。通过一个不大的Jar程序能够对Servlet/JSP进行运行,也能够通过很多服务器进行集群和负载平衡,甚至能够通过多台Application解决问题。单个的服务器到多个的服务器,Java展示了一个强大的功能

  • Java已经有了很多的设计方法,何况大部分工具都是没有花费的,这中间有很多都在多种平台之下顺畅的进展

  • 支持服务器端组件。只有很有力的服务器端组件才能支撑web运行,因此开发者可以在调用web页面时通过另外的开发工具来达成纷乱效用的组件,来加强系统的可操作性。JSP可以通过完善的JAVA BEANS 组件来达成纷乱的商务功能

在JSP的内部对象中会表现出来:客户端发送请求使用request,这个请求会涵盖到来自于GET/POST参数的请求; 服务器端传回客户端的回馈使用response;管理pageContext 网页的属性;session 与请求相关的会话;application servlet正在进行的内容;输送响应的输出流使用out;config代码片段配置对象;page JSP网页本身。

JSP 与ASP(Active Server Page) 的区别

从上面的基本介绍中,乍一看觉得JSP 与微软的ASP 十分相似,但事实上,两者有着本质的不同,我们主要从以下几个方面对其进行比较:

  • Web 服务器的支持:大部分的支持WEB的服务器段例如:Apache、IE、Netscape 和Microsoft IIS 等一系列服务器都可以运行JSP 。ASP的却很难再除了微软之外的平台上继续的运行与移植

  • 平台的支持:平台具有一定的独立性,所有的能够支持java程序的平台,都可以支持JSP的运行。Windows 平台可以很好的支持ASP, 但ASP 难于移植到其它平台上

  • 组件模型:JSP 所在的平台是建立在跨平台的、这上面的所有的组件都是可是重新利用的。而ASP 使用的平台却是建立在Win32的COM 组件模型之上的,所使用的组件没有JSP的灵活

  • 脚本语言:JSP是比较万能的能够灵活的使用JAVA语言或着与其他的脚本语言如javascript相互配合使用。可是ASP使用起来比较局限,只能使用Jscript 或者是VBScript两种语言来作为脚本语言,不够灵活

  • 安全性:JSP的安全模式是使用Java 的安全模型,但是ASP的安全模式使用的是Windows NT的安全模式两者各不相同

  • 与Access数据库的连接:Access 数据库在与JSP 相连接的时候使用的连接方式是JDBC连接,而Access 数据库与ASP相连接的时候使用的是Data Active Objects

  • 用户定制的标签:JSP有一个很好的功能是用户可以自己定义一个属于自己的标签库,并且可以灵活运用。然而ASP 中用户却不能自己定制标签库,原因是在 ASP 中用户是不可以对标签库进行扩充的

  • JSP 与Servlet 的区别:从某种意义上讲,JSP 并不是一种新技术,因为JSP 可以完成的工作,都可以通过编写Servlet 程序来实现。而且,JSP 页面中动态的、交互的部分最终也都是需要再编译为相对应的Servlet程序来实现。所以,可以说,JSP其实是Servlet 的一种抽象,它提供了更加方便有效的方式来编写Servlet

  • JSP 与CGI 的区别:JSP 与CGI 两者之间有一个很明显的最大的差异点,JSP在编写时与编译HTML时是很相似的两者的差异不大,在语法上有些不同只要了解JSP的语法即可,不需要对JAVA、JScripety等语言有过多的了解。而编写CGI 程序要求对脚本语言十分熟悉,因为CGI 程序基本上是用脚本语言直接写的。除此之外,在使用CGI 程序的时侯,对每一次的访问他都会进行处理,可是这样的结果会造成在多个用户的请求被处理时,会造成力不从心的局面,不会得到满意的结果。可是JSP在编译时只能编译一次,在此之后会驻留在内存中,再次调用时,不必重新处理,适于应付多用户情况

1.4.2 JavaScript技术

JavaScript语言是脚本语言中直译式的一种,属于动态类型、弱种类型、原型为基础的语言,支持类型的语言。JavaScript引擎是他的解释器语言,属于浏览器中的内容,常常用在客户端的一种脚本的语言,早期常常在HTML所编译的网站上面运用,主要的功能是在HTML的基础之上增加一些动态的功能。 在1995年时,由Netscape公司的Brendan Eich,在一个叫做网景导航者的浏览器上第一次实现而成。由于Netscape的合作者是SUN,所以在Netscape的管理层们希望把他的外观做起来像JAVA,出于种种的原因给他取名叫做JavaScript。可是在实际上多了解了解它的语法风格会发现是与Self及Scheme比较接近的。为了取得技术优势,微软推出了JScript,CEnvi推出ScriptEase,与JavaScript同样可在浏览器上运行。

为了能够将规格得到统一,因为JavaScript兼容于ECMA标准,因此,也称为ECMAScript。

JS技术特征

  • 脚本语言

  • 解释性语言

  • 弱类型语言

  • 事件驱动

  • 动态性

  • 安全性

  • 跨平台性(兼容性)

1.4.3 Tomcat

Tomcat 从一定的意义上面来说他并不只是一个APP Server, 它仅仅只是一个可以支持并且运行Serlvet/JSP 的Web 的容器,而且他还具有一些传统的Web 服务器所具有的一系列的功能。可是他跟Apache 相对比,Tomcat处理静态的HTML 的能力就比不上Apache。 因此,我们可以把Tomcat与Apache 集成到一块,然后运用Apache 处理静态HTML, 最后在利用Tomcat 处理JSP 还有Servlet。这几种技术之间相互配合。这种集成只需将Apache 和Tomcat 的配置文件作出修改就可以了。

Tomcat 也扩展了一些App Server 的功能,如JNDI, 数据库连接池,用户事务处理等等。Tomcat 被非常广泛的应用在中小规模的Java Web 应用中。在Tomcat5中,在Servlet2.3 中拥有一些事件监听器的功能我们可以利用这些功能来对事应用或者Session 等进行一些列的实行监听。Tomcat 还有好多其他的一些特征,如与SSL 集成到一块,实现安全传输。很多中小应用不需要采用EJB 等技术,JSP 和Servlet 已经足够,这时如果用应用服务器就有些浪费了,我们自然会选择Tomcat。

JSP 和Servlet的开发主要是在Tomcat的基上来进行开发的,JSP 与Servlet的开发并没有想象中的麻烦,一般的一些文本编辑器或着IDE都是可以开发的, 最后,把这些东西压缩为成WAR格式的就可以了。另外,也可以利用标签库实现Java 代码与HTML 文件的分离,使JSP 的维护更方便。

Tomcat 也可以与其它一些软件一起来实现更多的功能,如与JBoss 集起来开发EJB, 与Cocoon 集成起来开发基于XML 的应用,与OpenJMS 集成起来开发JMS 应用,除了这几种,可以与Tomcat 集成的软件还有很多。

1.4.4 软硬件需求

  • 硬件需求

    • CPU:Pentium以上计算机
    • 内存: 512M以上
  • 软件需求

    • 操作系统版本:Windows XP /vista/Win7
    • 开发工具:MyEclipse 6.0.1
    • 后台服务器:Apache Tomcat 6.0
    • 开发语言:Java
    • 浏览器:F6.0

1.5 可行性研究分析

可行性分析能够让系统用最低的开发成本来获得最高的经济效益。可行性分析目的是根据所开发系统的用户需求,明确研究方向,明确目标[1] 。通过一些社会上的调查以及一些系统的框架设计功能模块的分析,找到可行的方法。对要设计实现的仓库管理系统从技术上、经济上、操作上、法律上进行可行性研究调查,这样既能够保证信息资源的合理利用,也能够避免在设计程序过程中因失误而导致的系统错漏问题,协助我们对设计做出更加合理和可惜的抉择[6]。

对所有系统完成设计,都可能受到时间以及空间上的制衡。因此,在开始设计每一个项目的时候,我们必须对系统进行可行性需求分析,只有这样才能够降低项目所带来的危害,减少人力、物力以及财力方面的损耗。在这里简单了解一下对技术、经济、系统和发展方面的可行性分析。

可行性研究这一部分的主要目的是探讨问题是在定义阶段所确定的问题有没有可行的解,可行性研究是必须的。在这个主要的阶段是从经济可行性、技术可行性、操作可行性和法律可行性等几个可行性来讨论项目是否能够解决及是否值得去解决。通过可行性研究可以减少一些不必要的损失。

1.5.1 系统目标可行性分析

本系统可以用最小的时间、经费充分帮助仓库管理人员进行仓库货品的数量进行管理,可以对商品的类型、出入库时的数目、还有时间方面进行查询。也可以对客户使用货物查看货物,货物与供应商之间进行辅助。

1.5.2 系统的经济可行性

仓库管理系统是基于JSP技术来开发,采用的软件都是开源的,这样能够削减很多的精力和资源,降低开发成本,同时也能够提升设计的作用,所以系统在开发人力、财力要求不高,具有经济可行性。

1.5.3 系统的技术可行性

在本系统的开发包含有前端的程序开发与后台的数据库的连接与数据库的维护。对于应用程序的开发则是要使用起来比较简单上手而且要兼具各方面的功能,而对于数据库的建立和维护必须要求有一套完整的数据库、数据必须要安全稳定。本系统开发的重点就是对数据库的设计和操作。在大学对软件工程,软件测试,UML统一建模语言等课程进行过系统的了解,也能够对这些课程进行开发,能让我们能够进一步辨别、开发与检验系统。所以,本仓库管理系统系统的开发在技术方面必定是高效的。

仓库管理系统是一个数据库的管理查询系统,要求运行环境、硬件、软件不高,操作简单,完全可以运用我们的技术实现系统的功能。

1.5.4 系统的法律可行性

本系统完全是自己设计的管理系统,对于本人来说具有重大的实际意义。开发环境软件和使用的数据库都是开源代码,因此对这个系统进行开发与普通的系统软件设计存在很大不同,没有侵权等问题,在法律上完全具有可行性。

综上所述,设计一个仓库管理系统具有效率高,操作简便,降低成本等优点,是必要可行的。

2.软件需求分析

软件需求分析是开发的第一个阶段,也是软件开发周期中的一个非常重要的阶段,根本任务是确定用户对软件系统的需求。它是项目开发的基础,它确定软件系统做什么,具有什么功能性能,有什么约束条件等。在软件的需求分析阶段所得到的结果在后期的软件开发的过程中是十分重要的,经过严格评审并得到用户确认是必须经过的。

2.1 需求分析

需求分析是系统开发的首要步骤,直接影响系统整体性能和功能的最主要的步骤。系统的需求分析最重要的是对系统的可行性、性能和功能等方面进行具体地分析。不合理的需求分析,会使系统的开发环节出现许多错误和走许多弯路,导致系统开发时间长,效率低,系统质量受到影响[8]。

2.1.1 用例图

仓库管理系统分为系统管理员和客户等不同种类的用户角色。在本系统的整个的用例功能模块包括管理员管理、用户管理等模块,管理员模块的主要功能包括查看库存信息,修改信息,用户管理,产品入库,产品出库等功能,如图2-1所示为仓库管理员用例图。

用户模块的功能主要包括有库存信息的查找,用户信息的修改,用户管理等功能,如图2-2所示为客户用例图。

2.1.2 类图

仓库管理系统中有管理员、客户、还有货物三大类。如图2-3所示为仓库管理系统的三大类之间的类图关系。

2.2 功能需求分析

  • 登录验证功能:为了保证仓库管理系统信息的安全性,进入系统时需要对用户身份进行验证,如果验证无误可成功进入系统,如果用户名或者密码不正确将返回错误提示要求重新输入

  • 管理员管理功能:此功能属于系统的管理员功能,他实现了对所有用户的管理操作,可以添加一个新的用户,也可以对已经添加的业务员进行删除的操作

  • 用户的查询功能模块:此项功能属客户管理员功能,用户可以根据条件查询客户信息,也可以对客户信息进行修改

  • 仓库存储的查询管理功能:此功能属系统管理员与客户共有的功能,客户可以实现查看、入库以及出库等功能,两者都可以查看库存信息

  • 用户的信息管理模块:此项功能属于用户管理员的功能,业务员可以对自己的客户信息进行管理与修改

2.3 业务流程分析

仓库管理系统主要分为两大用户功能,两种功能所实现的功能流程如下所示。

2.3.1 管理员模块业务流程

仓库的管理员可以通过帐号和密码验证之后进行登录,登录到系统之后主要的功能是对商品与用户的信息进行管理,主要流程如图 2-4 所示。

2.3.2 客户模块业务流程分析

管理员可以通过帐号和密码进行登录,登录后的主要功能是对用户与品信息的管理,主要的功能包括查看用户信息、修改用户信息、对库存商品进行查看等。主要业务流程图如图 2-5 所示。

2.4 数据流程分析

基于对业务流程的分析,对数据流分析。

2.4.1 顶层数据流

现行的顶层数据流图如图2-6所示。

2.4.2 一层数据流图

具体分析第一层数据流图,包括有商品的管理、用户信息的管理。商品管理,主要包括用户对产品的入库操作、查询操作、出库操作等一系列的处理以及管理员对产品的管理。用户管理,管理员能对用户的信息来操作。详细流程图如图2-7所示。

2.4.3 二层数据流图

具体分析第二层数据流图,包括的功能信息有用户注册、用户登录,产品入库,产品查询,产品出库等功能。

用户注册模块数据流图如图2-8所示:

用户登录功能的数据流图如图2-9所示:

商品入库功能模块的数据流图如图2-10所示:

如图2-11所示为商品查询功能模块的数据流图:

如图2-12所示为商品出库模块的数据流图:

2.5 数据字典分析

2.5.1 数据存储条目

  • 文件名:用户信息表
    • 组成:本次刚刚注册用户 + 之前注册过的用户
    • 组织方式:索引类型的文件,以用户名为索引
    • 文件名:商品库存表
    • 组成:本次新入库商品+以前入库商品
    • 组织方式:索引文件,以商品编号为索引

2.5.2 加工条目

  • 加工名:商品存储处理

    • 编号:无
    • 输入:商品信息
    • 输出:库存信息表
  • 加工名:商品入库处理

    • 编号:无
    • 输入:商品信息
    • 输出:库存信息表
  • 加工名:商品出库

    • 编号:无
    • 输入:商品信息
    • 输出:库存信息表
  • 加工名:用户信息存储

    • 编号:无
    • 输入:用户信息
    • 输出:用户信息表
  • 加工名:用户查询处理

    • 编号:无
    • 输入:用户名
    • 输出:用户信息表
  • 加工名:用户信息验证

    • 编号:1.1
    • 输入:用户信息
    • 输出:用户信息表
  • 加工名:验证用户是否存在

    • 编号:1.2
    • 输入:用户名
    • 输出:用户信息表
  • 加工名:录入用户信息

    • 编号:1.3
    • 输入:用户信息
    • 输出:用户信息表
  • 加工名:登陆系统时的信息验证

    • 编号:2.1
    • 输入:用户名、密码
    • 输出:用户信息表
  • 加工名:个人信息查询

    • 编号:2.2
    • 输入:用户名
    • 输出:用户信息表
  • 加工名:审查商品信息

    • 编号:3.1
    • 输入:商品名称
    • 输出:商品信息表
  • 加工名:验证是否为新商品

    • 编号:3.2
    • 输入:商品名称
    • 输出:库存信息表
  • 加工名:录入商品

    • 编号:3.3
    • 输入:商品信息
    • 输出:库存信息表
  • 加工名:查询商品

    • 编号:4.2
    • 输入:商品名称
    • 输出:库存信息表

3.软件总体设计

软件系统的设计是在整个系统在实现软件开发过程中的十分重要的一个环节。本章将主要介绍一下仓库管理系统的总体结构与系统的架构[2]。总体设计的结构实际上介绍了各个模快相互产生的关系,数据库的设计主要说明了表的建立与数据之间的关系。

系统怎样实现是在总体设计阶段的阶段的基本目标。所以总体设计又被叫做为概要设计。在经历过这个阶段的工作,开发人员又将可以组成系统的物理元素,例如有文件、程序、还有数据库等。但是这些物理元素还处于黑盒子的形式。总体设计的另一项任务是设计软件的总体结构,即为了找出系统中的每一样程序都是由那些模块组成的,每个模块的功能及模块和模块之间的接口、调用关系等,但所有这些都不要求设计模块的内部过程的细节。

容易看出,软件设计的结构是基于模块之上的,根据分析阶段得到的数据流图来设计软件结构。数据流图是设想各种可能方案的基础。首先,分析员从提供的方案中选出若干个设计方案,然后对这些方案进行筛选,从而选出一个合理方案。对于复杂的大型系统要进行功能分解,为确定软件结构,把一些设十分复杂的处理功能适当地分解成一系列比较简单复杂的功能,然后在进行软件结构设计。最后制定测试计划,书写文档并复审。

3.1 软件结构设计原则

软件总体设计的任务是软件的结构体系设计与软件的模块化设计。为了提高软件设计质量,人们在长期的计算机软件开发过程中积累了丰富经验,对这些经验做出总结会进一步得出一下软件设计准则。

3.1.1 软件的结构体系

软件的体系结构是在整个软件系统中最基层的。设计准则如下:

  • 体系结构是一种抽象的结构

  • 软件的体系结构能够保持一定时间的稳定

  • 良好的体系结构意味着普通、高校和稳定

3.1.2 软件模块设计原则

在软件开发过程中,软件的模块化式设计关键,软件模块化设计需要遵循的总则如下:

  • 模块的耦合性降低,模块的内聚性要提高

  • 模块的作用范围需要能够控制

  • 模块接口设计要简单,以便降低复杂程度和冗余度

  • 设计功能可预测并能得到验证的模块

  • 适当划分模块规模,已保持其独立性

3.1.3 软件的模块化

模块是软件结构的基础,是软件元素,是能够单独命名、独立完成一定功能的程序语句的集合,如高级语言中的过程、函数、子程序等。广义的将,在面向对象的方法学中其中的对象也属于模块,模块是构成程序的基本构件,在程序设计中有很重要的地位。

模块化是使得软件能够对付复杂问题所具备的属性。使用模块化是为了使软件的复杂性能够降低,能简单的操作软件的设计、维护、还有测试。模块化技术的运用还可以防 止错误蔓延,从而可以提高系统的可靠性。关于模块可以降低软件复杂性的事实。

3.2 系统任务概述

一个成功的网站应明确为什么要建立这个网站,确定网站所拥有的功能,明确网站所有的规模、投资花费的费用等[8],了解这些都需去市场进行调查。只有经过详细的策划,才能够免去在网站的建设中出现的很多问题网站的建设才会顺利[4]。同时,一个大型的计算机网站系统,需要有一个十分明确的思想做指导,并且通过一系列合理的结构设计,就能够充分发挥出仓库管理系统的巨大优势。

在仓库管理系统系统的实现时首先我们要考虑下面几点:

  • 安全性:现在社会是一个信息的社会,信息就是宝贵的财富,保证信息的安全,特别是个人信息更加的需要安全性

  • 先进性:结合当前流行趋势,开发要符合用户的需求,适合用户进行网上预约挂号的系统。本系统采用的这些技术完全基于微软平台进行开发,从来有效的降低了系统的运营成本,大大提高了该医院预约挂号系统的稳定性和易维护性

  • 可扩展性:本系统给用户带来了极大的便利,提高了网站的管理效率,因此在开发系统的功能过程中,我们要考虑到系统的可扩展性,便于将来系统的升级、更新

  • 有效性:实际上这里所说的有效性包括了两个方面的意思,即有用性和可用性。其中有用性是指的是站点能满足用户需求的潜在功能,而可用性指的是能够通过站点来操作实现系统的体现功能。所以实现在仓库管理系统的功能时一定要尽最大的可能满足用户的需求

3.2.1 系统的功能设计

仓库管理系统主要分为两个个用户角色,主要是管理员角色与用户角色,其功能如下:

  • 管理员:管理员可以通过帐号和密码进行登录,登录到系统后主要功能是对库存信息的管理,主要包括个人信息管理、商品进行入库、出库、查询操作、客户的信息进行查看修改、退出系统等功能

  • 用户:用户可以注册登录成为会员,其中的系统功能包括系统首页,查询库存,注册登录,我的信息,退出系统等一些功能

3.2.2 系统功能结构

根据上述分析,得出的功能结构图有,如图3-1所示。

3.3 系统架构

B/S系统对客户机的工作量做了极大的简化,对数据库的访问以及应用程序的执行都将由服务器来完成。B/S架构主要使用WWW浏览器技术,根据各种基于浏览器的脚本语言。在B/S架构基础上软件结构的安装、修改与维修的需要在服务器端解决。使用该系统时,只需要一个浏览器用户可以运行所有的模块,从而实现了“零客户端”功能,很容易在运行时自动升级。B/S架构也有一个均质机,网上异构网络,异构应用服务的联机[10]。

B/S系统由以下三层构成,三层是相对独立又相互关联,在这里我们在三个层面上做一个介绍:

  • 表示逻辑层提出一个服务请求到网络上的Web服务器,并且开始验证身份,主页信息被HTTP给传送给客户端,主页文件会被客户机收到,并将主页文件信息显示在Web浏览器上

  • 用户的数据请求会被控制逻辑层接受到,数据库与程序相互连接,并进行数据处理请求的数据库服务器,然后Web服务器开始接受数据库服务器的数据处理的结果,最后再返回给客户端

  • 数据表示层接受Web服务器请求的数据库操作,以实现对数据库操作的一系列的功能, Web服务器来接收操作结果

3.4 系统主要子模块设计

在对系统的功能设计进行分析,在对系统的小模块在进行划分,即系统的模块化。建立系统的整体的结构了解模块之间的关系如何。系统的功能需求分析和企业仓库管理的有各自不同的特点。

3.4.1 用户登录子模块设计

系统中用户登录验证相对比较简单,可以将其流程概括如下:

在用户登录时,系统要求在用户名的输入框与密码的输入框输入相应的信息,然后再由系统将其传送至相应的服务器端。服务器端处理程序时,服务器会根据提交的内容将用户名中的内容以及密码框的内容进行分离,再与数据库中的数据进行比对判断。如果输入的内容能够相互匹配会进入到登录首页;若不能正常匹配则系统会跳转到报错界面。

3.4.2 商品入库子模块设计

首先,入库申请人需要向仓库管理员提交一份入库申请单和相应的货物,仓库管理员会根据所提交的清单进行对比。如果发现货物与入库申请单中的数据有所差异,那么则拒绝货物入库操作;如果发现库存中有该商品存在,还需考虑入库货物的数量加上现有的库存量是不是超过了该仓库的最大库存量,若超过则暂时禁止入库。没有超过的话,仓库的管理员进行入库操作。如果该库存中没有该商品存在,则需要重新添加该商品,计算该商品可在库存中所能存放的最大库存量,重新考虑入库货物的数量加上现有的库存量是不是超过了该仓库的最大库存量,若超过则暂时禁止入库。货物存入仓库之后,该仓库管理员需要给入库申请人开具一份货物入库单,入库单中的内容必须严谨。至此该系统的入库流程全部完成。

3.4.3 商品出库子模块设计

在进行出库操作时,首先,出库申请人需要向仓库管理员提交一份申请单。若申请单不真实,则取消出库操作,不再继续进行出库。对真实有效的出库单,仓库管理员再对照其要求出库的货物名称查询该货物的信息和库存量。如果此货物的库存量达未到所需要数量则取消出库操作。如果此货物的库存量达到所需要数量,可以执行出库操作并且记录。随后仓库管理员给该申请人开出库单据,仓库管理系统出库流程全部完成。

3.4.4 用户注册子模块设计

系统中用户登录验证相对比较简单,可以将其流程概括如下:

在用户注册时,需要在注册的页面各框中输入用户名、密码、姓名、性别、年龄、联系方式、email、联系地址等一系列信息,系统将其提交至服务器端。服务器端处理程序时,服务器根据提交的内容将用户名与其他信息进行分离判断。如果没有找到所注册的用户名,系统会进一步进行注册;当在注册的过程中有空的情况下系统会有相应的提示。在进行email注册时,在注册的栏中输入的不正确时,系统会提示出错误。当输入的内容符合要求时会继续注册。还可以选择清空,从头开始在注册一遍内容。

4.数据库设计

数据库的设计在开发的过程中占有一个十分关键的作用,在这里强调数据库重要性的作用,原因是数据库是软件开发过程的根基,前期的建设不牢固,会使得后期的建设出现大批量的问题,在后期的处理过程中会非常的困难。

通常概念设计的主要目标是设计并反映出某一个组织部门的信息需求中的要求,数据库系统通常是独立的并主要存在于:数据库系统的逻辑结构、DBMS即数据库管理系统、计算机系统等模式。

概念模式的设计方法是在需求分析的基础上,通常使用E-R模型来表示数据以和数据之间的联系,开发出能够解决用户信息要求和处理要求的数据库的模式。数据库概念设计的主要目标是能够准确的描述应用领域的信息模式,并且支持用户的不同应用,并方便转换为数据库系统逻辑模式以及方便用户理解。该模型是不能够直接的用于数据库系统的实现的,因为它主要是面向现实世界的数据模型。在此阶段,用户可以参与和评价数据库系统的设计,从而有利于保证数据库系统的设计能够满足用户的需求。

4.1 数据库概念

数据库技术从年代中期至今只有不到年的历史,但其发展速度之快是其它技术所不及的。数据库的发展已经从刚开始的网状型数据库发展到后来的的关系型数据库现如今已经变为以面向对象为主要模型的数据库。数据库技术现如今已经与网络的通信技术、现如今流行的人工智能技术以及面向对象的编程思想等技术之间互有融合,并且使得其得到了广泛的发展与应用。

数据库的原理管理方式根据的是数据结构的方式进行的管理还有存储数据的数据仓库,在本次系统中的作用主要是用来查询仓库管理系统的系统设计与实现数据的存储。使用数据库可以带来许多好处:使得数据的冗余度得到了减少,而且在一定的程度上使得数据的存储的空间得到了充分的利用,让数据资源能够最大程度的得到共享等等。尤其在最近的一些年中计算机的关系数据库的不断地发展,使得编程方面更大限度的得到便利,在处理数据的过程中更加方便快捷,操作更容易上手。

数据库设计的目的是指在特定的环境下能够在建立好的应用模式与好的应用环境之下使得用户的各种需求得到满足。

数据库在一个完整的网站中是必不可少的,原因是在网页被访问的过程中都会有数据保存下来,网站会是这些数据保存在一个文件中。可是在实际的网站建设当中,这些文件所能保存的数据往往是不够的,无法满足各种数据的需求[5]。因此一个完美的网站的建设必须拥有一个完美的数据库。我们现在可以使用的数据库有很多种,如数据库、数据库等等,在本次设计中,选择了ORACLE数据库作为后台数据库工具。自从ORACLE数据库推出一来,得到了快速的发展,很快便在应用市场中占有了十分重要的地位。在时代的不断发展过程中,ORACLE数据库已经在发展的过程中占据了牢固的地位,在下如今工作的前景之下,以数据库为背景的应用发展,为用户的应用提供了款完善的数据管理和数据分析解决方案。数据库是一种具有属于自己的结构与管理的方式数据的仓库。数据库简单来说是是属于一种文件柜电子化的一种存储工具(主要用于电子文件的存储),用户可以对其中的文件进行一定的操作。它能够把以一种属于自己的方式进行存储、而且能够使得多个用户之间的数据相互的分享、还能使得用户数据的冗余度能够最大程度的减少、在应用程序之间的各种数据能够分离。

4.2 数据库分析

数据的模型属于在数据库当中中用来存储数据的一种方式,是数据库系统的基础。

数据模型经历了:

  • 层次模型:是数据库系统中最早使用的一种模型,它的数据的结构是一棵“有向树”

  • 网状模型:网状模型以网状结构表示实体之间的联系。网中的每一个结点代表一个记录类型,联系用链接指针来实现。网状模型可以表示许多不同的联系,还能表示不同的数据之间的交流,即数据间的横向关系与纵向关系,属于扩展之后的层次模型。网状模型可以方便地表示各种类型的联系,但结构复杂,实现的算法难以规范化

  • 关系型:在关系模型中基本数据结构就是二维表,不用像层次或网状那样的链接指针

4.2.1 数据库的完整性分析

数据的正确性与数据之间的相容性即为数据哭库的完整性。用来管理数据库的系统,需要用一定的机制来检查现存的数据库中的数据是否满足规定的条件,数据的约束条件是基于仓库管理系统设计与实现语义的体现,会作为模式的一部分存入数据库之中。本系统中定义了表与表之间的联系有助于实现完整性规则,一般在程序中实现具体的完整性控制。数据库的完整性约束能够在一定的程度上防止终端的用户输入一些错误的数据,以此来保证所有的数据库中的数据都是合法的、完整的。

在设计数据库表时采用数据库完整性约束,它是数据库完整性的一种机制,他会在之前用来定制一些规则,用来约束数据库,而这些数据规则存放于数据库中,具体来说,这种约束有以下几种非空约束缺省值约束唯一性约束主键约束外部键约束规则约束。由于这种约束是加在数据库的表的定义上的,因此,不需要有大的代价便可以取得一些高的性能。

4.2.2 数据库的安全性分析

能够保证数据的网整性、合法性还有安全性是数据库重要的安全性能的指标。数据能够在数据库中大量的存放并且能够实现数据之间的共享,这都属于数据库的宝贵的资源。

数据库的安全和服务器的安全是仓库管理系统安全的重要性能。采用管理员表示和鉴定的方法实现数据库的安全,此安全管理措施并不在前台开发工具中实现,而是在后台数据库中实现。在登录数据库时,系统让管理员户表示自己的身份,不同的管理员权限不同,系统进行核实,分辨出此管理员是否能够与系统匹配,若是,系统进一步核实用户,通常要求重新输入,系统和用户重新输入的信息用来鉴别用户的身份。服务器的安全也是通过判断用户在登录服务器时输入信息是否与数据库中的信息相匹配来验证的[3]。这种方法比较容易实现,实现起来也比较方便。没有采用更加复杂的系统安全管理措施是因为本管理系统一般是应用在校园网中,采用安全管理措施主要是为了防止没有修改权限的用户无意间修改了数据,因此采用用户标识和鉴定的安全管理措施就能够保障数据库的安全性。

4.3 数据库的设计

4.3.1 概念结构设计

在次结构的设计过程当中,E-R模型法是最常见的设计方法。在次结构设计当中中,有以下几种方法方法:

  • 自下往上、从上往下、逐步扩张、相互结合,以这种方式为模型然后烦别实现各个结构的模型。

  • 在物理结构设计阶段首先分两步走:

    • 确定数据库的物理结构,是用来说明数据在数据库中怎么样存储的
    • 选取正确的关系模式存取方法有好多种方法进行选择

概念设计通常是从系统的需求出发,常常将对象使用数据流的形式表达成为完整的抽象实体。而与模块内部的细节无关。E-R图为主要的工具,如下图4-1。

4.3.2 逻辑结构设计

管理员信息关系模式,里面的主键是管理员ID

列名 数据类型 可否为空 说明
id number NOT NULL 管理员编号
account varchar NOT NULL 帐号
Password varchar NOT NULL 密码
name varchar NOT NULL 姓名
sex varchar NOT NULL 性别
age varchar NOT NULL 年龄
phone varchar NOT NULL 联系方式
email varchar NOT NULL E-mail
address varchar NOT NULL 地址

客户信息关系模式,里面的关系主键是客户ID

列名 数据类型 可否为空 说明
id number NOT NULL 客户编号
account varchar NOT NULL 帐号
password varchar NOT NULL 密码
name varchar NOT NULL 姓名
sex varchar NOT NULL 性别
age varchar NOT NULL 年龄
phone varchar NOT NULL 联系方式
email varchar NOT NULL E-mail
address varchar NOT NULL 地址

商品信息关系模式,里面的关系主键是商品编号

列名 数据类型 可否为空 说明
id number NOT NULL 库存编号
name Varchar NOT NULL 商品名称
goodsid varchar NOT NULL 商品编号
price varchar NOT NULL 商品价格
sort varchar NOT NULL 商品分类
num varchar NOT NULL 商品数量
address varchar NOT NULL 生产厂商

4.4 数据库的连接

本系统与数据库的连接方式,包括对数据库中的信息进行添加、删除、修改,都使用的数据持久化层(persistence layer)的开源框架Mybatis,它抽象了大量的JDBC冗余代码,并提供了一个简单易用的API和数据库交互。以便仓库管理人员在计算机上运行本系统时,对数据库进行必要的操作.

4.4.1 连接工具

本系统采用mybatis数据持久化层的开源框架与数据库进行连接,包括对数据库中的信息进行添加、删除、修改. MyBatis简化与实现了在变成中的数据的持久化层(persistence layer),并且它抽象出了大量的JDBC冗余代码,并提供了一个简单易用的API和数据库交互。MyBatis的前身是iBATIS,iBATIS于2002年由ClintonBegin创建。MyBatis3是iBATIS的另一个版本,而且支持注解还有Mapper。

MyBatis具有简单性和易使用性,所以,才会开始流行起来。在Java应用程序中,将从数据库查询到的数据生成所需要的Java对象;将Java对象中的数据通过SQL长期保存到数据库中,都是数据库的设计中所涉及到的。MyBatis通过抽象底层的JDBC代码,自动化SQL结果集产生Java对象、Java对象的数据持久化数据库中的过程使得对SQL的使用变得容易。

使用Mybatis的具有一下几点的优势:

  • 它消除了大量的不必要的重复代码

  • 学习和使用起来非常简单

  • 能与其他的一些数据库在一起共同使用

  • 它可以接受SQL语句

  • 具有与其他的一些框架一起使用的集成支持

  • 提供了与第三方缓存类库的集成支持

  • 引入了更好的性能

4.4.2 工厂类配置文件主要内容

  1. <Configuration>
  2. <settings>
  3. <setting name="cacheEnabled" value="true" />
  4. </settings>
  5. <typeAliases>
  6. <package name="com.briup.bean"/>
  7. </typeAliases>
  8. <environments default="develepment">
  9. <environment id="develepment">
  10. <transactionManager type="JDBC"></transactionManager>
  11. <dataSource type="POOLED">
  12. <property name="driver" value="oracle.jdbc.driver.OracleDriver"/>
  13. <property name="url" value="jdbc:oracle:thin:@localhost:1521:xe"/>
  14. <property name="username" value="briup"/>
  15. <property name="password" value="briup"/>
  16. </dataSource>
  17. </environment>
  18. </environments>
  19. </configuration>

4.4.3 Mapper类配置文件主要代码

  1. <mapper namespace="com.briup.bean.AdminMapper">
  2. <select id="selectAdminByName"
  3. parameterType="String" resultType="Admin">
  4. select * from admin
  5. where account=#{account}
  6. </select>
  7. <select id="selectAdminById"
  8. parameterType="int" resultType="Admin">
  9. select * from admin
  10. where id=#{id}
  11. </select>
  12. <insert id="insertAdmin" parameterType="Admin">
  13. <selectKey keyColumn="id" keyProperty="id" order="BEFORE" resultType="int">
  14. select admin_seq.nextval from dual
  15. </selectKey>
  16. insert into admin values(#{id},#{account},#{password},#{name},#{sex},#{age},#{phone},#{email},#{address})
  17. </insert>
  18. <update id="updateAdmin" parameterType="Admin">
  19. update Admin set account=#{account},password=#{password}, name=#{name}, sex=#{sex}, age=#{age}, phone=#{phone}, address=#{address}, email=#{email}
  20. where account=#{account}
  21. </update>
  22. </mapper>

5.软件详细设计

在软件的详细设计的这个阶段确定应该使用什么样的方式来实现整个系统使这个阶段的根本目的,通过这一阶段的具体的努力基本上能够明确整个系统所需要实现的所有的功能,具体的就是微软件结构图中每个模块确定采用的算法和块内数据结构,用某种选定的详细设计工具更清晰的描述。经过这一阶段的努力可以在编码阶段直接翻译成为源程序。

在这个阶段中,考虑到的程序代码的质量时必须注意,程序的“读者”有两个,即计算机和人。在整个软件生存周期中,软件的测试与诊断出的程序的错误还有程序错误的修改等都必须先读程序。实际上对于任何一个经常使用的软件系统,程序员在之后的过程中,读程序所花费的时间可能比写程序所花费的时间还要长的多。因此,衡量程序的质量不仅仅看他的逻辑是否正确,性能是否满足要求,更重要的是看他是否一度易理解。详细设计的目的不仅仅看他的逻辑上是否正确,性能是否满足于要求,更重要的是看他是否易读、易理解。结构化的程序设计技术是实现这些问题所使用的关键性技术,更是详细设计的基础。

在本次仓库管理系统说实现的这些基本功能。仓库管理的人员或者是客户在登录后可以进入系统使用主界面进行相应的操作。

5.1 登录模块

在本次的仓库管理系统中有两个不同的入口。仓库管理人员使用用户名和密码之后可以对应有相应的操作。用户的登录所需的用户名和密码已经在之前的用户信息表中建立,用户的个人信息由管理员提前录入或者自己注册。由于用户信息需要先从所对应的数据库中进行读取,所以在读取之前需要先于数据库进行连接。在本系统当中,有两个登陆模块的入口。如下图所示确认文件审核用户提供的用户名和密码。

管理员登录图片如下:

管理员登陆模块主要逻辑代码如下:

AloginServlet.java文件主要代码如下

  1. String account = request.getParameter("in_be");
  2. String password = request.getParameter("pass");
  3. HttpSession session = request.getSession();
  4. session.setAttribute("account", account);
  5. AdminService adminService = new AdminService();
  6. SqlSession sqlSession = MybatisSessionFactory.getSession();
  7. AdminDaoImp aDaoImp = new AdminDaoImp();
  8. try {
  9. List<Admin> fadmin = aDaoImp.findAdminByName(account);
  10. sqlSession.clearCache();
  11. sqlSession.commit();
  12. //session.close();
  13. System.out.println("用户名不存在,ADS开始注册"+fadmin);
  14. for(Admin fAdmin2:fadmin)
  15. {
  16. if( password.equals(fAdmin2.getPassword()))
  17. {
  18. response.sendRedirect("AFirstLog.jsp");
  19. session.setAttribute("Admin", fAdmin2);
  20. //System.out.println("帐号密码正确!");
  21. find=true;
  22. }
  23. }
  24. if (fadmin.size()==0) {
  25. System.out.println("用户名不存在,ADS开始注册"+fadmin);
  26. response.sendRedirect("AloginFail.html");
  27. throw new AdminServiceException("用户名不存在!");
  28. }
  29. else {
  30. if(find==false){
  31. response.sendRedirect("AloginFail.html");
  32. throw new AdminServiceException("密码错误!");
  33. }
  34. }
  35. } catch (Exception e) {
  36. // TODO Auto-generated catch block
  37. e.printStackTrace();
  38. }

5.2 入库模块

商品入库模块这是系统设计得最好最完善的模块之一。系统提供两种入库方式可供选择一次是录入库存中已经录入的商品,或者录入库存中没有录入的商品,另外添加新商品。录入已存在商品方式时,可自由选择录入某种商品。己录入的商品的信息会在相应的信息的框中显示出来。在此模块的编程中,使用了非常多的编程技巧来提供上述功能做到了与完美的配合。此种方式便于管理员掌握相应商品的情况。按商品名查询可以在选定撒谎能够品后,查询某一次或多次商品信息。

添加已有上商品模块如图5-2所示:

当有新的商品进入仓库中时,仓库管理人员需点击入库界面的“添加新商品”选项。在对现有的商品进行入库操作时,商品的信息都是重新输入的。当将新入库的商品的信息填写完毕之后,系统会自己将新入库的一些商品的信息添加到管理商品信息的数据表“goods”中。

添加新商品模块如图5-3所示:

5.3 出库模块

商品出库模块这是系统设计得最好最完善的模块之一。系统提供出库方式是在库存表中已经储存有商品基础上才能可以出库的。若是在库存中商品品的数量小于所要出库的输了时,系统会显示出库存数量不足。在进行出库的操作过程时,若是出库的商品在库存中的数量小于0时,系统会报出出库商品出错。此时都不可以正常出库。在正常出库之后,库存中商品的数量会发生改变。

在出库商品的管理模块中的主要逻辑代码如下

  1. GoodsDaoImp goodsDaoImp = new GoodsDaoImp();
  2. OutGoodsDaoImp outGoodsDaoImp = new OutGoodsDaoImp();
  3. for(Goods goods2:goods){
  4. String GoodsNum = goods2.getNum();
  5. System.out.println("goods2值为:"+goods2);
  6. Integer IntGoodsNum = Integer.valueOf(GoodsNum);
  7. Goods goods3 = goods2;
  8. System.out.println("IntGoodsNum :"+IntGoodsNum);
  9. if (IntOutNum>IntGoodsNum) {
  10. System.out.println("出库数量不足!");
  11. response.sendRedirect("OutStockFail.jsp");
  12. }else{
  13. goods2.setNum(String.valueOf(IntGoodsNum-IntOutNum));
  14. try {
  15. //goods3.setNum(String.valueOf(IntOutNum));
  16. goodsDaoImp.updateGoods(goods2);
  17. sqlSession.commit();
  18. goods3.setNum(String.valueOf(IntOutNum));
  19. outGoodsDaoImp.saveOutGoods(goods3);
  20. sqlSession.commit();
  21. } catch (Exception e) {
  22. // TODO Auto-generated catch block
  23. e.printStackTrace();
  24. }
  25. response.sendRedirect("Goods.jsp");
  26. System.out.println("出库成功!");
  27. }
  28. }

5.4 用户注册模块

在用户需要访问此系统时,用户需要在登录框中输入相应的信息,然后系统在后台服务器中与数据库进行匹配。所以在进入系统之前需要进行帐号密码的注册,在注册的过程中需要输入输入用户名、密码、姓名、性别、年龄、联系方式、email、联系地址等一系列信息,系统将其提交至服务器端。服务器端处理程序时,服务器会获取到系统提交的内容,然后系统会将获取的信息与数据库中所存储的表格中的信息进行对比,得出相应的结果。若是输入的用户名是在数据库的库存中已经存在的,系统会终止注册,然后系统会提示用户名已经被使用,请重新注册的提示。如果在进行继续注册的过程中出现某一项信息没有填写时,系统会发出此项信息没有填写请重新填写的提示。在进行email注册时,若输入的格式与系统定义的格式不匹配的情况下,系统会作出相应的警告在重新注册。若注册的信息不满足要求时,可以将信息清空再重新注册。

用户注册模块的逻辑代码如下

  1. String account = request.getParameter("in_be");
  2. String password = request.getParameter("pass");
  3. HttpSession session = request.getSession();
  4. session.setAttribute("account", account);
  5. //System.out.println("账户为:"+account);
  6. //System.out.println("密码为:"+password);
  7. AdminService adminService = new AdminService();
  8. SqlSession sqlSession = MybatisSessionFactory.getSession();
  9. AdminDaoImp aDaoImp = new AdminDaoImp();
  10. try {
  11. List<Admin> fadmin = aDaoImp.findAdminByName(account);
  12. sqlSession.clearCache();
  13. sqlSession.commit();
  14. //session.close();
  15. // /session.flush();
  16. for(Admin fAdmin2:fadmin)
  17. {
  18. if( password.equals(fAdmin2.getPassword()))
  19. {
  20. response.sendRedirect("AFirstLog.jsp");
  21. session.setAttribute("Admin", fAdmin2);
  22. //System.out.println("帐号密码正确!");
  23. find=true;
  24. }
  25. }
  26. if (fadmin.size()==0) {
  27. System.out.println("用户名不存在,ADS开始注册"+fadmin);
  28. response.sendRedirect("AloginFail.html");
  29. throw new AdminServiceException("用户名不存在!");
  30. }
  31. else {
  32. if(find==false){
  33. response.sendRedirect("AloginFail.html");
  34. throw new AdminServiceException("密码错误!");
  35. }
  36. }
  37. } catch (Exception e) {
  38. // TODO Auto-generated catch block
  39. e.printStackTrace();
  40. }

5.5 个人信息管理模块

当管理员或用户进入到主界面之后,管理员可以选择信息管理选项,会进入到用户信息的管理模块。管理员或者用户在系统中具有两项功能,第一项功能是可以对管理员或用户的个人信息进行一些列的操作。在此界面上面可以查询到用户全部的个人信息。第二项功能是能够管理全部的用户的信息。在进入信息管理模块对个人的信息可以进行查看,可以修改自己的信息。在点击修改之后会完成所对应的个人信息。

管理员信息模块图片如图5-6所示:

此信息模块的主要逻辑代码如下

  1. request.setCharacterEncoding("UTF-8")
  2. response.setCharacterEncoding("UTF-8");
  3. String account = request.getParameter("userid");
  4. String password = request.getParameter("password");
  5. String name = request.getParameter("name");
  6. String sex = request.getParameter("sex");
  7. String age = request.getParameter("age");
  8. String phone = request.getParameter("phone");
  9. String email = request.getParameter("email");
  10. String address = request.getParameter("address");
  11. Admin admin = new Admin();
  12. admin.setAccount(account);
  13. admin.setPassword(password);
  14. admin.setName(name);
  15. admin.setSex(sex);
  16. admin.setAge(age);
  17. admin.setPhone(phone);
  18. admin.setEmail(email);
  19. admin.setAddress(address);
  20. System.out.println("AInfServlet获取的信息:"+admin);
  21. SqlSession sqlSession = MybatisSessionFactory.getSession();
  22. HttpSession session = request.getSession();
  23. AdminDaoImp aDaoImp = new AdminDaoImp();
  24. try {
  25. aDaoImp.updateAdmin(admin);
  26. sqlSession.commit();
  27. session.setAttribute("admin", admin);
  28. response.sendRedirect("AInf.jsp");
  29. } catch (Exception e) {
  30. // TODO Auto-generated catch block
  31. e.printStackTrace();
  32. }

在这个模块当中,管理员可以对所有的信息进行修改,所有的用户的信息也可以被查询到。在客户的需求之下,管理员可以随意的进入到某一位客户的信息界面之下,可以对所有的信息进行管理。修改之后用户可使用最新一次更新的信息进行登录,进入主界面之后可以更新自己信息。

系统中全部的用户信息块如图5-7所示:

实现此模块的主要逻辑代码如下

  1. String password = request.getParameter("password");
  2. String name = request.getParameter("name");
  3. String sex = request.getParameter("sex");
  4. String age = request.getParameter("age");
  5. String phone = request.getParameter("phone");
  6. String email = request.getParameter("email");
  7. String address = request.getParameter("address");
  8. Customer customer = new Customer();
  9. customer.setAccount(account);
  10. customer.setPassword(password);
  11. customer.setName(name);
  12. customer.setSex(sex);
  13. customer.setAge(age);
  14. customer.setPhone(phone);
  15. customer.setEmail(email);
  16. customer.setAddress(address);
  17. System.out.println("AInfServlet获取的信息:"+customer);
  18. SqlSession sqlSession = MybatisSessionFactory.getSession();
  19. HttpSession session = request.getSession();
  20. CustomerDaoImp customerDaoImp = new CustomerDaoImp();
  21. try {
  22. customerDaoImp.updateCustomer(customer);
  23. sqlSession.commit();
  24. //response.sendRedirect("ACInf.jsp");
  25. session.setAttribute("customer",customer);
  26. response.sendRedirect("ACInf.jsp");
  27. }
  28. catch (Exception e) {
  29. // TODO Auto-generated catch block
  30. e.printStackTrace();
  31. }

6.系统的测试

系统测试是软件设计过程中最后的一部分,也是非常重要的一步。用于检查软件的质量、性能、可靠性等是否符合用户需求。一套严谨的、规范的、完善的测试过程将大大提高软件的质量、可信度、可靠性,降低软件的出错率,降低用户风险系数。

软件测试就是用户希望能够通过软件测试寻找出软件当中的一些错误,以考虑该产品能不能被广大的用户所接受。而软件测试者则是替用户受过。而今,人们已认识到,用户能够得到最为满意的产品是软件测试的最终的目的,尽可能多的发现系统的问题并改正,然后交给客户使用。

在测试的过程中主要需要实现一下几点要求:

  • 要完成并实现在前期承诺所需要实现的功能,并且在系统中的每一项功能都需要有说明书

  • 所做出来的产品的性能要得到满足

  • 产品应该能够适应所有的用户的环境

总之,软件测试的最终的目标是希望能够找出系统中所存在的一些不足与缺陷,而且要求与软件需求阶段所提出的要求相匹配。要注意的是:软件的测试并不能说明软件中没有错误,只能发现并尽可能的减少错误。

6.1 测试简述

软件测试,是在软件的完整性、安全性、正确性以及质量是否过关的一种描述。也可以说成是输出比较的一种过程。软件测试的经典定义是:在一定的条件之下来操作并使用软件,在这个过程中来发现并且找出软件自身的错误,以此来评价一个软件的质量。

在经过查询一系列的资料表明出,软件的测试工作在软件的整个开发的过程当中占有极其重大的一部分。在一些情况表明之下,如果所设计的软件关系到人的生命安全的情况下,软件的测试会变的即为的重要,并且还需要有成倍的工作量来增加测试的目的,以此来说明程序能正确的执行它应有的功能,还有表明程序没有错误。如果抱有这样的目的,就不会轻易地发现错误,从而导致选择一些不易暴露错误的例子。

6.1.1 测试目的及重要性

测试目的

系统的测试是一个在开发过程中十分重要的一个阶段。在系统的测试阶段找出程序的错误,并提高系统的性能是测试阶段的主要任务。主要目的是检验系统“做得怎样”。通过软件的测试会发现一系列的问题,还能找出问题的原因,然后再对这些问题进行修改。

Grenford J.Myers在以前提出过一下的软件问题:

  • 找出程序中尽可能多的问题

  • 设计出一个非常好的测试方案,有可能发现一些到目前为止没有能发现的错误

  • 如果能够找出之前并未发现的错误,算是设计出了一个成功的方案

  • 测试不是单独的找出错误。而是通过分析错误,来找出产生错误的原因,来避免发生错误,帮助程序员找出软件开发过程中的缺陷,以便及时进项改正

测试重要性

不管是什么技术,以及如何使用的方法,但该软件,该软件将仍然是放错了地方。为了减少引入的错误,您可以使用最新的语言,最领先的开发方法,详细的改进开发过程,可是就算是这样也不能够完全的消除软件上面的错误,还要进行详细的测试过程,以找出引入的错误,你必须通过测试误差估计密度在软件中。所有工程学科最根本的所在是一个测试,是在软件开发中占有很重要的一个部分。测试陪同,从编程本身的日子。统计显示,软件测试这个阶段所花费的成本为这个测试是30%至50%的软件开发总成本的。要是也考虑了维护的阶段,在软件开发的整个周期中,有所降低的也许是测试的成本比例,可是维护的工作,实际上是相当于对软件进行了第二次的开发,还有可能是多次,许多测试工作也一定包含在其中。

6.1.2 测试原则

在软件测试中人们所具有的经验非常重要,但人们的心理因素也更加的很重要的。根据软件测试的目标确定一些测试原则,将一些容易被人们忽视的、实际上又是显而易见的问题作为原则来加以重视,所以测试有以下几大原则。

  • 测试用力既要有合理的数据的输入,又需要有一定合理的输出结果

  • 合理的用例固然重要,但是却不能忘却一些不合理的用例

  • 检查程序时,需要检查程序该做的与不该做的事情

  • 测试的计划需要早早的开始制定

  • 测试计划、测试用例、测试报告需要进行长期的保存,以免以后出问题可以解决

  • 遵守二八原则

  • 软件的开发人员应该尽量避免不要亲自去进行测试

6.2 测试方法

测试的过程是一个执行程序的过程,即要求被测试程序能够在各种环境下运行。其实,不再记起上运行也可以发现程序的错误。为了便于区分,一般把被测程序在机器上运行称为动态测试,不再机器上运行称为静态测试,广义上讲都属于软件测试。动态分析方法又分为黑盒测试和白盒测试两种方法。以下的两种方法是即为典型的测试方法。

6.2.1 黑盒测试

黑河测试,即功能测试。他的工作重点不是考虑程序应该是怎么编写的。往往将被测试的程序看成一个黑盒,只是在软件的接口处开始进行测试,根据前期制定的需求说明,来检查所做出来的程序是否满足了所有的功能要求。程序梭边写出来的每一项功能,都能不能满足用户在输入数据之后所要达到的目的与要求。并且保持外部信息的完整性。在黑盒测试中会有以下的错误。

  • 发现一些没有实现的功能

  • 在接口上,数据能不能正确的别接收,结果是否合理

  • 性能上是否满足要求

  • 所做出来的界面是不是很清晰、美观

6.2.2 白盒测试

白盒测试,即结构化的测试,主要测试程序的内部组成。白盒测试与黑盒测试法不同,测试人员将程序视为一个透明的盒子,测试人员需要检查处理过程的中一些细微的程序,要求对程序的结构性做到一定程度的覆盖,以此来检验程序内部的一些组成。

白盒测试法也不可能完全测试,也做不到对所有的路径都挨个测试一遍。例如要测试一个循环20次的嵌套if语句,循环体中有5条路径,这样的测试程序会产生很多种情况。如果每1ms完成一条路径的测试,测试完这样的一个程序需要花费很多的时间,因此可能做到完全覆盖。

总之,无论哪种测试的方法,对于一个大的软件系统完全测试是不可能的,所以我们要找出更多更合适的方法进行测试,使得软件产品达到一定的质量标准的要求。

6.2.3 单元测试

单元测试(unit testing),对软件设计中的一些细小的结构单元进行测试。单元测试是在软件开发过程中要进行的最低级别的测试活动,软件的测试单元与其他部分相隔离的情况下进行测试。

6.2.4 集成测试

集成测试,即软件的联合测试。以单元测试为基础,把系统中所做出来的一些模块结合起来进行测试。

6.3 系统模块的测试

6.3.1 登陆模块测试

在首次进入系统时,首次进入的是登陆注册的界面,在输入的信息有效的情况下会进入到首界面。如图6-1所示为系统的登录界面的测试:

6.3.2 出库模块测试

系统在进入主界面之后会有一个出库模块的入口,在进入到出库模块时,在输入的出库数量小于库存数量商品能够进行正常出库操作,查询库存结果随之更新。出库的数量比库存中的数量躲得情况下,会跳转一个出库出错的界面,提示库存数量不足。该模块之下的测试用例如下:

在进行完出库的操作之后,如图6-5所示:

出库数量超出库存数量,以铅笔为例,出库25个如图6-6所示:

铅笔进行出库操作后库存中的信息图如图6-7所示:

用户信息模块测试:

修改后信息图如图6-9所示:

6.4.3 用户信息模块测试结果

当在操作中,进入到系统中的这个模块时,可以查看到本人的所有登录信息。可以对此模块中的所有的信息都进行修改操作,然后在对所作出的操作进行更新。

总结

基于Web的仓库管理系统在之后的市场发展中有着非常广阔的前景,会对传统的一些理念造成巨大的冲击。本文是运用了计算机学科中的两项重要的技术即计算机网络技术和数据库技术出发,分析了Web数据库及JSP技术在本次仓库管理系统中的应用。本文的主要工作如下:

  • 探讨了数据库应用系统所经历的主机/服务器—浏览器/服务器模式,重点讨论了三层结构的工作原理及其特点,其中有中间件技术(CGI和API), Java技术、JSP技术、JScript技术、Mybatis技术、PowerDesiner技术等,而且还从一定的方面评价分析了其中的优缺点

  • 探讨了怎么合理的运用在软件工程中所学习的一些基本原理去分析和设计实现仓库管理系统的过程。并对系统的开发原理、功能设计和模块的设计做出系统的分析

  • 论文中详尽的介绍了仓库管理系统的总体框架和使用的主要技术、以及功能的实现

本文通过理论联系实际,对三层架构结构上的Web数据库的不同实现方法作了详尽的分析,同时使用JSP技术开发的一个仓库管理系统。

上传的附件 cloud_download 基于WEB的仓库管理系统的设计与实现.zip ( 5.00mb, 60次下载 )
error_outline 下载需要13点积分

发送私信

55
文章数
9
评论数
最近文章
eject