JAVA网上手机商店百宝箱的设计与实现(本科毕业论文)_第1页
JAVA网上手机商店百宝箱的设计与实现(本科毕业论文)_第2页
JAVA网上手机商店百宝箱的设计与实现(本科毕业论文)_第3页
JAVA网上手机商店百宝箱的设计与实现(本科毕业论文)_第4页
JAVA网上手机商店百宝箱的设计与实现(本科毕业论文)_第5页
已阅读5页,还剩34页未读 继续免费阅读

下载本文档

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

文档简介

1、装订线长 春 大 学 毕业设计(论文)纸1 引 言1.1 网上手机商店的发展近年来,随着internet的迅速崛起,互联网已日益成为收集提供信息的最佳渠道并逐步进入传统的流通领域。于是电子商务开始流行起来,越来越多的商家在网上建起在线商店,向消费者展示出一种新颖的购物理念。网上手机店是一种具有交互功能的商业信息系统。它向用户提供特价手机和新品上市两类信息资源。所谓特价手机是指那些日期过久的手机或者是活动的手机,会被放入到特价手机行列中;新品上市的信息,即这个星期或者这几天某个手机厂商最新发布的手机信息等。网上手机购物系统具有强大的交互功能,可使商家和用户方便的传递信息,完成电子交易。1.2 网

2、上手机店的现状随着社会的发展,网络的普及,网上购物已成为在线业务的重要载体。网络购物能够绕过中介(如批发商、销售商或经销商)建立与客户的直接关系。还可以为用户提供商品的详细信息,用户可以在线购买商品,确定自己的订单。网上销售为人们提供了更广阔的环境:人们不受时间的限制,不受空间的限制,不受传统购物的诸多限制,可以随时随地在网上交易。更广阔的市场:在网上这个世界将会变得很小,一个商家可以面对全球的消费者,而一个消费者可以在全球的任何一家商家购物。更快速的流通和低廉的价格:电子商务减少了商品流通的中间环节,节省了大量的开支,从而也大大降低了商品流通和交易的成本。更符合时代的要求:如今人们越来越追求

3、时尚、讲究个性,注重购物的环境,网上购物,更能体现个性化的购物过程。1.3 网上手机店系统的构建现在流行的网上购物系统不仅要有漂亮的网页,更要有严谨的规划。每一个细小的环节都很重要。这样才能使得在电子交易时避免不必要错误发生。我将使用html、jsp等技术来编辑网页,使用了struts技术对网页之间的请求进行相应的控制,能够更轻松更方便的管理客户的请求和相应的用户管理。以及及时的将系统信息返回给展示页面。由于传统的管理信息系统的信息获取方法是由专业文字录入人员将信息输入到管理系统的数据库中,这种方法在数据量不大时有很多的应用场合。当数据量比较大,并且有较强的专业性时,录入的费用和出错的可能性都

4、相应上升。本系统通过运用hibernate技术把数据库和动态网页连接,使得出错和成本都相应的降低。本文在实际应用开发中解决方案是建立网站, 以及自己的数据库,使得所需商品信息可以及时的保存、更新,以更好的及时了解商品买卖的情况。目前网上手机商场布局比较凌乱,操作和简便性也有一定得局限性。因此有必要重新设计并且组织一个结构清晰,操作简单傻瓜式的一站式手机网上商城。因此经过此次毕业设计简单的将手机网上商城进行了实现。共 39 页 第 39 页2 系统分析2.1可行性分析2.1.1经济可行性本手机网上商店采用了b/s结构,主要看重的是其异地浏览和信息采集的灵活性。无论在任何时间、任何地点、任何系统,

5、只要可以使用浏览器上网,就都可以浏览网站。而且当网站的升级维护时,只需更新服务器端的软件就可以,这减轻了异地用户系统维护与升级的成本。数据库方面选用了mysql,它能够处理大量数据,同时保持数据的完整性并提供许多高级管理功能。并且mysql是开源的软件使得程序开发成本得到最大的节省。而且开发工具是开放的,不需要任何费用,节省了开发成本。因此经济可行。2.1.2技术可行性从技术角度考虑,java网络编程实用性很强,相关书籍资料非常丰富,我们可以在学习中逐渐完善系统的开发。并且,随着现代化的网络技术的发展,众多编程人员在论坛里相互交流经验,无形中形成了跨局域的团队互补团队合作,方便了我们在碰到技术

