仓库管理系统+JAVA源代码++设计说明_第1页
仓库管理系统+JAVA源代码++设计说明_第2页
仓库管理系统+JAVA源代码++设计说明_第3页
仓库管理系统+JAVA源代码++设计说明_第4页
仓库管理系统+JAVA源代码++设计说明_第5页
已阅读5页,还剩37页未读 继续免费阅读

下载本文档

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

文档简介

计算机与通信学院本科生毕业设计说明书仓库管理系统作 者: 曹亚磊学 号: 05240207专 业: 计算机科学与技术班 级: 05级软件工程 (2)指导教师: 曹来成答辩时间: 2009年6月仓库管理系统StorageManagementSystem曹亚磊( CaoYalei)05240207前言随着科学技术的不断发展 ,我们的社会已经进入了一个信息化的社会,人们每天都要接收大量的信息和处理大量的数据,仅靠传统的纸和笔已不能适应这个时代的要求,人们必须采取新的手段 ,于是信息技术进入我们的生活,计算机不再是简单的计算工具,它已成为我们生活中处理大量信息的不可或缺的手段。在当今产业竞争越来越激烈的信息时代,企业经营除了降低成本,提高品质外,更需要以先进的管理理念来整合企业内部与外部资源。仓库管理系统正是在这个背景下产生的。本系统正是针对仓库部门的货物信息管理,通过对仓库基本信息、出入库信息等的系统界面设计,将会给管理者带来极大的方便,具有手工管理无法比拟的优点,例如检索速度快、查找方便、可靠性高、存储量大、使用时间长等。用计算机管理取代传统的手工操作,大大减少了管理人员的工作量,提高了工作效率,为获取详细的管理信息提供了保证,方便各类人员的查询和信息保证,增强了管理工作的时效和人员主动性。仓库管理主要摆阔两方面:一是仓库的基本信息,涉及人员信息、库房信息、供货商信息、客户信息;另一项是仓库业务管理,包括入库管理、在库管理、出库管理、报表管理。在本系统中侧重实现仓库的基本信息管理。摘要仓库管理系统是为了实现企业产品管理的系统化、规范化和自动化,从而提高企业管理效率而设计的。它完全取代了原来一直用人工管理的工作方式,避免了由于管理人员的工作疏忽以及管理质量问题所造成的各种错误,为及时、准确、高效的完成仓库管理提供了强有力的工具和管理手段。仓库管理系统是一个中小型数据库管理系统,它界面美观、操作简单、安全性高,基本满足了仓库管理的要求。整个系统由基本信息、单据中心、查询统计、报表打印、维护设置、帮助等模块组成。本系统是在以MySql作为后台数据库,以J2EE为编程语言来开发的。仓库管理系统在运行阶段,效果好,数据准确性高,提高了工作效率,同时也实现了仓库管理计算机化。关键词:仓库;管理系统;数据库AbstractTheadministrativesystemofthewarehouseisdesignedforrealizingthesystematization,standardizationandautomizationofenterprise'sproductsmanagementandimprovingefficiencyofenterprisesmanagement.Itcompletelyreplacestheworkingwayofartificialmanagementoriginally,preventsfromvariouskindsofmistakesbecauseofadministrativestaffneglectandthequalityproblemofmanagementandofferespowerfultoolandmanagementwaytocompletstorehousemanagementforprompt,accurate,high-efficient.Theadministrativesystemofthewarehouseisamediumandsmall-scaledatabasemanagementsystem,ithasnotonlybeautifulinterface,butalsothehighsecurityandthesimplyoperation,andmeetthedemandforstorehousemanagementbasically.Wholesystemismadeupbybasicinformation,documentinthecenter,inquirestatistics,reportformtype,setuptomaintainandmoduleofhelpingetc.TheWarehouseadministrativesystemisdesignedwithregardingMySqlasthebackstagedatabaseandregardingJ2EEasprogramminglanguage.Theadministrativesystemiseffectual,thehighdataaccuracyduringthecourseofoperating,improvesworkingefficiencyandrealizescomputerizationforstorehousemanagementatthesametime.Keyword:TheWarehouse;AdministrativeSystem;TheDatabase摘要 ABSTRACT 第1章绪论 第2章需求分析 仓库管理系统概述 系统流程图 数据流程图 仓库管理系统的角色定义 第3章总体设计 总体用例图 4用例说明 用户从浏览器登录 供货商信息查询用例概述 供货商信息修改用例概述 供货商信息添加用例概述 3.3功能模块图 第4章详细设计 ER图 数据库设计 数据库的逻辑设计 运行环境 第5章编码 登陆的实现 登陆action 舂陆过滤器 舂陆DAO 供傍商的实现 供货商查询Action 供货商修改Action 供傍商添加Action 供货商DAO 第6章测试 舂陆测试方案 数据录入测试 杳询测试 测试结论 第7章使用说明 系统功能简介 运行环境简介 系统运行与操作指南 操作,M示 特色介绍 第8章总结 参考文献 致 词t 翻译资料原文 翻译资料译文 第1章绪论仓库管理系统是现代仓储企业进行货物管理和处理的业务操作系统。它可以实现本地一个或几个仓库的精细化管理,也可实现制造企业、物流企业、连锁业在全国范围内、异地多点仓库的管理;它可以对货物存储和出货等进行动态安排,可以对仓储作业流程的全过程进行电子化操作;可以与客服中心建立数据接口使客户通过互联网实现远程货物管理,可以与企业的ERP系统实现无缝连接。在现代企业中,仓库管理是一项繁琐复杂的工作,每天要处理大量的单据数据。为及时结清每笔业务,盘点库存和货物流动情况,保证企业生产用料以及货物安全,库管人员要花费大量人力物力和时间来作数据记录统计工作。众所周知,仓库管理是一种既麻烦又单调的工作,每天都是重复记录一些货物的存入与取出,而且货物的种类繁多,存取有很大的随机性,这样为工作人员带来了很大的不便,在操作过程中,由于人为的计算出错率很高,一旦出错改正也很困难,这样简单繁重的工作要很多人来做,为经营者增加了很多成本。所以开发一个可行的仓库管理系统是十分必要的。本系统以MySQL作为后台数据库,以java语言来开发的,不仅实现了仓库管理的自动化,同时也提高了工作效率。本系统由以下几个模块组成:基本信息管理、入库管理、在库管理、出库管理、报表管理。第2章需求分析2.1仓库管理系统概述本系统是为物流管理而设计的高效管理系统, 系统功能强大, 同时操作又比较简单, 而管理人员大多受到过系统的培训,并能够操作电脑,所以只要花很少的时间,就能够让他们熟悉本系统。系统开发的总体任务是实现各种信息的系统化、 规范化和自动化。 系统功能分析是在系统开发的总体任务的基础上完成。本仓库管理系统需要完成功能主要有:•仓库管理各种信息的输入,包括货物、供应商、客户、仓库信息的输入等。•仓库管理各种信息的查询、统计、修改和维护,包括货物、单据查询,货物出入、职员操作统计,各种信息的修改和维护等。•打印报表的生成。•在货物管理中加入最高储备和最低储备字段,对仓库中的产品实现监控和报警。•操作日志的管理。

