小型网上书店_第1页
小型网上书店_第2页
小型网上书店_第3页
小型网上书店_第4页
小型网上书店_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

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

文档简介

1、 基于Web设计实习报告课程设计题目:网上书店桂林理工大学 信息科学与工程学院 班级:计本10-2报告人姓名: 戚荣家 学号:3100717218 承担角色:组长同组组长:戚荣家 同组其他成员:梁积东,何子良,兰佳浪,潘曾尚实验指导教师: 吴名欢实验地点:1409完成起止日期:7月1日到7月12日一、系统设计概述(目的、任务、开发环境、参考资料)网站主要提供的基本服务项目有:用户的注册,登录;用户的分级浏览或图书选购;店主对进书,售书,库存,客户,订单的管理;开发环境:MyEclipse和Access。二、系统需求分析随着时代的发展,网上购物的流行,喜欢读书的人也喜欢在网上买书,所以网上书店越

2、来越流行。本系统就是在这一背景下设计的。3、 系统设计的基本原理和采用的主要方法与技术系统的设计是基于jsp和javaBean来构建的网上书店,其中也运用了MVC模式。以及Access的数据库连接。4、 本人在此次实习负责的系统模块设计与实现。本人负责数据库的连接和所有代码整合,还有一些界面的设计模块。代码主要分为四个部分。1.登录、注册,2.选书,3.提交订单和付款,4.还有店长管理。5、 个人遇到的困难与获得的主要成果(本节内容不得少于3页)在运行的结果中可以提现。见附录本人遇到了些许小困难,但都得到了适当的解决。比如数据库连接问题,(连不上);代码乱码;模块的整合问题等等。成果:懂得了系

3、统的概念和模块的整合。六、测试与运行记录在测试的结果中可以提现。见附录7、 系统设计完成结果分析与个人小结通过近两周的学习,我觉得本次实习收获还是挺大的。我觉得,如果我们决定要做一个系统,就得对这个系统有一个整体得把握,首先要进行系统的规划和选择,接着就是系统的设计,其中系统设计包括三个部分:1.确定系统需求;2.系统需求结构化:过程建模,这一步骤主要就是画数据流图;3.系统需求结构化:概念数据建模,这一过程主要是画实体关系图。然后就是进行系统设计,系统设计包括设计人机界面和数据库设计。最后一步就是系统的实现与运行。在做书店系统分析与设计的的时候,我和我们的小组成员讨论过,我们清晰地了解我们系

4、统所要实现的功能。当然,我们做东西,也是要追求进步,如果说做出来的东西和以前的系统都没什么两样,这样意义也不大。不过,这也得是在我们能力所及的范围内,我们得适当地把握好自己的时间和现有资源进行适当的设计。相信自己的努力还是能有一个很好的结果,我们得对自己的发展有一个好的概括。书店系统分析与设计的实习一直伴随着我们,说实在话,一直觉得自己有做不完的作业,刚开始还有些抱怨,但随着作业的进行,我们慢慢看到了自己的小小成果,觉得付出有了回报,并开始乐在其中。但我们相信只要坚持做下去,我们会收获到成功的喜悦的!最后我们完成了本次实习的基本要求。8、 附录(软件配置、个人完成的程序模块和文档清单)(其中代

5、码太多已删除)我们使用JSP和Java Bean来构建一个网上书店。介绍的例子可以分成两大部分,第一部分是普通程序,用于客户在网上选购图书,第二部分是管理程序,用于在服务器端处理客户的定单。客户端程序由以下几个部分构成:default.htm:会员登录界面(首页);checklogon.jsp:检测登录代码和密码是否一致,根据由JavaBean返回的结果显示不同的信息。BuyerBean:会员的合法性检验所用的Bean;booklist.jsp:给登录会员显示当前书店中可供选择的图书;addcart.jsp:将所选的图书加入购物车;shoppingcart.jsp:查看购物车的内容;本例的数据

6、库采用Access(.MDB数据库),对数据库的访问采用便于理解的JDBC-ODBC方式,在使用本例前先在本地数据库建立一个ODBC数据源:bookstore。设置步骤如下:(1)在开始-设置-控制面版(Win98、NT4.0)中选取“数据源(ODBC)”;在Win 2000 Professional和Server中分别位于“开始-设置-控制面版-管理工具”和“开始-程序-管理工具”下。(2)启动“数据源(ODBC)”配置程序,界面如图1-1所示。图1-1 ODBC数据源管理界面(3)在图1-1中“系统DSN”选项下单击“添加”按钮,来添加一个系统的数据源(DSN),则出现如图1-2所示数据源