6、问题时候及时的获得解决办法,提高了工作效率。我们经过比较之后选择了java和mysql来开发这个系统,首先java是目前最优秀的网络软件开发语言,功能强大,简单易学,而mysql是完全免费的,功能十分强大,针对中小企业能够完全满足要求。综合以上原因,在技术上也是可行的。2.3 需求分析随着计算机以及互联网的普及,各家各户都基本上购置了计算机,网络消费也成为了当今一种流行趋势。因此网上手机商店这个时候的出现是一种必然。2.3.1系统目标本系统以网络浏览器为客户端,通过对相应网站的访问进而访问本系统,实现手机商店的网络化。2.3.2系统具体功能(1)顾客可以方便的注册与登录;(2)顾客可以灵活地检

7、索所需的商品信息及了解特价商品信息;(3)顾客可以方便的查看详细的商品资料;(4)顾客可以方便的管理自己的购物车,包括添加或删除选购商品,修改购买数量及在线下订单等一些操作;(5)顾客可以反馈自己的意见或留言;(6)商品管理员可以方便的管理商品及特价商品信息,包括新增,删除,修改商品及特价商品;(7)订单管理员可以方便的查看订单,发货与缺货处理;(8)会员管理员可以方便的查看顾客反馈的信息以及具体的处理情况;(9)系统管理员可以方便的进行系统用户的管理,包括新增,删除,修改系统用户。4 开发工具简介4.1运行环境要求4.1.1 硬件环境要求(1)中央处理器:p3 以上;(2)内存:512mb;

8、(3)硬盘空间:2g; (4)显示器:分辨率要求1024*768或更高;(5)光盘驱动器、键盘和鼠标;(6)对于网络操作要有与windows兼容的网络和网络服务器。4.1.2 软件环境要求(1)操作系统: microsoft windows98/2000/nt4.0/xp/vista;(2)数据库系统:mysql;(3)java环境:jvm虚拟机。4.2开发工具   eclipse 是一个开放源代码的、基于 java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,eclipse 附带了一个标准的插件集,包括 java 开发

9、工具(java development tools,jdt)。 eclipse最初是由ibm公司开发的替代商业软件visual age for java的下一代ide开发环境,2001年11月贡献给开源社区,现在它由非营利软件供应商联盟eclipse基金会(eclipse foundation)管理。 2003年,eclipse 3.0选择osgi服务平台规范为运行时架构。 2007年6月,稳定版3.3发布。2008年6月发布代号为ganymede的3.4版。eclipse是著名的跨平台的自由集成开发环境(ide)。最初主要用来java语言开发,但是目前亦有人通过插件使其作为其他计算机语言比如

10、c+和python的开发工具。eclipse的本身只是一个框架平台,但是众多插件的支持使得eclipse拥有其他功能相对固定的ide软件很难具有的灵活性。许多软件开发商以eclipse为框架开发自己的ide。eclipse 最初由oti和ibm两家公司的ide产品开发组创建,起始于1999年4月。ibm提供了最初的eclipse代码基础,包括platform、jdt 和pde。目前由ibm牵头,围绕着eclipse项目已经发展成为了一个庞大的eclipse联盟,有150多家软件公司参与到eclipse项目中,其中包括borland、rational software、red hat及sybas

11、e等。eclipse是一个开发源码项目,它其实是 visual age for java的替代品,其界面跟先前的visual age for java差不多,但由于其开放源码,任何人都可以免费得到,并可以在此基础上开发各自的插件,因此越来越受人们关注。近期还有包括oracle在内的许多大公司也纷纷加入了该项目,并宣称eclipse将来能成为可进行任何语言开发的ide集大成者,使用者只需下载各种语言的插件即可。虽然大多数用户很乐于将 eclipse 当作 java ide 来使用,但 eclipse 的目标不仅限于此。eclipse 还包括插件开发环境(plug-in development e

12、nvironment,pde),这个组件主要针对希望扩展 eclipse 的软件开发人员,因为它允许他们构建与 eclipse 环境无缝集成的工具。由于 eclipse 中的每样东西都是插件,对于给 eclipse 提供插件,以及给用户提供一致和统一的集成开发环境而言,所有工具开发人员都具有同等的发挥场所。这种平等和一致性并不仅限于 java 开发工具。尽管 eclipse 是使用 java 语言开发的,但它的用途并不限于 java 语言;例如,支持诸如 c/c+、cobol 和 eiffel 等编程语言的插件已经可用,或预计会推出。eclipse 框架还可用来作为与软件开发无关的其他应用程序