理系统的使用帮助。2.2系统流程图图理系统的使用帮助。2.2系统流程图图2-2系统流程图数据流程图数据流图是描述系统的逻辑模型的,图中没有任何具体的物理元素,只是描述信息在系统中流动和处理的情况,它比口头与文字的描述更直观地显示出来系统中数据的使用。数据流图简称DFD图,数据流图有四种成分:源点或终点、处理、数据存储表和数据流。图中没有任何具体的物理元素,只是描述信息在系统中的流动和处理情况,即使不是专业的计算机技术人员也容易理解,是极好的理解工具。它能精确的描述系统的逻辑模型,描述数据在MIS中有输入经过存储、加工处理最后输出的全过程,是设计者和用户交流的很好的工具。仔细分析调查有关仓库管理信息需求的基础上,得到如图 4-1所示的本系统所处理的数据流程。图2-3仓库管理系统数据流程图通过对企业仓库管理的内容和数据流程分析,设计数据项和数据结构如下:号、货物名称、货物类别、货物规格、计量单位、最号、仓库名称、仓库地点、保管员编号、备注等。・货物信息,包括的数据项有编高限量、最低限量、备注等。号、货物名称、货物类别、货物规格、计量单位、最号、仓库名称、仓库地点、保管员编号、备注等。・仓库信息,包括的数据项有编•库存状况信息,包括的数据项有编号、货物编号、库存数量、仓库编号等。•入库单信息,包括的数据项有编号、货物编号、经办人编号、入库时间、入库单价、入库数量、供应商编号、仓库编号、定单状况、其它金额、备注等。•出库单信息,包括的数据项有编号、货物编号、经办人编号、出库时间、出库单价、出库数量、客户编号、仓库编号、定单状况、其它金额、备注等。•进行月盘点信息,包括的数据项有编号、仓库编号、盘点时间、经办人编号、盘点数据等。•系统日志信息,包括的数据项有用户名、操作时间、操作内容等。•用户管理信息,包括的数据项有用户名、用户密码、用户权限等。另外,还有借入单、借出单、报损单、调拨单信息等。它们与入库单、出库单信息基本类似,这里不再一一例举。仓库管理系统的角色定义本系统角色包括两种,仓管部管理人员和管理部主管,其中,管理部主管拥有整个系统的最高权限。仓管部管理人员:负责仓库的出入库管理,可以根据流向单实现出 /入库操作。具体权限有:•库存信息管理•库检信息维护•入库单信息维护•出库单信息维护•报表信息管理•进行密码修改、清除表信息等系统设置•客户、供应商、库房等基本信息的查询浏览等仓管部主管:•负责整个山口仓管部门的日常运作和管理工作,主要包括:部门信息维护人员信息管理・审批•报表信息管理•进行密码修改、备份数据库等系统设置第3章总体设计总体用例图用例图是一个系统建模的启始点,可以使用用例图对将要开发系统的实际工作流程进行业务建模,从业务模型的基础上过度到系统建模的开始,可以通过用例图来搜集用户的需求,明确和系统相关的用户和其他系统,同时确定系统将会提供什么功能,以及各个功能间的关系。图3-1总体用例图用例说明根据上述用例图,对登陆和人员信息管理模块做了如下用例说明:用户从浏览器登录用例概述用例名称用户登陆主题领域用例定义用户登录到系统,获得相应的界面和使用权限角色仓管员或主管业务触发事件用户准备开始使用系统进行业务处理或系统管理前置条件系统中已为该用户建立系统用户,并分配了相应权限结束条件成功条件用户登录系统,并获得相应权限失败条件1)系统中没有该用户;2)用户名、密码错误相关用例输入概述用户名、密码、角色输出概述与用户权限相应的界面使用性备注本用例使用频繁用例备注主事件流步骤角色/系统描述数据项备注1.角色启动登录程序2.系统显不登录界囿;提示输入用户标识和保密字3.角色输入用户标识和保密字,登录用户名,密码,角色

