J2EE技术实验报告-基于SSH的轿车信息管理系统.doc_第1页
J2EE技术实验报告-基于SSH的轿车信息管理系统.doc_第2页
免费预览已结束,剩余47页可下载查看

下载本文档

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

文档简介

基于ssh的轿车信息管理系统j2ee技术实验报告项目题目: 基于ssh的轿车信息管理系统 学 院: 计算机学院 指 导 教 师: 项 目 成 员: 专 业: 软件工程 班 级: 软件0901 完 成 时 间: 2012-06-02 46目 录1引言12核心技术简介22.1mvc模式简介22.2struts2框架简介32.2.1struts2架构42.2.2struts2基本处理流程52.2.3struts2的优点62.3hibernate框架简介62.3.1hibernate架构62.3.2hibernate核心接口72.3.3hibernate基本处理流程72.3.4hibernate的优点72.4spring框架简介82.4.1spring架构82.4.2spring特点93轿车信息管理系统需求分析103.1任务概述103.2用户特点103.3功能需求103.4界面需求113.5操作需求113.6输入输出需求114轿车信息管理系统概要设计124.1设计思想124.2总体设计124.3系统层次结构图134.4接口设计134.5数据库设计134.6出错处理设计145轿车信息管理系统详细设计165.1数据库详细设计165.1.1数据库关系模型设计165.1.2数据库物理结构设计165.2轿车管理系统模块详细设计175.2.1用户登陆模块175.2.2用户首页面模块185.2.3添加汽车模块185.2.4删除汽车模块195.2.5查询汽车模块205.2.6修改汽车模块205.2.7出售汽车模块215.2.8总销售查询模块225.2.9按时间查询模块226轿车信息管理系统具体实现246.1开发与运行环境246.2开发环境的搭建246.3数据库系统实现306.4dao层实现346.5manager层实现356.6action层实现366.7汽车信息查询模块实现366.1按时间查询模块实现386.2系统其它模块的实现417总结448参考文献451 引言近年来随着人均收入水平的提高,人们购车的能力也逐步提升。为了方便轿车销售企业对己方轿车管理,轿车销售管理系统成了轿车市场一个不可或缺的管理软件。一个好的管理软件能提高企业的管理效率,减轻企业统计人员的工作量。同时随着近年来企业java的发展,使得开发一个针对企业需求的软件系统变得简单。因此使用企业java来开发一个轿车信息管理系统,是行之有效的。2 核心技术简介struts2,spring,hibernate是三个相互独立的框架。但三个框架一起整合起来使用,能使软件系统开发更轻松、更灵活、更容易扩展。三者都是“半成品”框架,使得我们在开发时不需要从头做起。三者之间的关系如图2-1:图2-1 struts2,spring,hibernate关系图122.1 mvc模式简介mvc全称model view controller,它使得应用程序的输入、处理和输出分开,使程序的耦合度降低。其每个层次说明如下: model(模型):模型表示业务相关的数据与业务的处理方法。能直接访问数据。 view(视图):视图用于对数据的显示。在这一层上,通常没有逻辑。为了更新视图,视图需要访问它监视的模型,因此视图通常事先在被监视的数据那进行注册。 controller(控制器):顾名思义,控制器起到控制作用,用于控制应用程序的流程。它处理事件并作出响应,调用相关的模型去处理事件请求,确定哪个视图返回请求。图2-2 mvc各层关系图图2-2显示的mvc各层之间的关系。由于它具有这些结构使得多个视图可以共有一个模型,同时对一层上的修改不会影响到其他层。2.2 struts2框架简介struts2是一个在webwork的基础上转化而来的基于mvc的框架。采用拦截器的机制来处理用户请求,使得业务逻辑控制器与servlet api实现分离。.1 struts2架构图2-3 struts2架构图2-3 展示了struts2的整体架构,其各模块说明如下: filterdispatcher:它是strut2的核心控制器。它根据actionmapper的结果来决定对请求的处理和响应。 actionmapper:它是一个接口,并提供了http请求与action之间的映射关系。如果用户的请求与actionmapper中提供的方法相匹配,就继续调用actionproxy。 actionproxy:它会依据actionmapper生成的uri以及配置管理器来找到响应用户请求的action对象。然后创建actioninvocation对象来执行相应的action方法。 actioninvocation:它会在调用action处理方法的前后,还要调用各种拦截器。 result:它会根据相关视图将用户请求的处理结果反馈给用户。 struts.xml:是struts2的配置文件,负责配置每个action的返回结果所对应的跳转页面。 interceptor:拦截器是struts2的重要组件,其设计思想来源于aop(面向切面编程)。通常用于处理某些通用的处理,它会在每个action的外部执行。 action:用于处理用户请求并封装业务数据。其执行后通常会返回一个string类型的量,struts.xml根据这个量来决定跳转页面。 templates:页面模板。 tag subsystem:struts2的标签库,用于页面的设置。2.2.2 struts2基本处理流程图2-4 struts2基本处理流程图2-4展示了struts2基本处理流程,用户请求在经过一系列拦截器(拦截器会对用户请求进行相应的处理,如增加某些功能)后,就会交由action处理,然后action返回响应的结果(默认为“input”),最后通过匹配结果来选择跳转视图页面。2.2.3 struts2的优点 “半成品”框架:使得开发不需要从头做起,而且在框架中很多地方都有默认值设置,减少了冗余的设置,提高了开发效率。 轻量级:资源消耗少,运行速度快。 搭建简单:只需在myeclipse中将需要的包拷贝入项目中,再进行配置。 标签强大:struts2提供了一系列的自己编写的标签用于页面布置,减少了页面代码。 action测试简单:不需要模拟http对象,就可以直接测试。 错误报告明了:便于迅速找出错误并修改。2.3 hibernate框架简介hibernate是一个开放源码的对象关系映射框架,采用orm机制,通常用于持久层的开发。它对jdbc进行了轻量级的封装,使得我们在开发过程中可以使用面向对象的方式来操纵数据库。2.3.1 hibernate架构图2-5 hibernate架构2.3.2 hibernate核心接口hibernate核心接口一共有6个: session接口:该接口用于持久化对象的增、查、删、该,属于非线程安全。 sessionfactory接口:该接口用于初始化hibernate,充当数据存储源的代理,并创建session对象。 configuration接口:该接口在hibernate的启动时,首先定位映射文档位置、读取配置,然后创建sessionfactory对象。 transaction接口:用于事务操作。 query和criteria接口:使用hql或sql语句查询数据库。其中criteria接口更靠近面向对象;query接口则提供了使用原生sql语句的方法。2.3.3 hibernate基本处理流程1. 创建configuration实例,读取项目路径根目录下的配置文件信息。2. 创建sessionfactory实例,将configuration中的配置信息复制到sessionfactory中。3. 调用sessionfactory来创建session4. 打开session,并创建事务transaction5. 进行持久化操作6. 提交事务7. 关闭session8. 关闭sessionfactory2.3.4 hibernate的优点 它使得数据库中的每一张表都映射为一个java类,让我们在开发过程中可以使用面向对象的方式来操作数据库。 自动配置,我们只需在数据库中建立表,然后通过myeclipse自带的工具就能完成映射。 它封装了对各种数据库的操作 轻量级框架,映射灵活,数据库表、配置文件、映射类我们只需要完成其中任何一部分就能依靠工具完成三者的关系映射。2.4 spring框架简介spring框架致力于j2ee应用各层的解决方案,贯穿表现层、业务层、持久层。同时它是一个轻量级的框架,没有侵入性,不会改变原有框架的类容。使用它的目的不是去修改原有框架,而是使用它来管理,使得原有的框架工作得更好。2.4.1 spring架构图2-6 spring架构图2-6为spring的架构,每个模块功能如下: 核心容器:提供spring框架的基本功能。其主要组件是beanfactory,采用ioc(控制反转)将应用程序的配置与依赖性代码分开。 spring上下文:是一个配置文件,用于提供上下文信息。 spring aop:该模块直接将面向方面的编程功能集成到了spring 框架中。支持声明式的事务管理。 spring dao:该模块用于管理异常处理和不同数据库供应商抛出的错误消息。 spring orm:提供了如hibernate这类orm 的对象关系工具。 spring web:为基于 web 的应用程序提供了上下文,简化了处理多部分请求以及将请求参数绑定到域对象的工作。 spring mvc框架:该框架中融入了大量视图技术。2.4.2 spring特点 轻量级框架:占用资源少,非侵入性。 控制反转(ioc):使得本来需要我们(应用程序)在执行前要进行的new操作,交由spring的ioc容器来管理,在容器中进行配置,再由容器来将new好的对象注入应用程序,从而松散了耦合度。 面向切面(aop):通常我们的编程思路是至上而下的,spring的aop使得我们能横向考虑问题,例如事务与日志记录。3 轿车信息管理系统需求分析3.1 任务概述轿车信息管理系统用户企业管理轿车的销售情况,除了基本的查询、添加功能外,还应有统计功能。同时操作方面应尽量简单。3.2 用户特点1) 系统管理员:该用户拥有最高权限,可以对轿车的信息修改,查看销售情况。2) 前台销售员:该用户仅用查看轿车基本信息(不包括成本价),以及成功出售一辆轿车后的出售操作3.3 功能需求除了基本的查询、添加功能外,还应有统计销售功能,以及分段查询功能。功能需求图如下图3-1所示:图3-1 系统功能需求各模块具体说明如下:1) 用户登陆:用户输入合法的用户名和密码完成登陆,如果用户名或密码错误,应输出提示。2) 登陆页面:显示当前用户的权限,以及相关功能连接。3) 车辆管理:提供基本的车辆增、查、删、改功能,以及出售车辆操作。同时增加相应错误判断。4) 业务管理:提供总销售统计查询,以及根据时间段的查询。同时提供相应的错误判断。3.4 界面需求界面简洁美观。3.5 操作需求操作简洁,符合人们通常使用习惯。3.6 输入输出需求要求输入数据合法,如果非法会跳出出错提示。4 轿车信息管理系统概要设计4.1 设计思想该轿车管理系统用于轿车基本的增、查、删、改、出售以及统计功能。能够方便企业对自己的轿车进行管理,它将具有以下特点: 运行速度快 占用资源少 界面简洁 操作简单4.2 总体设计1) 以用户登陆后的界面为平台,将各模块功能放于该页面2) 采用ssh框架3) 灵活性要求:视图与业务逻辑分开,低耦合。采取接口方式编程便于系统的维护以及移植。4) 输入输出要求:要求输入数据合法,如果非法会跳出出错提示。4.3 系统层次结构图图4-1 系统层次结构图4.4 接口设计用户接口:通过鼠标与键盘操作。内部接口:使用数据流提供的接口操作各个模块。4.5 数据库设计概念结构设计是指将需求分析得到的用户需求抽象为信息结构。描述概念模型的有力工具是e-r模型。本系统e-r图如下图所示:图4-2 用户e-r图图4-3 轿车销售e-r图4.6 出错处理设计1) 以下列出了可能的错误情况及其对应的错误信息:2) 用户名或密码有误,提示:您输入的用户名或密码有误,请重新输入。3) 新增车辆在数据库中已经存在,提示:您录入的车名-型号,在数据库中已经存在,如果要修改,请到修改页面。4) 新增车辆的售价小于成本,提示:您输入的售价小于成本。5) 出售数量大于库存数量,提示:您出售的车名-型号,出售数量大于库存数量6) 按时间查询时起始日期大于截止日期,提示:您输入的起始日期大于截止日期5 轿车信息管理系统详细设计本报告将对轿车系统的数据库与各模块进行详细设计。5.1 数据库详细设计5.1.1 数据库关系模型设计e-r图向关系模型转换:一个实体型转换为一个关系模式,实体的属性即为关系模式的属性,实体的标识符即为关系模式的键。根据图4-2与图4-3,本系统的关系模型为:1) 用户(用户id,用户名,密码,权限);2) 轿车(轿车id,车名,型号,数量,售价,成本);3) 销售表(销售id,轿车id,销售日期,销售数量)。5.1.2 数据库物理结构设计数据库的物理设计是将一个给定逻辑结构实施到具体的环境中,逻辑数据模型要选取一个具体的工作环境,这个工作环境提供了数据存储结构与存取方法。经过分析设计给出了各主要表的物理结构:users表,用于存取用户信息,其设计如下:列名类型长度是否允许空值主键/外键user_idint8no主键usernamevarchar20nopasswordvarchar20nolevelint1no表5-1car表,用于存取轿车基本信息,其设计如下:列名类型长度是否允许空值主键/外键car_idint8no主键carnamevarchar20nocartypevarchar20noamountint8noin_priceint8nosell_priceint8no表5-2sell表,用于存取销售情况,其设计如下:列名类型长度是否允许空值主键/外键sell_idint8no主键car_idint8no外键sell_amountint8nosell_datedate-no表5-35.2 轿车管理系统模块详细设计5.2.1 用户登陆模块模块功能:用户输入正确的用户名密码后跳转到相应页面,若用户名或密码有误,输出提示流程图:图5-15.2.2 用户首页面模块模块功能:显示当前用户权限,展示相应功能连接流程图:图5-25.2.3 添加汽车模块模块功能:将用户输入的轿车信息保存到数据库中。流程图:图5-35.2.4 删除汽车模块模块功能:通过下拉框选择汽车的型号与名字,点击删除按钮对汽车删除。流程图:图5-45.2.5 查询汽车模块模块功能:通过下拉框选择汽车的型号与名字,点击查询按钮查询轿车信息。流程图:图5-55.2.6 修改汽车模块模块功能:依据输入的汽车信息修改相应汽车的信息流程图:图5-65.2.7 出售汽车模块模块功能:用户选择要出售的汽车,输入出售数量,提交出售,如果出售数量大于库存数量,输出错误提示流程图:图5-75.2.8 总销售查询模块模块功能:输出总的销售结果流程图:图5-85.2.9 按时间查询模块模块功能:依据用户选择的时间段来查询该段时间的销售情况流程图:图5-96 轿车信息管理系统具体实现6.1 开发与运行环境 操作系统:win7 内存:2g 硬盘空间:500g 开发软件:myeclipse 10,microsoft sql server 2008,java 6.0 ,tomcat6.0 框架版本:struts 2.1,hibernate 3.0,spring 3.06.2 开发环境的搭建新建一个web项目名为cims(car infomation management system),选择使用java6.0,如图6-1:图6-1添加struts2相关支持包,如图6-2图6-2在meclipse的数据库视图中增加cardb配置,如图6-3:图6-3添加spring相关包,除了默认的包以外,还应选上spring web liberaies 3.0,如图6-4:图6-4添加hibernate支持包,除了原有包外,将最后4个包也加入,如图6-5图6-5hibernate configuration选择spring configuration file,因为三大框架整合之后由spring来管理所有的bean,所以hibernate的配置文件也由spring的applicationcontext.xml文件来管理,点击下一步;选择existing spring configuration file,点击下一步;选择数据库为cardb,注意方言为sql server;不建立sessionfactory,完成;在web.xml中添加如下代码; contextconfiglocation/web-inf/classes/applicationcontext.xml org.springframework.web.context.contextloaderlistener struts2 org.apache.struts2.dispatcher.ng.filter.strutsprepareandexecutefilter encodingutf-8 struts2 /* 6.3 数据库系统实现users表car表sell表其中sell表中的外键请安如下方式添加:数据库映射到项目中,注意id的生成方式选择native最后的项目中将会有如下映射类:6.4 dao层实现dao(data access object)是用于访问数据的对象,在使用时,我们在dao中定义访问其对应数据对象的接口方法,业务层通过dao操作数据,这样避免了直接在业务层使用持久层的技术。dao以及dao实现的项目结构如下图所示:在使用前,需要在spring的配置文件中添加如下配置:org.hibernate.dialect.sqlserverdialectcom/cims/domain/users.hbm.xmlcom/cims/domain/sell.hbm.xmlcom/cims/domain/car.hbm.xml在本系统中绝大多数dao实现使用gethibernatetemplate()模板来操作数据库,因为该模板是线程安全的。例子:overridepublic car findcarbynameandtype(string carname, string cartype) list l= gethibernatetemplate().find(from car +where car_name=+carname+ and car_type=+cartype+);if(l.size()=1)return (car)l.get(0);return null; 从中可以看出hibernate处理数据库的优势,它使用了对象的方式来对数据库的表操作。而且我们不需要编写最底层的sql语句,而是直接使用它提供的方法。但hibernate的模板提供的方法似乎不支持一些数据库中的默认函数,因此本系统一些地方还使用了session来使用原生sql语句。例子:overridepublic list findcarname() return getsession().createsqlquery(select +distinct car_name from car).list();该方法主要是用于得到数据库中的汽车名字,并且过滤掉重复的部分。6.5 manager层实现在action中通过manager对dao接口进行调用,首先将需要对用到的dao实例化,采用spring的依赖注入方式将实例化的dao注入到action中。具体调用示例如下:overridepublic void savesell(car car, int sellamount) calendar c=calendar.getinstance();car.setamount(car.getamount()-sellamount);sell sell=new sell();sell.setcar(car);sell.setsellamount(sellamount);sell.setselldate(c.gettime().tolocalestring();selldao.savesell(sell);cardao.update(car);前后省略了selldao,cardao的定义以及set方法。该方法用于保存一条销售信息。在spring的配置文件中需要添加如下代码:可以理解为我们以前在action执行的cardao cardio=new cardaoimpl();语句。不过由于spring的控制反转与依赖注入,使得我们将这个工作交给了spring框架来完成6.6 action层实现action用于返回一个stirng类型字符串,来选择跳转页面。其主要的配置在struts.xml这个文件中,例子如下:/pages/sellmanager/sellcarresult.jsp/pages/sellmanager/willsellcarinfo.jsp6.7 汽车信息查询模块实现该模块实现界面如下:首先会根据数据库中汽车信息生成一个查询选择页面;用户选择好查询车辆后,显示查询结果;下面是该模块的具体实现过程:查询页面用到了一个struts2的标签该标签有2个主要参数list对应第一个下拉选框,它的值由数据库中的汽车名称决定;doublelist对应第二个下拉选框,它的值对应第一个选框中的汽车名称所对应的型号;其生成action的主要代码如下:public string execute() throws exception nametotype=carmanager.carnametotype();carname=new arraylist();carname.add(所有);carname.addall(carmanager.carname();return success;public list getcartype() valuestack stack = servletactioncontext.getvaluestack( servletactioncontext.getrequest() );object name = stack.findvalue( top );if( name!=null & name instanceof string ) return nametotype.get( (string)name );return collections.empty_list;execute()方法中的carname是一个list对象,用于存放所有的汽车名称,对应中的totype是个mapstring,list类型对象,用来存放汽车名称与型号的对应。getcartype()方法依据栈顶元素来选择对应的汽车型号的list。它的返回值对应于中的doublelist。在spring的配置文件中需要注入carmanager6.1 按时间查询模块实现该模块的具体实现页面如下:首先生成一个选择查询时间的页面,其中年份会依据数据库中的所有年份来生成选择时间段都输出查询统计结果如果选择的起始时间大于截止时间会报错具体实现过程如下:action中主要方法如下overridepublic string execute() throws exception if(beginyear=-1)selllist=sellmanager.findallsellinfo();else if(beginyearendyear)setmsg(您选择的起始年份:+beginyear+,大于截止年份:+endyear);return input;else if(beginyear=endyear)if(beginmonthendmonth)setmsg(您选择的起始月份:+beginmonth+,小于截止月份:+endmonth);return input;selllist=sellmanager.findsellinfobydate(beginyear, beginmonth, endyear, endmonth);elseselllist=sellmanager.findsellinfobydate(beginyear, beginmonth, endyear, endmonth);setmsg();profit=sellmanager.totalprofit(selllist);totalsell=sellmanager.totalsells(selllist);beginyear=-1;return success;其中默认给beginyear赋值为-1,用于处理用户选择总销售情况时的查询。其余情况下如果时间合法则调用sellmanager中的相关方法来获取销售的信息。需要在spring的配置文件中添加如下代码:findsellinfobydate()方法会根据输入的4个参数来生成查询sell表的sql语句,其中用了很的判断来处理输入时间。分别判断了如下条件:1) 起止年份相同2) 起始年份小于截止年份其主要代码如下:public list findsellinfobydate(int beginyear, int beginmonth,int endyear, int endmonth) list selllist=new arraylist();string date=null;for(int i=beginyear;i=endyear;i+)if(i=endyear&i=beginyear)for(int j=beginmonth;j=endmonth;j+)date=+i+-%+j+-%;selllist.addall(selldao.findsellinfobydate(date);else if(i!=endyear)for(int j=beginmonth;j=12;j+)date=+i+-%+j+-%;selllist.addall(selldao.findsellinfobydate(date);elsefor(int j=1;j=endmonth;j+)date=+i+-%+j+-%;selllist.ad

温馨提示

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

评论

0/150

提交评论