13、类型的基础,比如内容管理系统。基于eclipse 的应用程序的突出例子是ibm 的websphere studio workbench,它构成了 ibm java 开发工具系列的基础。例如,websphere studio application developer 添加了对 jsp、servlet、ejb、xml、web 服务和数据库访问的支持。4.3 java及相应技术简介4.3.1 java简介java是由sun microsystems公司于1995年5月推出的java程序设计语言(以下简称java语言)和java平台的总称1。用java实现的hotjava浏览器(支持java app

14、let)显示了java的魅力:跨平台、动态的web、internet计算。从此,java被广泛接受并推动了web的迅速发展,常用的浏览器现在均支持java applet。另一方面,java技术也不断更新。java平台由java虚拟机(java virtual machine)和java 应用编程接口(application programming interface、简称api)构成。java 应用编程接口为java应用提供了一个独立于操作系统的标准接口,可分为基本部分和扩展部分。在硬件或操作系统平台上安装一个java平台之后,java应用程序就可运行。现在java平台已经嵌入了几乎所有的操作

15、系统。这样java程序可以只编译一次,就可以在各种系统中运行。java应用编程接口已经从1.1x版发展到1.2版。目前常用的java平台基于java1.4,最近版本为java1.7。java分为三个体系javase(java2 platform standard edition,java平台标准版),javaee(java 2 platform,enterprise edition,java平台企业版),javame(java 2 platform micro edition,java平台微型版) 2。4.3.2 jdbc定义 jdbc(java data base connectivity,

16、java数据库连接)是一种用于执行sql语句的java api,可以为多种关系数据库提供统一访问,它由一组用java语言编写的类和接口组成种关系数据发送sql语句就是一件很容易的事。换言之,有了jdbc api,就不必为访问sybase数据库专门写一个程序,为访问oracle数据库又专门写一个程序,或为访问informix数据库又编写另一个程序等等,程序员只需用jdbc api写一个程序就够了,它可向相应数据库发送sql调用。同时,将java语言和jdbc结合起来使程序员不必为不同的平台编写不同的应用程序,只须写一遍程序就可以让它在任何平台上运行,这也是java语言“编写一次,处处运行”的优势

17、5。java数据库连接体系结构是用于java应用程序连接数据库的标准方法。jdbc对java程序员而言是api,对实现与数据库连接的服务提供商而言是接口模型。作为api,jdbc为程序开发提供标准的接口,并为数据库厂商及。jdbc为工具/数据库开发人员提供了一个标准的api,据此可以构建更高级的工具和接口,使数据库开发人员能够用纯 java api 编写数据库应用程序,同时,jdbc也是个商标名。 有了jdbc,向各第三方中间件厂商实现与数据库的连接提供了标准方法。jdbc使用已有的sql标准并支持与其它数据库连接标准,如odbc之间的桥接。jdbc实现了所有这些面向标准的目标并且具有简单、严

18、格类型定义且高性能实现的接口。 java 具有坚固、安全、易于使用、易于理解和可从网络上自动下载等特性,是编写数据库应用程序的杰出语言。所需要的只是 java应用程序与各种不同数据库之间进行对话的方法。而 jdbc 正是作为此种用途的机制。 jdbc 扩展了 java 的功能。例如,用 java 和 jdbc api 可以发布含有 applet 的网页,而该 applet 使用的信息可能来自远程数据库。企业也可以用 jdbc 通过 intranet 将所有职员连到一个或多个内部数据库中(即使这些职员所用的计算机有 windows、 macintosh 和unix 等各种不同的操作系统)。随着越