系统4.系统验证用户是否合法用户、保密字是否止确;返回用户相应的界面、菜单如果小是合法用户、或保密字不止确转到A1。5.分支事件流编号主事件流步骤号角色/系统条件描述数据项转去主事件流步骤号备注A14系统不是合法用户,用户名、密码错误,用户名和密码与角色不对应返回登录失败信息登录失败信息2供货商信息查询用例概述用例名称供货商信息查询主题领域供货商信息查询用例包用例定义供货商信息查询角色仓库管理人员业务触发事件进行供货商信息查询前置条件有需要查询的供货商信息记录结束条件成功条件查询到需要查询的供货商信息失败条件未查询到需要查询的供货商信息相关用例输入概述所需查询的供货商信息输出概述查询结果使用性备注用例备注主事件流步骤角色/系统描述数据项备注6.角色进入查询界囿7.系统显不查询界囿8.角色输入所需查询的供货商信息9.系统查询是否成功查询成功如果查询成功转到A1如果查询不成功转到A2

分支事件流编号主事件流步骤号角色/系统条件描述数据项转去主事件流步骤号备注A14系统完成供货商信息查询返回成功信息查询的供货商信息2A24系统没有完成供货商信息查询返回失败信息查询失败的信息提示2供货商信息修改用例概述用例名称供货商信息修改主题领域供货商信息修改用例包用例定义供货商信息修改角色仓库管理人员业务触发事件进行供货商信息修改前置条件有需要修改的供货商信息记录结束条件成功条件查询到需要修改的供货商信息失败条件未查询到需要修改的供货商信息相关用例输入概述所需修改的供货商信息输出概述修改结果使用性备注用例备注主事件流步骤角色/系统描述数据项备注10.角色进入修改界囿11.系统显不修改界囿12.角色输入所需修改的供货商信息13.系统修改是否成功修改成功如果修改成功转到A1如果修改不成功转到A2分支事件流编号主事件流步骤号角色/系统条件描述数据项转去主事件流步骤号备注

A14系统完成供货商信息修改返回成功信息修改的供货商信息2A24系统没有完成供货商信息修改返回失败信息修改失败的信息提示2供货商信息添加用例概述用例名称供货商信息添加主题领域供货商信息添加用例包用例定义供货商信息角色仓库管理人员业务触发事件进行供货商信息添加前置条件有需要添加的供货商信息记录结束条件成功条件查询到需要添加的供货商信息失败条件未查询到需要添加的供货商信息相关用例输入概述所需添加的供货商信息输出概述添加结果使用性备注用例备注主事件流步骤角色/系统描述数据项备注14.角色进入添加界囿15.系统显不添加界囿16.角色输入所需添加的供货商信息17.系统添加是否成功添加成功如果添加成功转到A1如果添加不成功转到A2分支事件流编号主事件流步骤号角色/系统条件描述数据项转去主事件流步骤号备注A14系统完成供货商信息添加返回成功信息添加的供货商信息2A24系统没有完成供货商信息添加返回失败信息添加失败的信息提示2