7、驱动程序选择界面:图1-2 数据源驱动程序选择界面(4)在图1-2中选择“Microsoft Access Driver (*.mdb)”单击“完成”加载Access数据库的驱动,则出现如图1-3所示数据库ODBC安装界面:图1-3 数据库ODBC安装界面(5)在图1-3中单击“选择(S)”按钮,启动一个类似资源管理器的界面来选择数据库,如图1-4所示,在图1-4所示的界面中选择bookstore.mdb。图1-4 数据库选择界面1.1 会员登录做一个网上书店,在顾客开始购书之前,必须要记录用户的一些信息以便用户在不同的分类、不同的页面购书时,最后能够去收款台统一结帐,而且网上书店同时有许多人

8、在选购图书,也要求对不同的顾客进行区分,我们可以要求顾客在购书之前进行注册成为会员,以后只用会员代码和密码即可登录。为了便于说明现在的电子商务网站,由JSP做页面表现,由Java Bean做应用逻辑的结构,在本例中将会员登录程序分成两大部分:一、Java Bean用于对数据库的操作,验证用户名和密码是否正确;二、JSP页面部分,用于供用户会员代码和密码以及显示验证结果。1.1.1 会员登录Java Bean我们网上书店中的会员信息的库结构如图1-5所示:图1-5 会员信息库其中memberID 是主键,用于区分不同的会员,新会员注册时只能使用没有被使用的用户代码。在验证时我们只要使用验证用户的

9、memberID和其pwd是否一致即可判断该用户是否合法,如果合法则其登录次数加1。下面是用户验证部分的Java Bean的代码清单1-1 BuyerBean.Java在BuyerBean中用了package cuug; 在发布到WEB SERVER时,可以用JAR(JDK中带的打包工具)把编译后的BuyerBean.class 打包成JAR文件在服务器的环境变量classpath中给予指定,或者在服务器classpath环境变量指定的目录下建一个cuug文件夹,把BuyerBean.class放到cuug目录下。1.1.2 会员登录htm与JSP会员登录要由两个部分来完成,第一个页面用于会员

10、输入其ID和密码,当然首页还可以加一些广告等的其它信息,在本例中略过。清单1-2 default.htm在本例中提供了一个文本框供用户输入会员代号和登录密码,其运行结果如图1-6所示,当会员输入其代码和密码后调用checklogon.jsp 来验证该网络用户是否是合法会员。图1-6 会员登录页在checklogon.jsp 中接收从default.htm中由用户所填的会员代码和密码,把它传给BuyerBean,由BuyerBean判断该用户的会员代码和密码的正确性,若正确显示欢迎信息;若不正确,则提供一个重新登录的链接。Checklogon.jsp的源代码如下:清单1-3 checklogon

11、.jsp登录正确时的结果如图1-7所示,错误时的结果如图1-8所示。图1-7 用户登录正确(会员abcd的真实姓名是cuug001)图1-8 用户登录错误1.2 选书会员登录之后,合法的用户将可以看到本书店中可供选择的图书,并且将他感兴趣的书放入“购物车”,在去“收银台”结帐之前,该用户可以放弃购买其购物车中的任何一本书。在此处我们用BookBean来获取图书的信息,在Booklist.jsp中显示这些书。在会员选书部分,我们仍用Java Bean来操作数据库,用jsp来做页面表现。1.2.1 选书Java Bean图书信息的表结构如图1-9所示,为了便于说明,在本例中price也设置成了St

12、ring型,在实际应用中应该设置成货币或浮点型:图1-9 图书信息的表结构其中,bookISBN是主键,区分不同的图书。Java Bean要根据不同的图书的bookISBN来获得其相应的书名、作者、出版社、价格、简介等信息。同时Java Bean还要有列出书店中所有图书的信息的功能。清单1-4 BookBean.Java1.2.2 选书JSP会员正确登录之后,即可进入书店进行选书,我们已经在checklogon.jsp中将会员的代码(memberID)放入系统的session中,为了保证用户只能从主页面登录进入书店,我们在给会员显示可供选择的图书之前,先检查session中是否有memberI