19、来越多的程序员开始使用java 编程语言,对从 java 中便捷地访问数据库的要求也在日益增加。 mis 管理员们都喜欢 java 和 jdbc 的结合,因为它使信息传播变得容易和经济。企业可继续使用它们安装好的数据库,并能便捷地存取信息,即使这些信息是储存在不同数据库管理系统上。新程序的开发期很短。安装和版本控制将大为简化。程序员可只编写一遍应用程序或只更新一次,然后将它放到服务器上,随后任何人就都可得到最新版本的应用程序。对于商务上的销售信息服务, java 和jdbc 可为外部客户提供获取信息更新的更好方法。4.4 mvc简介mvc三层架构也称mvc模式,主要是将程序开发分为model层

20、(数据持久层)、view(界面表示层)、control层(控制层)这三个层面,并将这三个层面分开来,形成了一个立体的架构6。三个层次之间的主要交互,如图4-1所示。view层control层model层图4-1 mvc模式三层架构4.4.1 mvc模型介绍 mvc英文即model-view-controller,即把一个应用的输入、处理、输出流程按照model、view、controller的方式进行分离,这样一个应用被分成三个层模型层、视图层、控制层7。(1)视图(view)代表用户交互界面,对于web应用来说,可以概括为html界面,但有可能为xhtml、xml和applet。随着应用的复

21、杂性和规模性,界面的处理也变得具有挑战性。一个应用可能有很多不同的视图,mvc设计模式对于视图的处理仅限于视图上数据的采集和处理,以及用户的请求,而不包括在视图上的业务流程的处理。业务流程的处理交予模型(model)处理。比如一个订单的视图只接受来自模型的数据并显示给用户,以及将用户界面的输入数据和请求传递给控制和模型。 (2)模型(model):就是业务流程/状态的处理以及业务规则的制定。业务流程的处理过程对其它层来说是黑箱操作,模型接受视图请求的数据,并返回最终的处理结果。业务模型的设计可以说是mvc最主要的核心。目前流行的ejb模型就是一个典型的应用例子,它从应用技术实现的角度对模型做了

22、进一步的划分,以便充分利用现有的组件,但它不能作为应用设计模型的框架。它仅仅告诉你按这种模型设计就可以利用某些技术组件,从而减少了技术上的困难。业务模型还有一个很重要的模型那就是数据模型。数据模型主要指实体对象的数据 保存(持续化)。比如将一张订单保存到数据库,从数据库获取订单。我们可以将这个模型单独列出,所有有关数据库的操作只限制在该模型中。(3)控制(controller)可以理解为从用户接收请求, 将模型与视图匹配在一起,共同完成用户的请求。划分控制层的作用也很明显,它清楚地告诉你,它就是一个分发器,选择什么样的模型,选择什么样的视图,可以完成什么样的用户请求。控制层并不做任何的数据处理

23、。例如,用户点击一个连接,控制层接受请求后, 并不处理业务信息,它只把用户的信息传递给模型,告诉模型做什么,选择符合要求的视图返回给用户。因此,一个模型可能对应多个视图,一个视图可能对应多个模型8。4.4.2 mvc设计模式的实现 (1)视图。是模型的表示,它提供用户交互界面。使用多个包含单显示页面的用户部件,复杂的web页面可以展示来自多个数据源的内容,并且网页人员,美工能独自参与这些web页面的开发和维护。(2)控制。为了能够控制和协调每个用户跨越多个请求的处理,控制机制应该以集中的方式进行管理。应用程序的控制器集中从客户端接收请求,决定执行什么商业逻辑功能,然后将产生下一步用户界面的责任

24、委派给一个适当的视图组件。用控制器提供一个控制和处理请求的集中入口点,它负责接收、截取并处理用户请求;并将请求委托给分发者类,根据当前状态和业务操作的结果决定向客户呈现的视图。(3)模型。mvc系统中的模型从概念上可以分为两类系统的内部状态和改变系统状态的动作。模型是你所有的商业逻辑代码片段所在。业务处理对象封装了具体的处理逻辑,调用业务逻辑模型,并且把响应提交到合适的视图组件以产生响应。业务实体对象可以通过定义属性描述客户端表单数据。通过业务实体对象实现了对视图和模型之间交互的支持。实现时把"做什么"(业务处理)和"如何做"(业务实体)分离。这样可以实