3.3功能模块图功能模块:山口电脑仓库管理系统包括仓管部信息管理、业务管理、系统维护等几个功能模块。山口电脑仓库管理系统仓管部信息管理仓管部业务管理系统维护仓管部信息管理仓管部业务管理系统维护图3-3总功能模块图1、仓管部信息管理模块:为仓管部主管提供对仓管部信息的管理维护的功能。仓管部信息管理基本信息管理在库信息管理出库信息维护入库信息维护报表信息管理系统设置修改密码基本信息管理在库信息管理出库信息维护入库信息维护报表信息管理系统设置修改密码图3-3-1仓管部模块图、仓管部信息管理模块,如图所示,包括以下功能模块:.基本信息管理模块:为管理员提供实现对客户信息、供货商信息、库房信息和仓管人员信息的管理维护,包括对信息查询、添加、修改和删除等操作。.在库信息管理模块:a、库存信息管理模块:为管理员提供实现对短线货物、货物信息的管理维护,包括对信息查询、添加、修改和删除等操作。b、库检信息管理模块:为管理员提供实现对产品库检信息、部件库检信息、礼品库检信息的管理维护,包括对信息查询、添加、修改和删除等操作。.出库信息管理模块:为管理员提供查询、添加、修改和删除出库流向单(包括:产品出库单、部件出库单、礼品出库单)的操作,其中添加和删除操作后的出库货检单要交由管理部审核。.入库信息管理模块:为管理员提供查询、添加、修改和删除入库流向单(包括:部件入库单、产品入库单、礼品入库单)的操作、其中添加和删除操作后的入库货检单要交由管理部审核。.报表信息管理模块:为管理员提供实现对报表信息的管理维护,包括对报表信息查询、浏览和上交等操作。.系统设置模块:为管理员提供实现对密码修改、清除表信息的功能管理部信息管理仓管部人员管理仓库报表管理仓库货检信息管理基本信息管理系统设置仓管部人员管理仓库报表管理仓库货检信息管理基本信息管理系统设置、图3-3-2管理部模块图二、管理部信息管理模块,如图所示,包括以下功能模块:1、仓管部人员管理模块:为管理员提供实现对仓库部门信息的管理维护,包括对部门信息查询、添加、修改和删除等操作。2、仓库报表管理模块:为管理员提供实现对报表信息的管理维护,包括对报表的查询、浏览和删除等操作。3、仓库货检信息管理模块:为管理员提供实现对货检信息的管理维护,包括对在库货检信息、入库货检信息和出库货检信息的审核操作。4、基本信息管理模块:为管理员提供实现对基本信息进行添加、删除、查询和浏览功能、5、系统设置模块:为管理员提供实现修改密码、备份数据库和恢复数据库的功能第4章详细设计ER图ER图就是实体关系图,主要完成了对系统中数据部分设计。E-R图为实体-联系图,提供了表示实体型、属性和联系的方法,用来描述现实世界的概念模型。构成E-R图的基本要素是实体型、属性和联系。以下是系统的整个ER图:图4-1ER图数据库设计数据库设计(DatabaseDesign)是指根据用户的需求,在某一具体的数据库管理系统上,设计数据库的结构和建立数据库的过程。一般,数据库的设计过程大致可分数据库设计为5个步骤:需求分析;调查和分析用户的业务活动和数据的使用情况,弄清所用数据的种类、范围、数量以及它们在业务活动中交流的情况,确定用户对数据库系统的使用要求和各种约束条件等,形成用户需求规约。概念设计;对用户要求描述的现实世界(可能是一个工厂、一个商场或者一个学校等),通过对其中住处的分类、聚集和概括,建立抽象的概念数据模型。这个概念模型应反映现实世界各部门的信息结构、信息流动情况、信息间的互相制约关系以及各部门对信息储存、查询和加工的要求等。所建立的模型应避开数据库在计算机上的具体实现细节,用一种抽象的形式表示出来。以扩充的实体一(E-R模型)联系模型方法为例,第一步先明确现实世界各部门所含的各种实体及其属性、实体间的联系以及对信息的制约条件等,从而给出各部门内所用信息的局部描述(在数据库中称为用户的局部视图)。第二步再将前面得到的多个用户的局部视图集成为一个全局视图, 即用户要描述的现实世界的概念数据模型。逻辑设计;主要工作是将现实世界的概念数据模型设计成数据库的一种逻辑模式, 即适应于某种特定数据库管理系统所支持的逻辑数据模式。 与此同时,可能还需为各种数据处理应用领域产生相应的逻辑子模式。这一步设计的结果就是所谓“逻辑数据库”。物理设计;根据特定数据库管理系统所提供的多种存储结构和存取方法等依赖于具体计算机结构的各项物理设计措施,对具体的应用任务选定最合适的物理存储结构 (包括文件类型、索引结构和数据的存放次序与位逻辑等 )、存取方法和存取路径等。这一步设计的结果就是所谓“物理数据库”。验证设计;在上述设计的基础上,收集数据并具体建立一个数据库,运行一些典型的应用任务来验证数据库设计的正确性和合理性。一般,一个大型数据库的设计过程往往需要经过多次循环反复。当设计的某步发现问题时,可能就需要返回到前面去进行修改。因此,在做上述数据库设计时就应考虑到今后修改设计的可能性和方便性。数据库的完整性是指数据的正确性和有效性,是为防止数据库中存在不符合语义规定的数据和防止因错误信息的输入输出造成无效操作或错误信息而提出的。数据库的完整性包括:实体完整性、参照完整性和用户定义完整性。实体完整性 (EntityIntegrity):现实世界的实体是可区分的,即它们具有某种唯一性标识。相应地,关系模型中主键应作为唯一性标识。因此实体完整性规则规定基本关系的所有主键 (PrimaryKey)都不能取空值(NULL)。参照完整性(ReferentialIntegrity):参照完整性维护表与表之间的相关性,通常用“主键(PrimaryKey)/外键(ForeignKey)”保证,其中ForeignKey可以取NULL值,或取其参照表中PrimaryKey的取值。用户定义的完整性(User_definedIntegrity):针对某一具体数据的约束条件,由应用环境决定。数据库完整性约束能够防止合法用户使用数据库时向数据库中添加不合语义的数据。数据库的逻辑设计仓库管理系统所用的数据库是MySQL如下是表在数据库的逻辑表示:表assembly的结构字段名注释旧长度是否主键是含不为空id编号INTEGER【11VVInbilljd入库单编号VARCHAR20Supplier_id供货商编号VARCHAR20Depot_id库房编号VARCHAR20Number数量INTEGER【11Sumof_bad不合格数量INTEGER【11Atcheck_date在库货检日期DATE11VIn_date入库日期DATE11VEmployee_id货检员编号char5

表product的结构字段名注释包长度是否主键是含不为空id编号INTEGER【11VVMakebill_id组装单编号VARCHAR20VDepot_id库房编号VARCHAR20Check_id货检编号VARCHAR20Number数量INTEGER【11Sumof_bad不合格数量INTEGER【11Make_date组装日期DATE11VCheck_date货检日期DATE11V表assembly_product的结构字段名注释长度是否主键是含不为空id编号INTEGER【11VVAssembly_id部件编号VARCHAR20Product_id成口口编pVARCHAR20表customer的结构字段名注释长度是否主键是含不为空Customer_id客户编号VARCHAR20VVname姓名VARCHAR20sex性别VARCHAR20credit信誉度INTEGER【11phone电话号码VARCHAR20address地址VARCHAR20remark备注VARCHAR20表depot的结构字段名注释类型长度|是否主键是含不为空Depot_id库房编号VARCHAR20VVEmployee_id责任人编号VARCHAR20phone电话号码VARCHAR20address地址VARCHAR20remark备注VARCHAR20表employee的结构字段名注释长度是否主键是含不为空Employee_id人员编号VARCHAR20VVInbilljd入库单编号VARCHAR20Supplier_id供货商编号VARCHAR20Depot_id库房编号VARCHAR20Number数量INTEGER【11Sumof_bad不合格数量INTEGER【11Atcheck_date在库货检日期DATE11VIn_date入库日期DATE11VEmployee_id货检员编号VARCHAR5表supplier的结构字段名注释长度是否主键是含不为空Supplier_id供货商编号VARCHAR20VVname姓名VARCHAR20Vsex性别VARCHAR20credit信誉度INTEGER【11phone电话号码VARCHAR20address地址VARCHAR20remark备注VARCHAR20表inbill的结构字段名注释长度是否主键是含不为空In_id入库单编号VARCHAR20VVDepot_id库房编号VARCHAR20Refer_date入库日期DATE11Wh_id提交人编号VARCHAR20Check_date货检日期DATE11Ch_id货检人编号VARCHAR20VAudit_date审核日期DATE11VM_id主管编号VARCHAR20In_state入库单状态VARCHAR20表inlist的结构字段名注释长度是否主键是含不为空id编号INTEGER【11VVIn_id入库单编号VARCHAR20V