13、D的合法值,如果没有则提示用户先去登录。清单1-5 booklist.jsp已经登录过的会员和没有登录过的会员进入该页面是的结构分别如图1-10和图1-11所示:正确登录的会员的会员代码在浏览器的标题栏显示为:member:“会员代码”。图1-10 会员abcd正确登录图1-11 会员未登录直接来选书在本例中利用JavaScript语句定义了一个函数来将所调用另外的一个jsp来处理把书加入购物车的操作:该函数用于打开addcart.jsp并切将图书编号作为参数传给addcart.jsp。addcart.jsp利用Cookie来保存所选购的图书信息,Cookie相当于一个购物车。为了与其他的Co

14、okie变量区分,每个写入Cookie的图书编码前面都加上“ISBN”作为标志,向购物车中加入图书的代码如下:清单1-6 addcart.jsp在addcart.jsp中利用JavaScript定义了一个函数Timer(),由它来控制该窗口的显示时间()。继续购买部分也是由JavaScript定义的函数来控制关闭本窗口。其运行结果如图1-12所示。图1-12 加入购物车无论从图1-12还是图1-13所示的界面中,都提供了一个查看购物车的超链接,查看购物车的程序如下所示,它从Cookie中取出图书的编号,并将它传给BookBean,由BookBean来获得图书的详细资料。查看购物车的JSP代码s

15、hoppingcart.jsp代码如下:清单1-7 shoppingcart.jsp 查看购物车的结果如图1-13所示:图1-13 查看购物车内容在查看购物车内容时提供了一个删除图书的功能,其目的是从购物车删除不想购买的图书,其源代码如下:清单1-8 delbook.jsp本例中利用jsp:forward动作在删除图书动作完成之后,将页面继续转向购物车页面。即图1-14只显示一瞬间,浏览器的内容由成为购物车内容的页面。图1-14 删除图书的页面如果一个会员选了很多书,逐个删除比较麻烦。为了方便会员放弃选购的所有图书,重新开始选书,本例提供了清空购物车程序(emptycart.jsp),用于清空

16、购物车,其原理与删除图书相同,只是把全部的Cookie中图书的有关的内容都清空了。其代码如下:清单1-9 emptycart.jsp图1-1 清空购物车的页面从图书选择页面和购物车页面,点图书名称,都可以查看图书的详细信息,查看图书详细信息的jsp仍用BookBean来获取图书的详细信息,只是在该页中可以看到更加详细的信息:清单1-10 bookinfo.jsp其运行结果如图1-16所示。图1-16 图书详细信息1.3 定单提交及查询用户一旦确定购物车中所选的图书都是其所要购买的,就要到去提交其定单,以便书店按照相应的方式进行处理。而且,为方便用户是否已经提交定单,及定单的状态,本例提供了定单

17、查询功能。在此处我们用OrderBean来将定单提交到数据库中,在order.jsp中显示并提交定单信息,queryorder.jsp来查询定单。在会员选书部分,我们仍用Java Bean来操作数据库,用jsp来做页面表现。1.3.1 定单提交Java Bean为了减少数据冗余,定单信息由两张表来记录其信息:orderInfo,记录定单的有关公用信息,orderdetail,记录该定单包含哪些书籍及数量,表结构分别如下:图1-17 定单信息表结构图1-18 定单详细所有的对数据库的操作都由JavaBean来完成,其代码如下:清单1-11 OrderBean.Java在本Bean中,如果一张定单

18、中有多种书籍,可以以“BOOKISBN = BOOKCOUNT;BOOKISBN = BOOKCOUNT;”的形式组成字符串,来向JAVABEAN中的bookinfo赋值。在赋值后,Bean内部完成创建定单,并将各个图书信息拆分,提交定单的详细信息。1.3.2 定单提交JSP用jsp页面来显示用户所选的图书的信息,并提供一个提交按纽,为便于程序的管理,我们将显示和处理结果放在一个JSP中,其代码如下:清单1-12 order.jsp在本JSP中将图书信息按照“BOOKISBN = BOOKCOUNT;BOOKISBN = BOOKCOUNT;”的形式组成字符串,用来向JAVABEAN中的bookinfo赋值,并根据JSP的处理结果进行响应的处理:如果定单被正确处理则,显示定单号并清空cookie(购物车)信息,如果定单未被正确提交,则显示出错信息。

温馨提示

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

评论

0/150

提交评论