25、现业务逻辑的重用8。4.5 mysql 概述 mysql是一个精巧的sql数据库管理系统,虽然它不是开放源代码的产品,但在某些情况下你可以自由使用。由于它的强大功能、灵活性、丰富的应用编程接口(api)以及精巧的系统结构,受到了广大自由软件爱好者甚至是商业软件用户的青睐,特别是与apache和php/perl结合,为建立基于数据库的动态网站提供了强大动力。mysql是一个真正的多用户、多线程sql数据库服务器。sql(结构化查询语言)是世界上最流行的和标准化的数据库语言。mysql是以一个客户机/服务器结构的实现,它由一个服务器守护程序mysql和很多不同的客户程序和库组成。sql是一种标准化

26、的语言,它使得存储、更新和存取信息更容易。例如,你能用sql语言为一个网站检索产品信息及存储顾客信息,同时mysql也足够快和灵活以允许你存储记录文件和图像。 mysql 主要目标是快速、健壮和易用。最初是因为我们需要这样一个sql服务器,它能处理与任何可不昂贵硬件平台上提供数据库的厂家在一个数量级上的大型数据库,但速度更快,mysql就开发出来。自1996年以来,我们一直都在使用mysql,其环境有超过 40 个数据库,包含 10,000个表,其中500多个表超过7百万行,这大约有100 个吉字节(gb)的关键应用数据。 mysql建立的基础是业已用在高要求的生产环境多年的一套实用例程。尽管

27、mysql仍在开发中,但它已经提供一个丰富和极其有用的功能集13。4.6 b/s模式介绍b/s结构:(browser/server,浏览器/服务器模式):是web兴起后的一种网络结构模式,web浏览器是客户端最主要的应用软件。这种模式统一了客户端,将系统功能实现的核心部分集中到服务器上,简化了系统的开发、维护和使用。客户机上只要安装一个浏览器(browser),如netscape navigator或internet explorer,服务器安装oracle、sybase、informix或 sql server等数据库。浏览器通过web server 同数据库进行数据交互。b/s结构的使用越

28、来越多,特别是由需求推动了ajax技术的发展,它的程序也能在客户端电脑上进行部分处理,从而大大的减轻了服务器的负担;并增加了交互性,能进行局部实时刷新。4.6.1 b/s结构的优点b/s结构最大的优点就是可以在任何地方进行操作而不用安装任何专门的软件。只要有一台能上网的电脑就能使用,客户端零维护。系统的扩展非常容易,只要能上网,再由系统管理员分配一个用户名和密码,就可以使用了。甚至可以在线申请,通过公司内部的安全认证(如ca证书)后,不需要人的参与,系统可以自动分配给用户一个账号进入系统。4.7 hibernate技术概述在项目中使用hibernate框架,非常关键的一点就是要了解hibern

29、ate的核心接口。hibernate接口位于业务层和持久化层,如图4-2所示。图4-2 hibernate核心接口的层次架构关系hibernate的核心接口一共有5个,分别为:session、sessionfactory、transaction、query和configuration。这5个核心接口在任何开发中都会用到。通过这些接口,不仅可以对持久化对象进行存取,还能够进行事务控制。 session接口:session接口负责执行被持久化对象的crud操作(crud的任务是完成与数据库的交流,包含了很多常见的sql语句。)。但需要注意的是session对象是非线程安全的。同时,hibernat

30、e的session不同于jsp应用中的httpsession。这里当使用session这个术语时,其实指的是hibernate中的session,而以后会将httpsesion对象称为用户session。sessionfactory接口:sessionfactroy接口负责初始化hibernate。它充当数据存储源的代理,并负责创建session对象。这里用到了工厂模式。需要注意的是sessionfactory并不是轻量级的,因为一般情况下,一个项目通常只需要一个sessionfactory就够,当需要操作多个数据库时,可以为每个数据库指定一个sessionfactory。configurat

31、ion接口:configuration接口负责配置并启动hibernate,创建sessionfactory对象。在hibernate的启动的过程中,configuration类的实例首先定位映射文档位置、读取配置,然后创建sessionfactory对象。transaction接口:transaction接口负责事务相关的操作。它是可选的,开发人员也可以设计编写自己的底层事务处理代码。query和criteria接口:query和criteria接口负责执行各种数据库查询。它可以使用hql语言或sql语句两种表达方式。4.8 struts技术概述struts 是一组相互协作的类、servle