Assembly_id部件编号VARCHAR20VSupplier_id供货商编号VARCHAR20VNumber数量INTEGER【11Badnumber不合格数量INTEGER【11Good_rate合格率VARCHAR20表makebill的结构字段名注释个长度是否主键是含不为空Makebill_id组装单编号VARCHAR20VVDepot_id库房编号VARCHAR20Product_id成口口编pVARCHAR20VNumber数量INTEGER【11Atcheck_date在库货检日期DATE11VMake_date组装日期DATE11Manager_id主管编号VARCHAR20V表outbill的结构字段名注释个长度是否主键是含不为空Outbill_id出库单编号VARCHAR20VVDepot_id库房编号VARCHAR20Refer_date供货商编号VARCHAR20Refer_id提交人编号VARCHAR20Audit_date审核日期DATE11Out_state出库单状态VARCHAR11Audit_id审核人编号VARCHAR20Customer_id客户编号VARCHAR20V表outlist的结构字段名注释长度是否主键是含不为空id编号INTEGER【11VVOutbill_id出库单编号VARCHAR20VProduct_id成口口编pVARCHAR20VNumber数量INTEGER【11表report的结构字段名注释I长度是否主键是含不为空字段名 字段名注释I长度是否主键是含不为空Reportid报表编pVARCHAR20VVReporttype报表类型VARCHAR20VDepotid库房编号VARCHAR20VbeginDate起始日期DATE11VendDate结束日期DATE11VcreateTime创建日期DATE11VreferId提交人编号VARCHAR20VcheckState审核状态VARCHAR20VcheckDate审核日期DATE11AuditId审核人编号VARCHAR20表report_detail的结构字段名注释个长度|是否主键是含不为空id编号INTEGER【11Vv-reportId报表编RVARCHAR20VDepotid库房编号VARCHAR20VgoodsName货物名称VARCHAR40VgoodsType货物类型VARCHAR30VallNumber总数量INTEGER【11badNumber不合格数量INTEGER【11checkId审核人编号VARCHAR20V运行环境开发工具:Eclipse,软件环境:Tomcat6.0,JDK5.0以上,硬件环境:cpu:P32.0GHZ以上Memory:512M以上第5章编码登陆的实现登陆actionimportimportimport

importimportimportimportimportimport/***MyEclipseStruts*Creationdate:05-30-2009*XDocletdefinition:*@struts.actionpath="/login"name="loginForm"input="/webpage/login.jspscope="request"validate="true"*/publicclassLoginActionextendsActionpublicclassLoginActionextendsAction{publicActionForwardexecute(ActionMappingmapping,ActionFormform,HttpServletRequestrequest,HttpServletResponseresponse){publicActionForwardexecute(ActionMappingmapping,ActionFormform,HttpServletRequestrequest,HttpServletResponseresponse){LoginFormloginForm=(LoginForm)form;try{StringuserName=loginForm.getUser_name().trim();Stringpsw=loginForm.getPsw().trim();LoginServiceloginService= newLoginService();HttpSessionsession=request.getSession( true);if(loginService.login(userName,psw)){//session.setAttribute(如果登录成功把登录的名字放在returnmapping.findForward(//session.setAttribute(如果登录成功把登录的名字放在returnmapping.findForward(//返回到登陆成功页面}else{session.invalidate();request.setAttribute(//返回到错误页面returnmapping.findForward(}}catch(Exceptione){

e.printStackTrace();"username",userName);session中以便在过滤器中判断"loginSuccess");"loginError","用户或者密码错误"loginError");!!");}returnnull}5.1.2登陆过滤器importimport