32、t 和 jsp 标记组成的一个可重用的 mvc2 设计。这个定义表示struts是一个框架,而不是一个库,但 struts框架也包含了丰富的标记库和独立于该框架工作的实用程序类。4.8.1 struts 概览(1)client browser(客户浏览器) 来自客户浏览器的每个 http 请求创建一个事件。web 容器将用一个http响应作出响应。(2)controller(控制器)控制器接收来自浏览器的请求,并决定将这个请求发往何处。 就 struts而言,控制器是以servlet 实现的一个命令设计模式。struts-config.xml 文件配置控制器命令。(3)业务逻辑 业务逻辑更新模

33、型的状态,并帮助控制应用程序的流程。就 struts而言,这是通过作为实际业务逻辑“瘦”包装的action 类完成的。(4)model(模型)的状态 模型表示应用程序的状态。业务对象更新应用程序的状态。actionformbean在会话级或请求级表示模型的状态,而不是在持久级。jsp 文件使用 jsp 标记读取来自 actionformbean的信息。(5)view(视图) 视图就是一个 jsp 文件。其中没有流程逻辑,没有业务逻辑,也没有模型信息 只有标记。标记是使struts 有别于其他框架(如 velocity)的因素之一。4.8.2 struts中的controller(控制器)命令设

34、计模式的实现: struts 的控制器将事件(事件通常是 http post)映射到类的一个 servlet。actionservlet (command)创建并使用 action 、actionform 和actionforward。 通过struts-config.xml 文件配置该 command。从而扩展 action 和actionform来解决特定的问题。可以通过扩展 actionservlet 来添加 command 功能。在struts框架中控制器组件由三个部分构成:(1)消息控制模块:用户所有的提交请求都发往消息控制模块,在由消息总线模块根据视图映射模块找到消息处理模块来执行

35、处理逻辑。消息控制模块接收所有用户的请求,并根据请求视图找到处理。strtus中通过actionservlet和requestprocessor类来完成。(2)消息处理模块:该模块执行该消息的逻辑处理,因此通常由用户扩展实现。struts中通过action类来实现。(3)视图映射模块:控制器逻辑和视图逻辑之间的结合是通过配置模块和配置文件建立其的链接。struts中配置模块通过moduleconfig类来完成,而配置文件由struts-config.xml文件提供。4.8.3 struts中的view(视图)视图组件通过jsp组件实现的。struts框架对视图组件进行了扩展和封装。struts

36、对视图的扩展提供了一组扩展服务器标签用来提供视图显示以及传递数据到处理缓冲,而处理缓冲由actionform的扩展类来实现。struts框架利用actionform bean来实现视图与控制器之间的数据的交互,维持会话级或请求级的模型的状态。服务器标签主要包括:html视图标签 logic逻辑流程控制标签 bean数据缓冲读取标签4.8.4 struts中的model(模型)(1)struts框架中并没有定义特定的模型组件,而是希望由用户自己决定选择合理的模型组件。j2ee中可用的模型组件包括:javabean 用户定义组件; ejb 组件,由ejb容器实现组件; jdo未来j2ee数据访问模

37、型;一些扩展框架如hibernate;(2)模型中状态的级别 会话级或请求级:actionform bean来维持 ;持久级:模型组件来维持。5 系统总体设计5.1 系统解决方案本手机网上商店网站采用的是基于网络的browser/server(浏览器/服务器)结构的软件实现,系统的实现分为3个层次:模型层(model)、视图层(view)、控制层(controller)。5.1.1 模型层模型层(model)主要负责系统的各种数据,由于本毕业设计管理系统的数据存储量比较大,所以本系统利用mysql 作为数据库管理系统。5.1.2 视图层视图层(view)主要负责前台的展示和获取前台信息等工作,

38、比如手机的功能展示等等,这里使用了jsp技术结合ajax技术来实现所有用户要求的。5.1.3 控制层控制层(controller)的功能是控制器接收用户的请求,然后调用某个模块来处理用户的请求,在控制器的控制下,再将处理的结果交给某个视图进行格式化输出给用户。5.2 系统结构划分系统总体用例图,如图 5-1所示。 图51系统总体用例图5.3 模块划分系统模块划分,如图52所示。百机会-网上手机商店登录注册模块浏览检索模块购物车模块后台登录模块反馈留言模块订单管理模块商品管理模块特价商品管理系统用户管理会员管理模块图52模块分布图6 系统详细设计6.1 数据库的设计6.1.1 系统数据库物理模型