importimportimportimportimportimportpublicclassSecurityAndDenyimplementsFilter{publicvoiddestroy。{//注销时调用}publicvoiddoFilter(ServletRequestreq,ServletResponseresp,FilterChainchain) throwsIOException,ServletException{HttpServletRequestrequest=(HttpServletRequest)req;HttpServletResponseresponse=(HttpServletResponse)resp;HttpSessionsession=request.getSession( false);//取出来session 如果没有得到空值if(session==null||session.getAttribute( "username")==null){//判断是否登录过如果没有就重定向到登陆页面Stringtemp="你还没登陆请重新登陆!! ";encode(temp.toString(), "utf-8" );response.sendRedirect(+temp);return;}//如果登录了就进入请求页面chain.doFilter(req,resp);}publicvoidinit(FilterConfigarg0) throwsServletException{//初始化时调用的方法}}5.1.3登陆DAOpublicBooleanlogin(StringuserName,Stringpsw){Employeeemployee=newEmployee();employee.setPsw(psw);employee.setUserName(userName);Listresults=findByExample(employee);intlength=results.size();if(length==1){returntrue;}elsereturnfalsereturnfalse5.2供货商的实现供货商查询 Actionpackageimportimportimportimportimportorg.apacheimportimportimportimportimportimportimportpublicclassQueryActionextendsAction{publicActionForwardexecute(ActionMappingmapping,ActionFormform,HttpServletRequestrequest,HttpServletResponseresponse)throwsException{QueryFormqueryForm=(QueryForm)form;SupplierServicess= newSupplierService();PageBeanpageBean=newPageBean();Listlist= null;//存放查出来的 spplier 对象StringcrrPage=request.getParameter( "cp");intcurrentPage=pageBean.getCurrentPage();intlineSize=pageBean.getLineSize();Suppliersupplier=change(queryForm);if(crrPage!=null){currentPage=Integer. parseInt(crrPage);}else{intallRecorders=ss.getCount(supplier);Tool.setALLRECORDERS(allRecorders);Tool.setPAGESIZE((allRecorders+lineSize-1)/lineSize);pageBean.setAllRecorders(allRecorders);pageBean.setPageSize((allRecorders+lineSize-1)/lineSize);}list=ss.queryByExample(supplier,currentPage,lineSize);pageBean.setCurrentPage(currentPage);request.setAttribute( "pageBean",pageBean);request.setAttribute( "list",list);//把查询出来的supplier对象放在request里returnmapping.findForward( "supplierResult" );}//把form表单里的东西转化为supplier对象publicSupplierchange(QueryFormqueryForm){Suppliersupplier= newSupplier。;if(queryForm.getSupplierId()!= nullTOC\o"1-5"\h\z&&!queryForm.getSupplierId().equals( ""))supplier.setSupplierId(queryForm.getSupplierId());if(queryForm.getAddress()!= null&&!queryForm.getAddress().equals( ""))supplier.setAddress(queryForm.getAddress());if(queryForm.getName()!= null&&!queryForm.getName().equals( ""))supplier.setName(queryForm.getName());if(queryForm.getCredit()!= null&&!queryForm.getCredit().equals( ""))supplier.setCredit(queryForm.getCredit());if(queryForm.getPhone()!= null&&!queryForm.getPhone().equals( ""))supplier.setPhone(queryForm.getPhone());if(queryForm.getRemark()!= null&&!queryForm.getRemark().equals( ""))supplier.setRemark(queryForm.getRemark());returnsupplier;}}供货商修改Actionimportuest;importimportimportimportimportimportimportimportpublicclassModifyActionextendsAction{publicActionForwardexecute(ActionMappingmapping,ActionFormform,HttpServletRequestrequest,HttpServletResponseresponse){ModifyFormmodifyForm=(ModifyForm)form;Suppliersupplier= newSupplier();supplier.setAddress(modifyForm.getAddress());supplier.setCredit(modifyForm.getCredit());supplier.setName(modifyForm.getName());supplier.setPhone(modifyForm.getPhone());supplier.setRemark(modifyForm.getRemark());supplier.setSupplierId(modifyForm.getSupplierId());SupplierServicess= newSupplierService();try{ss.upDate(supplier);returnmapping.findForward( "success");}catch(Exceptione){e.printStackTrace();returnmapping.findForward( "error");}}}供货商添加 Actionimportimportjavax.serimportimportimportimportimportimportimportpublicclassAddActionextendsAction{publicActionForwardexecute(ActionMappingmapping,ActionFormform,HttpServletRequestrequest,HttpServletResponseresponse){AddFormaddForm=(AddForm)form;Suppliersupplier= newSupplier();supplier.setAddress(addForm.getAddress());supplier.setCredit(addForm.getCredit());supplier.setName(addForm.getName());supplier.setPhone(addForm.getPhone());supplier.setRemark(addForm.getRemark());supplier.setSupplierId(addForm.getSupplierId());SupplierServicess= newSupplierService();try{ss.insert(supplier);returnmapping.findForward( "success");}catch(Exceptione){e.printStackTrace();//出现异常打印轨迹returnmapping.findForward( "error");供货商DAOpackageimport;importimportimportimportimportimportimportimportimportimportpublicclassSJupplierDAOextendsBaseHibernateDAO{publicstaticfinalStringNAME="name";publicstaticfinalStringADDRESS="address"publicstaticfinalStringPHONE="phone";publicstaticfinalStringCREDIT="credit" ;publicstaticfinalStringREMARK="remark";publicstaticfinalStringSUPPLIERID="supplierId"publicvoidsave(SuppliertransientInstance){Transactiontransaction=nulltry{Sessionsession=getSession();transaction=session.beginTransaction();session.save(transientlnstance);mit();session.close();}catch(Exceptionre){}}publicvoidupDate(SuppliertransientInstance) throwsException{try{Sessionsession=getSession();Transactiontransaction=session.beginTransaction();session.update(transientInstance);mit();session.close();}catch(RuntimeExceptionre){throwre;publictry{Sessionsession=getSession();Transactiontransaction=session.beginTransaction();Supplierinstance=(Supplier)session.get(,id);session.close();returninstance;}catch(RuntimeExceptionre){throwre;}}publicintgetCount(Supplierinstance) throwsException{if(instance.getSupplierId()!= null){Suppliersupplier=findById(instance.getSupplierId());if(supplier!=null){return1;}else{return0;}}else{Sessionsession=getSession();Transactiontransaction=session.beginTransaction();Criteriac=session.createCriteria().add(Example.create(instance));inti=c.list().size();mit();session.close();returni;}}intlineSize)publicListfindByExample(Supplierinstance, intcurrentPage,intlineSize)throwsException{Listlist= null;Sessionsession=getSession();if(findByProperty(SUPPLIERID,instance.getSupplierId()).size()==0||findByProperty( "supplierId"instance.getSupplierId())== null){Examplees=UtilGetExample. getExample(instance);Transactiontransaction=session.beginTransaction();Criteriac=session.createCriteria().add(es);c.setFirstResult((current1)*lineSize);c.setMaxResults(lineSize);list=c.list();mit();getSession().close();if(list.size()==0||list== null){returnnull;}returnlist;}else{instance.getSupplierId());returnfindByProperty("supplierld"}}instance.getSupplierId());第6章测试登陆测试方案输入空账号输入不存在的账号密码输入正确的账号和错误的密码输入正确账号和空密码没有登录直接访问页面数据录入测试录入一条空记录录入一条以上全部数据项非空记录录入一条以上只填必填数据项的记录录入一条以上只填非必填数据项的记录对具有外键关联的表录入一条以上检验外键约束的记录录入一条以上正确的记录录入一条以上检验其他自定义完整性约束的记录查询测试正常查询一条以上记录查询各种查非所查的记录查询各种不对应选项的查询测试结论首先,我们要认识到测试是软件开发过程中一个非常重要的环节,一个好的软件必须经过无数次的测试,软件测试是保证软件质量的关键步骤。在经过对各模块的测试后,已经能够证实该软件各方面的能力都可以正常运行。该软件在各方面的综合能力都通过。第7章使用说明系统功能简介本系统角色包括两种,仓库主管和普通管理员,其中,仓库主管拥有整个系统的最高权限。仓库主管负责整个山口物流公司仓管部的日常运作和管理工作,除了具有普通管理员的权利,还具有以下权利和义务,主要包括:基本信息管理:维护客户信息、供货商信息和仓管员信息,具体操作有添加、修改、删除和查询。入库管理:查看入库单,并且具有审批的功能,以决定是否需要入库。如果没有通过审批,将不能入库。出库管理:查看出库单,具有审批的功能,如果没有通过审批,将不能出库。报表信息管理:打印、查看一些报表。系统设置:修改个人信息,备份和还原数据。在库管理:管理在库的物品,记录盘点信息,以及维护仓库。退货信息管理:管理退货信息,包括客户向公司的退货,以及公司向供货商退货。仓管部管理人员:负责仓库的出入库管理,可以根据流向单实现出 /入库操作;管理库内的产品,记录一些库检、盘点等信息,还可以修改个人信息等。具体权限有:基本信息管理:只可以查询客户信息,供货商信息和仓管员的信息,不能对其做任何修改或删除操作。还可以查询仓库信息。入库管理:添加入库单,然后提交给主管审批,如果通过审批,则可以入库。对于通过审批的入库单,不能再作修改,只能查询;对于没有通过审批的入库单,可以根据主管的批注作修改或删除的操作。出库管理:添加出库单,然后提交给主管审批,如果通过审批,则可以出库。对于通过审批的出库单,不能再作修改,只能查询;对于没有通过审批的出库单,可以根据主管的批注作修改或删除的操作。在库管理:查看库存信息、成品组装、在库移动、以及记录盘点信息。退货信息管理:管理退货信息,包括客户向公司的退货,以及公司向供货商退货。报表信息管理:打印、查看一些报表。系统设置:修改个人信息。运行环境简介TOC\o"1-5"\h\z硬件环境 :服务器端:推荐配置为1G内存,CPU为1700MHZZ上配置,硬盘容量为80G的微机。通信网络 : 依托校园网,网络协议为 HTTP、TCP/IP。软件环境 :服务器端 :操作系统: Windows2000/NT/XP/2003数据库服务器 :MySQLServer4.1Web服务器: ApacheTomcat6.0技术架构平台: SunJ2DK1.6客户端:操作系统: Windows2000/XP/2003浏览器:InternetExplore6.0或以上版本屏幕分辨率推荐为: 1024*768或以上系统运行与操作指南配置该项目,启动Tomcat服务器,打开InternetExplorer,在URL地址中输入JT03EtpLgtWebProject03/login.jsp,进入登录页面,根据输入的用户,可以判定是主管或者是普通仓管员,用户名和密码都正确,即可登录到相应的主页面,进行相应的操作。操作演示主登陆页面特色介绍本系统根据山口物流公司实际需求进行设计和开发的, 切合实际, 具有很强的实用性。界面友好,功能完善,接口丰富,具有很好的可扩充性 .完善的后台管理,管理员不需要懂得任何操作就可以对前台进行控制。采用Browser/Server三层体系结构,使系统具有很好的可维护性和可重用性。(5)Web服务器采用的是Apache的Tomcat应用服务器,它是一个比较完善的、开放的轻量级Web应用服务器,性能优良,配置和部署方便。它严格地遵循普遍流行的开放标准,在中小型开发过程中较为适用。有警报设置功能,对于数量不足的产品或积压时间过长的产品,会自动提示,更加人性化。第8章总结仓库管理是物流管理的核心内容之一,基于 Internet的仓储管理系统,改变了繁重的手工操作带来的效率低,易出错的状况,解决了跨地域仓储的难题,提高了仓储服务水平,减少了企业仓储投资。系统从分析、设计开始,高标准要求,并且严格按照信息系统工程的方法,保证了系统在运行之后的稳定性。技术采用的 J2EE、MVC1式、DAO1式等方法,提高了系统的模块化和结构化,使系统更易扩展、升级和维护。但是,本系统目前只是针对某些物流公司的业务情况开发的,有一定的通用性。由于每个公司的业务情况和管理方式都不一样,设计时并没考虑这些情况。另外,在数据仓库,深度数据挖掘技术以及仓储的智能化方面,没有做详细的考虑,有待今后逐步地进行完善。关于本系统,虽然对仓库管理进行了系统的创建,但我们不可忽略的是这个系统并不完美,我们也不能高枕无忧。我们要在以后的实践中去检验它的可用性,特别要考虑它的实时性和安全性,这才是我们最值得考虑的问题。一个系统好不好,要经过反复的使用才能知道,不光光是理论中分析和设计得出来的。由此我就想到了在做这个系统时,有的同学用了ACCESS有的同学用了SQL等来建不同的数据库,这样就导致有的是系统自带的代码,而有的则是我们写进去的纯代码,当然也就出现了各种各样的问题。特别是关于系统的可移植性,有许多不足之处,这样我们就应该多查阅相关资料,反复地熟练应用,才能把系统设计的巧,设计的好。同学们之间的交流也十分重要,交流就是进步,有时进会带你走入一种柳暗花明的欣喜境界参考文献吴建,郑潮,汪杰.UML基础与Rose建模案例.北京:人民邮电出版社.2004年9月黄晓东着.JAVA课程设计案例精编.河南:中国水利水电出版社.2004.7[3](美)BruceEckel着,陈昊鹏,饶若楠等译.JAVA编程思想.陕西:机械工业出版社.2005.6陈玉峰.MySql数据库开发教程 .北京:科学出版社 .2004.4PerryEdwards.SystemAnalysis&Design.MitchellMcgraw-Hill.2005.5冀振燕.UML系统分析设计与应用案例.北京:人民邮电出版社.2005.6TedHusted,CedricDumoulin,GeorgeFranciscus,DavidWinterfeldt.StrutsinAction[M].ManningPublicationsCompany.2003冯燕奎,赵德奎等 .JSP实用案例教程 .北京:清华大学出版社 .2004BruceEckel.Thinkinginjava.pearsonEducation.2005.5杨志波.DreamweaverMX2004标准教程 .北京:中国宇航出版社 .2004年第1版[11]孙卫琴.精通Struts基于MVC勺JavaWeb设计与开发[M].北京:飞思科技产品研发中心.2006&FraserPublishingCompany.2004致谢非常感谢我的导师曹来成老师给我的悉心关怀,让我顺利地完成了毕业论文,当然,也感谢母校辛勤培育之恩,各位领导、老师和同学的大力帮助之情,使我学到了许多新的知识,同是也更懂得了一些做学问的道理,这是一笔宝贵的财富。从选择毕业设计题目,到毕业设计规划,查找相关资料,设计模型,具体实施,结束论文,整个大致的流程中,我的导师都给予了我耐心的指导和默默的关心,设计为期之长,其间遇到了不少问题,也承蒙了老师的照顾,真的想对老师说一声:老师,辛苦了,谢谢您。除此之外,我还要致谢我的几位同学的得力相助,我希望我能向他们学习,发扬那种百折不挠、孜孜不倦的对知识求索精神,那种至高无上的敬业精神,马上我就要走向工作单位了,我相信我会时刻用他们的平凡而不简单来鞭策自已。最后,衷心祝愿我的老师和学友们永远幸福,快乐。翻译资料原文OverviewofJSPTechnologyBenefitsofJSPJSPpagesaretranslatedintoservlets.So,fundamentally,anytaskJSPpagescanperformcouldalsobeaccomplishedbyservlets.However,thisunderlyingequivalencedoesnotmeanthatservletsandJSPpagesareequallyappropriateinallscenarios.Theissueisnotthepowerofthetechnology,itistheconvenience,productivity,andmaintainabilityofoneortheother.Afterall,anythingyoucandoonaparticularcomputerplatformintheJavaprogramminglanguageyoucouldalsodoinassemblylanguage.Butitstillmatterswhichyouchoose.JSPprovidesthefollowingbenefitsoverservletsalone:?ItiseasiertowriteandmaintaintheHTML.YourstaticcodeisordinaryHTML:noextrabackslashes,nodoublequotes,andnolurkingJavasyntax.?YoucanusestandardWeb-sitedevelopmenttools.EvenHTMLtoolsthatknownothingaboutJSPcanbeusedbecausetheysimplyignoretheJSPtags.?Youcandivideupyourdevelopmentteam.TheJavaprogrammerscanworkonthedynamiccode.TheWebdeveloperscanconcentrateonthepresentationlayer.Onlargeprojects,thisdivisionisveryimportant.Dependingonthesizeofyourteamandthecomplexityofyourproject,youcanenforceaweakerorstrongerseparationbetweenthestaticHTMLandthedynamiccontent.Now,thisdiscussionisnottosaythatyoushouldstopusingservletsanduseonlyJSPinstead.Bynomeans.Almostallprojectswilluseboth.Forsomerequestsinyourproject,youwilluseservlets.Forothers,youwilluseJSP.Forstillothers,youwillcombinethemwiththeMVCarchitecture.Youwanttheappropriatetoolforthejob,andservlets,bythemselves,donotcompleteyourtoolkit.AdvantagesofJSPOverCompetingTechnologiesAnumberofyearsago,Martywasinvitedtoattendasmall20-personindustryroundtablediscussiononsoftwaretechnology.SittingintheseatnexttoMartywasJamesGosling,inventoroftheJavaprogramminglanguage.Sittingseveralseatsawaywasahigh-levelmanagerfromaverylargesoftwarecompanyinRedmond,Washington.Duringthediscussion,themoderatorbroughtupthesubjectofJini,whichatthattimewasanewJavatechnology.Themoderatoraskedthemanagerwhathethoughtofit,andthemanagerrespondedthatitwastooearlytotell,butthatitseemedtobeanexcellentidea.Hewentontosaythattheywouldkeepaneyeonit,andifitseemedtobecatchingon,theywouldfollowhiscompany'susual"embraceandextend"strategy.Atthispoint,Goslinglightheartedlyinterjected"Youmeandisgraceanddistend."Now,thegrievancethatGoslingwasairingwasthathefeltthatthiscompanywouldtaketechnologyfromothercompaniesandsubornitfortheirownpurposes.Butguesswhat?Theshoeisontheotherfoothere.TheJavacommunitydidnotinventtheideaofdesigningpagesasamixtureofstaticHTMLanddynamiccodemarkedwithspecialtags.Forexample,ColdFusiondidityearsearlier.EvenASP(aproductfromtheverysoftwarecompanyoftheaforementionedmanager)popularizedthisapproachbeforeJSPcamealonganddecidedtojumponthebandwagon.Infact,JSPnotonlyadoptedthegeneralidea,itevenusedmanyofthesamespecialtagsasASPdid.So,thequestionbecomes:whyuseJSPinsteadofoneoftheseothertechnologies?Ourfirstresponseisthatwearenotarguingthateveryoneshould.Severalofthoseothertechnologiesarequitegoodandarereasonableoptionsinsomesituations.Inothersituations,however,JSPisclearlybetter.Hereareafewofthereasons.Versus.NETandActiveServerPages(ASP).NETiswell-designedtechnologyfromMicrosoft.ASP.NETisthepartthatdirectlycompeteswithservletsandJSP.TheadvantagesofJSParetwofold.First,JSPisportabletomultipleoperatingsystemsandWebservers;youaren'tlockedintodep

温馨提示

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

评论

0/150

提交评论