39、图系统数据库物理模型,如图6-1所示。图6-1数据库物理模型图6.1.2 数据库和数据表的设计“网上手机店”数据库,包含会员级别,注册会员,手机类别,手机,购物车选购,购物车,订单,留言,系统用户等几个数据表,其中“会员级别表”是用来存储会员等级,包括id号,级别名称,优惠百分比;“注册会员表”包括id号,登录账号,登录密码,真实姓名,联系电话,联系地址,邮政编码,注册日期,最近登录日期,登录次数,电子邮箱;“手机类别表”存储包括id号,类别名称,类别描述;“手机表”存储包括id号,商品类别id,商品名称,商品价格,商品型号,商品特价,商品图片,商品描述,生产厂家,出厂日其,有无特价;“购物车

40、表”包含id号,会员id,总金额,购物车状态;“订单表”包含id号,会员id,购物车id,订单编号,订单日期,订单状态;“留言表”包含id号,会员id,管理员id,留言标题,留言内容,留言日期,留言回复,回复日期;“系统用户表”id号,管理员类型,管理员真实姓名,管理员登录账号,管理员登录密码。6.1.3 各数据表设计与实现(1)会员级别,如表6-1所示。表6-1会员级别表字段名称数据类型描述idint(4)id号levelnamechar(20)级别名称favourableint(4)优惠百分比(2)注册会员表,如表6-2所示。表6-2 注册会员表字段名称数据类型描述idint(4)id号m

41、emberlevelint(4)会员级别idloginnamechar(12)登录账号loginpwdchar(12)登录密码membernamechar(20)真是姓名phonechar(15)联系电话addressnvarchar(100)联系地址zipchar(10)邮政编码regdatedatetime(0)注册时间lastdatedatetime(0)最近登录时间logintimesint(4)登录次数emailnvarchanr(100)电子邮箱(3)手机类别表,如表6-3所示。表6-3 手机类别表字段名称数据类型描述idint(4)手机类别idcatenamenchar(40)类

42、别名称catedesctext(0)类别描述(4)手机表,如表6-4所示。表6-4 手机表字段名称数据类型描述idint(4)id号categoryint(4)手机类别idmernamenchar(40)手机名称pricedecimal(8)手机价格spricedecimal(8)手机特价mermodelnchar(40)手机型号picturenvarchar(100)手机图片merdesctext(0)手机描述manufacturenchar(60)生产厂家leavefactorydatedatetime(0)出厂日期specialint(4)有无特价 (5)购物车选购表,如表6-5所示。

43、表6-5 购物车选购表字段名称数据类型描述idint(4)id号cartint(4)购物车idmerchandiseint(4)手机idnumberint(4)手机数量pricedecimal(4)手机价格moneydecimal(4)金额(6)购物车表,如表6-6所示。表6-6 购物车表字段名称数据类型描述idint(4)id号memberint(4)会员idmoneydecimal(9)总金额cartsatusint(4)购物车状态(7)订单表,如表6-7所示。表6-7 订单表字段名称数据类型描述idint(4)id号membersint(4)会员idcartint(4)购物车idorde

44、rnonchar(20)订单编号orderdatedatetime(0)订单日期orderstatusint(4)订单状态 (8) 留言表,如表6-8所示。 表6-8 留言表 字段名称数据类型描述membersint(4)会员idadminint(4)管理员idtitlenchar(4)留言标题contenttext(60)留言内容leavedatedatetime(0)留言日期answercontent text(0)回复内容answerdatedatetime(0)回复日期(9)系统用户表,如表6-9所示。 表6-9 系统用户表字段名称数据类型描述idint(4)id号admintypei

45、nt(4)管理员类型adminnamechar(12)管理员真实姓名loginnmaechar(12)管理员登录账号loginpwdchar(12)管理员登录密码6.2 工程设计对于本网上手机商店,所有工程均使用eclipse创建,调试,开发以及部署执行的,具体步骤如下:(1)建立工程在eclipse中,file->new->web project,命名为phones。(2)添加框架插件选中当前工程,右键>myeclipse->add hibernate capabilitids 和 右键>myeclipse->add struts capabilitids

46、,经过两个步骤,hibernate和struts集合开发框架就大体的加入到了工程中。(3)工程结构,如图6-2所示。 图6-2 工程结构图6.3 模块设计6.3.1 顾客登录(1)模块功能 顾客可以通过填写注册信息注册成为会员,会员登录后才能进行购物车的管理以及意见的反馈,未登录的会员或者为注册的顾客只能检索与浏览商品信息。(2)界面效果,如图6-3所示 。图6-3 登录注册模块(3)模块主要代码及详解当会员登录的时候,首先在default.jsp中填写登录表单,填写完毕提交之后,defaul.jsp中登录表单的内容由struts自动封装到memloginform对象中,并送交validato

47、r进行表单有效性验证,如果验证失败则返回default.jsp要求用户重新填写表单直到通过验证,否则就将memloginform对象送给loginaction的login方法进行处理,处理完成后将处理结果反馈给default.jsp并完成登录。 /* 会员登录代码 */public member memlogin(string loginname, string loginpwd) throws exception session session = mysessionfactory.getsession();transaction tx = null;member mem = null;tr

48、ystring hql = "select a from member as a where a.loginname=:loginname and a.loginpwd=:loginpwd"query query = session.createquery(hql);query.setstring("loginname", loginname);query.setstring("loginpwd", loginpwd);query.setmaxresults(1);tx = session.begintransaction();mem

49、 = (member)query.uniqueresult();mem.setlogintimes(integer.valueof(mem.getlogintimes().intvalue()+1);mem.setlastdate(new date();session.update(mem);mit();catch(exception ex)if(tx!=null)tx.rollback();("在执行memserviceimpl类中的memlogin方法时出错n");ex.printstacktrace();finallymysessionfacto

50、ry.closesession();return mem;6.3.2 手机检索浏览模块(1)模块功能顾客可以根据不同的手机种类浏览手机的信息,也可以输入关键字进行手机检索。(2)程序效果,如图6-4所示。图6-4 手机检索以及浏览模块(3)模块主要代码及详解用户的请求,例如查看手机。均通过调用meraction类的相应方法进行处理,meraction类中的方法在收到请求后,根据具体的请求调用merservice接口中的相应dao方法完成数据库的访问,并将检索得到的结果返回给meraction,meraction则将最终的处理结果保存到request对象中,由相应的jsp页面带回并展示给用户。/

51、*处理分类查询手机请求*/public actionforward searchmer(actionmapping mapping, actionform form,httpservletrequest request, httpservletresponse response) list merlist = null;merservice service = new merserviceimpl();int pageno = 1; /页号int pagesize = 15; /每页记录数int totals = 0; /记录总数int totalpages = 0; /总页数if (key!

52、=null)key = new string(key.getbytes("iso8859-1"),"gb2312");request.setattribute("key", key);if(haswhere)hql = hql + " and a.mername like '%"+key+"%'"hql1 = hql1 + " and a.mername like '%"+key+"%'"action = action +

53、"key="+key+"&"elsehql = hql + " where a.mername like '%"+key+"%'"hql1 = hql1 + " where a.mername like '%"+key+"%'"action = action + "&key="+key+"&"request.setattribute("action", acti

54、on);merlist = service.browsemer(pagesize,pageno,hql);totals = service.countrecord(hql1);6.3.3 购物车模块(1)模块功能顾客需要输入注册账号与密码登录后便可以使用购物车以及对其进行相应的管理,如将选中的手机放入购物车,修改选购手机的数量,删除购物车中的手机,在线下订单以及查看订单等。(2) 程序效果,如图6-5所示。图6-5 购物车模块图(3) 模块主要代码及详解用户请求,例如购物车查看。都是通过直接调用了cartaction类的相应方法进行处理,cartaction类中的方法在收到请求后,根据具体的请求调用cartservice接口中的相应dao方法完成数据库的访问,并将检索得到的结果返回给cartaction,cartaction则将最终的结果保存到request对象中,由相应的jsp页面带回并展示给用户。/* 装载指定会员的购物车 */public cart loadcart(member member) throws exception session session = mysessionfactory.getsession();transaction tx = null;cart cart

温馨提示

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

评论

0/150

提交评论