毕业设计(论文)基于jsp的网上书店毕业设计论文.doc

上传人:仙人指路1688 文档编号:3979360 上传时间:2023-03-30 格式:DOC 页数:22 大小:591.50KB
返回 下载 相关 举报
毕业设计(论文)基于jsp的网上书店毕业设计论文.doc_第1页
第1页 / 共22页
毕业设计(论文)基于jsp的网上书店毕业设计论文.doc_第2页
第2页 / 共22页
毕业设计(论文)基于jsp的网上书店毕业设计论文.doc_第3页
第3页 / 共22页
毕业设计(论文)基于jsp的网上书店毕业设计论文.doc_第4页
第4页 / 共22页
毕业设计(论文)基于jsp的网上书店毕业设计论文.doc_第5页
第5页 / 共22页
点击查看更多>>
资源描述

《毕业设计(论文)基于jsp的网上书店毕业设计论文.doc》由会员分享,可在线阅读,更多相关《毕业设计(论文)基于jsp的网上书店毕业设计论文.doc(22页珍藏版)》请在三一办公上搜索。

1、1.网上书店系统概述网上书店是电子商务的一部分,电子商务应有的功能、网上书店也应该具有。由于商家软件设计不大一样,因此网上书店的功能也不完全一致,有的多,有的少。作者本人认为,网上书店是一种无店铺,人不出门,在计算机联网的网络上作业,就可进行远距离的图书销售与订购。一般应具有如下功能:(1)向上网顾客提供图书期刊在线电子版(虚拟版),供顾客订购 、下载;(2)提供新书目、新书内容介绍、书评等,供顾客选择图书时参考;(3)提供书店存货书目,供顾客挑选或补全、补缺;(4)提供网上书店的有关资料,如营业执照等,让顾客了解网上书店的可信程度;(5)开辟网上论坛,供顾客在网上讨论有关图书内容与网上发行中

2、的有关问题;(6)通过网络收集顾客采访图书的计划与要求,顾客的阅读爱好、兴趣、阅读历史和对网上书店的建议与要求;(7)网上订购图书、期刊;(8)安全认证、数字签名、网上结算和支付,并提供正式发票;(9)图书配送;(10)退货处理;(11)质量监控。但是由于时间及本人能力方面的一些条件所限,本次设计的网上书店系统主要是以实现购书和定单的功能作为设计的重点,实现了网络书店的一些最基本和必须的功能,其他的详细复杂的功能并没有涉及。2.系统需求分析及设计2.1业务及用户需求分析要设计一个实用的网络书店销售管理系统,就必须首先明确应用环境对系统的要求。本系统开发的总体设计目标为开发一个在线系统,实现图书

3、的在线查找、销售,以及在线管理等功能。系统以Windows操作系统为平台,网络联接以TCP/IP协议为基础,使用Web服务器提供信息的浏览和查询,采用流行的B/S三层体系结构。因此,该系统需主要满足以下几方面需求: 1.用户的管理,含注册、检验及修改等功能。2.在线图书销售,包括查找、购物车及定单等功能。 3.图书在线管理,如浏览、修改、添加和删除图书等。2.2系统可行性分析本节从技术的可行性,经济的可行性以及操作的可行性三个方面来说明本网站的可行性。2.2.1技术可行性1.硬件:计算机的存储量大,运算速度快,外部设备的功能好、效率高、可靠性高,通信设备的能力、质量都可以满足要求。2.系统软件

4、:(1)操作系统Windows XP/2000接口能力强,数据库管理系统的功能足够。(2)Java语言是一种优秀的编程语言。它最大的优点就是与平台无关,在Windows 、Linux以及其它平台上,都可以使用相同的代码。“一次编写,到处运行”的特点,使其在互联网上广泛采用。JSP+JavaBeans几乎可以在所有平台上通行无阻,从一个平台移植到另外一个平台,JSP和JavaBeans甚至不用重新编译。除此之外Java语言还提供了一些有用的新特性,使得使用Java语言比C+语言更容易写出“无错代码”。3.有专用的开发应用软件:(1)Microsoft Office Access,主要针对数据库的

5、建立。(2)Dreamweaver,主要针对网页的制作。工欲善其事,必先利其器。Dreamweaver 是Macromedia公司推出的可视化网页制作工具,制作出来的网页兼容性比较好,制作效率也很高。可以控制和删除冗余代码,使网页文件的结构更加合理,从而能够快速下载。与其他软件不同,Deamweaver采用的是浮动面版的设计风格,而Dreamweaver的直观性与高效性是其他软件所无法比拟的。2.2.2经济可行性从经济角度看,书店对系统的投资要小于系统对书店的回报,书店决策者才会实施系统计划。从本系统开发的角度出发,系统开发成功会减低人员费用的支出,办公用品的支出,同时,大量的用户增加会给书店

6、无法量化的估计,会使书店获得更大的收益。2.2.3操作可行性本系统大概需要四个月的时间完成。前三个星期主要是以看书以及收集有关系统方面的资料为主,接下来就是对系统的分析,到做数据库,界面,以及中间的连接。系统对于熟悉JSP编程的作者来说是可行的。2.3系统开发技术及其关系图本网上书店系统开发应包括以下技术:1.通信平台技术2.接口技术3.程序设计代码技术4.数据库存储技术它们的关系可以用图2.1来表示:图2.1 网上书店系统开发技术基础及其关系图2.5系统数据流程分析2.5.1顶层数据流图说明:未注册用户通过注册后可以登录到前台进行购书,管理员通过登录可以进入后台进行管理。系统顶层数据流图如下

7、图2.2所示。图2.2系统顶层数据流图2.5.2第二层数据流图前台购书和后台管理根据顶层数据流图,对前台购书和后台管理模块作进一步分解,得到第二层数据流图,分别如图2.3和图2.4。1.前台购书用户登录后进行书籍浏览和查询,对书籍信息有了一定了解后可根据自己的需求进行购书,购书后将所需书放入购物车,最终确定要购买的图书,提交定单,等待定单的处理结果。系统第二层数据流图(前台购书)如下图2.3所示。图2.3系统第二层数据流图(前台购书)2.后台管理管理员可以登陆到后台,查看相关的定单信息,然后修改定单的信息,主要是审核定单的有效性。系统第二层数据流图(后台管理)如下图2.4所示:图2.4系统第二

8、层数据流图(后台管理)2.5.3第三层数据流图用户登陆处理 为保证数据的有效和客户的管理,系统必须登陆后才能进行购买图书的相关操作,登陆是系统安全和数据有效性验证的第一部分。系统第三层数据流图(用户登陆)如下图2.5所示:图2.5系统第三层数据流图(用户登陆)2.6数据字典(DD)数据字典是在系统数据流程图的基础上。进一步定义和描述所有的数据项、数据结构、数据存储、处理过程和外部实体的详细逻辑内容与特征的工具。数据字典的任务是对于数据流程图中出现的元素的名字都有一个确切的解释。因此,建立数据字典的工作量很大,相当烦琐。但这是一项必不可少的工作。数据字典在系统开发中具有十分重要的意义,不仅在系统

9、分析阶段要使用它,在系统的整个研制过程中以及系统运行中都要使用它提供帮助。用户数据字典如下表2.1所示。文件名:用户表编号:1组成:用户ID+用户名+用户密码+用户邮箱+用户地址+用户类型+邮递区号+用户电话 备注:这是所有的用户信息表表2.1数据文件“用户表”的字典条目管理员数据字典如下表2.2所示。文件名:管理员表编号:2组成:管理员ID+管理员名+管理员密码备注: 这是管理员信息表表2.2数据文件“管理员表”的字典条目购书车数据字典如下表2.3所示。文件名:购书车表编号:3组成: 购书车ID+图书ID+用户名+购物数量+购书时间+购书审查+定单号+管理员审查+图书名称+图书价格备注:这里

10、有所有购书的信息 表2.3数据文件“购书车表”的字典条目图书数据字典如下表2.4所示。文件名:图书表编号:4组成: 图书ID+图书名+图书价格+图书简介+图书数量+图书日期+图书照片+出版社+代理价格+批发价格+用户状态+作者+图书页数+开本+图书编号+推荐备注:这里有所有书籍的信息 表2.4数据文件“图书表”的字典条目友情链接数据字典如下表2.5所示。文件名:友情链接表编号:5组成: ID+链接地址+地址名称备注:这里有所有友情链接的信息 表2.5数据文件“友情链接表”的字典条目公告栏数据字典如下表2.6所示。文件名:公告栏表编号:6组成: ID+标题+内容+公告时间备注:这里有所有公告的信

11、息 表2.6数据文件“公告栏表”的字典条目图书类别数据字典如下表2.7所示。文件名:图书类别表编号:7组成: ID+名称备注:这里有所有图书分类的信息 表2.7数据文件“图书类别表”的字典条目定单信息数据字典如下表2.8所示。文件名:定单信息表编号:8组成: 定单ID+购书车ID+用户名+定单时间+定单号+定单审查+下定单用户名+下定者邮箱+下定者电话+下定者地址+下定者邮编+付款方式备注:这里有所有定单的信息 表2.8数据文件“定单信息表”的字典条目3系统设计3.1系统结构图根据需求分析和方案设计,可得到系统结构图如图3.1所示:图3.1系统结构图3.2系统功能具体分析当用户登陆到本系统时,

12、可以直接以点击的形式进入如下的版块:用户登陆、用户注册、图书查询、购书车、提交定单、图书信息维护、定单信息处理,以及辅助功能。 用户登陆 普通用户通过网络和浏览器,可以访问到网上书店, 如果用户想在网上购买图书,必须先登陆,如果用户没有登陆账号可以先免费注册。 用户注册没有账号的用户,网站提供免费注册的功能,用户只需要在注册页面填写相关的内容,如果信息通过验证,用户则注册成功,如果用户输入的信息有诸如密码不能为空等类似的错误,则会显示出错误信息,让用户重新输入登陆信息。 图书查询用户可以浏览图书信息,但是图书信息比较多,想找到合适自己的图书,有一定的难度,因此,用户可以通过查询功能,输入想找的

13、图书的关键字,系统会模糊查询,显示出相关的图书信息,提供给用户选择,如果用户选择的图书数据库中找不到合适的匹配,则会提示没有相关图书的信息。 购物车用户选择自己喜欢或者需要的图书后,可以把图书存放到购物车中,方便自己的二次查询,如果用户真的需要图书,可以付款购买图书。如果用户不需要图书,可以从购书车中删除图书信息。 提交定单用户查看购书车中的信息,确认要购买的图书,可以直接提交定单,在定单中填写自己的相关信息,填写信息必须正确,填写完只要付款后,经过管理员的确认便可以得到邮购的图书。 图书信息维护网站管理员登陆到管理员界面后,可以对图书数据进行添加,修改,删除操作,管理图书信息,方便管理员和用

14、户浏览图书信息,管理员可以添加需要上架的新书以不断的补充书店的图书,让书店的图书更加丰富,对于已经明显显示出下滑趋势的图书,管理员可以进行删除处理,之后用户便不能再看到该书的信息。 定单处理用户通过定单提交,确定自己的定单。管理员在后台维护界面可以查看所有的定单,定单和汇款单统一,如果用户汇款,管理员则处理定单,邮发图书到指定用户。 辅助功能本系统还有一些其他辅助功能,比如:用户数据管理,公告管理,图书分类等。在用户数据管理中,管理员可以对用户的详细信息进行管理,如修改和删除用户信息,还可以给用户升级为VIP,以便让用户能享受到VIP会员价格。在公告管理中,管理员可以及时的添加新的公告,以便让

15、用户更及时的知道该网络书店的最新动态,删除已经不再需要的信息。图书分类中,管理员可以进行图书分类的添加,比如管理员添加了一本新书在先有的图书分类中没有该类别,则管理员通过添加新的类别,可以把已经添加的图书并归到该类别中。3.3数据库的设计3.3.1逻辑结构设计系统实体及其属性描述如下:1. 用户用户ID,用户名,用户密码,用户邮箱,用户地址,用户类型,邮递区号,用户电话2. 管理员管理员ID,管理员名,管理员密码3. 购物车购书车ID,图书ID,用户名,购书数量,购物时间,购书审查,定单号,管理员审查,图书名称,图书价格4. 图书图书ID,图书名,图书价格,图书简介,图书数量,图书日期,图书照

16、片,出版社,代理价格,批发价格,用户状态,作者,图书页数,开本,图书编号,推荐5. 友情链接ID,链接地址,地址名称6. 公告栏ID,标题,内容,公告时间7. 图书类别ID,名称8. 定单信息定单ID,购书车ID,用户名,定单时间,定单号,定单审查,下定单用户名,下定者邮箱,下定者电话,下定者地址,下定者邮编,付款方式利用Microsoft Office Access 建立一个新的空的数据库名为bookshop.mdb,其中包括以下表。1. 用户表如下表3.3.1所示。列名类型主码可为空值描述user_id自动编号YN由数据库自动生成的顺序编号,作为用户的标示user_name文本NN用户的名

17、称user_pass文本NY用户的密码user_mail文本NY用户邮箱user_adds文本NY用户地址user_tel文本NY用户电话user_regtime日期/时间NY用户登录时间user_regip文本NY用户登录user_lasttime日期/时间NY用户最后登录时间user_lastip文本NYuser_buymoney文本NY用户买书的钱user_postcode文本NY用户邮递区号user_namec文本NYuser_type文本NY用户类型表3.3.1用户表2.管理员表如下表3.3.2所示。列名类型主码可为空值描述admin_id自动编号YN由数据库自动生成的顺序编号,作为

18、管理员的标示admin_name文本NN管理员名称admin_pass文本NY管理员密码 表3.3.2管理员表3.购书车表如下表3.3.3所示。列名类型主码可为空值描述basket_id自动编号YN由数据库自动生成的顺序编号,作为购书车的标示hw_id文本NN购书车的IDuser_name文本NY用户名称basket_count文本NY购书数量basket_date日期/时间NY购书日期basket_check是/否NY购书审查basket_admincheck是/否NY管理员审查hw_name文本NY图书名称hw_cash文本NY图书价格sub_number文本NY定单号Daili文本NY代

19、理价格 表3.3.3购书车表4.图书表如下表3.3.4所示。列名类型主码可为空值描述hw_id自动编号YN由数据库自动生成的顺序编号,作为图书的标示sort_id数字NNnsort_id数字NYhw_name文本NY图书名称hw_cash数字NY图书价格hw_content备注NY图书简介hw_date日期/时间NY图书日期hw_pic文本NY图书照片Chubsh文本NY出版社Daili数字NY代理价格Pifa数字NY批发价格Zhuang文本NY用户状态hw_sn文本NY图书作者Yeshu文本NY图书页数Kaiben文本NY开本Isbn文本NY图书编号Tuijian是/否NY推荐Jia是/否N

20、Y表3.3.4图书表5.友情链接表如下表3.3.5所示。列名类型主码可为空值描述id自动编号YN由数据库自动生成的顺序编号,作为链接的标示。url文本NN地址链接wordlink文本NY地址名称(中文显示)bs数字NY表3.3.5友情链接表6.公告栏表如下表3.3.6所示。列名类型主码可为空值描述ID自动编号YN由数据库自动生成的顺序编号,作为公告的标示am_uid文本NNTitle文本NY公告标题Msg文本NY公告信息Date日期/时间NY公告日期Time日期/时间NY公告时间表3.3.6公告栏表7.图书类别表如下表3.3.7所示。列名类型主码可为空值描述sort_id自动编号YN由数据库自

21、动生成的顺序编号,作为图书类别的标示sort_name文本NN分类名称表3.3.7图书类别表8.定单信息表如下表3.3.8所示。列名类型主码可为空值描述sub_id自动编号YN由数据库自动生成的顺序编号,作为定单的标示basket_id文本NN购物IDuser_name文本NY用户名sub_date日期/时间NY定单日期sub_number文本NY定单数量sub_check是/否NY定单审查sub_to文本NY下定单用户名sub_mail文本NY下定者邮箱sub_tel文本NY下定者电话sub_adds文本NY下定者地址sub_post文本NY下定者邮编qian文本NY付款方式other文本N

22、Y其他表3.3.8定单信息表4.系统功能模块实现4.1用户登录模块这里介绍用户登录的程序设计思路,数据库中存放有用户的基本信息,用户在网站中输入相关信息,通过匹配检测,便可以知道数据的有效性,下面是登录程序流程图如下图4.1所示:图 4.1 登陆程序流程图登陆模块中的主要程序:user_name=request.getParameter(user_name);/获得用户名 user_pass=request.getParameter(user_pass);/获得用户密码String sql=select * from member where user_name=+user_name+; Re

23、sultSet rs;/建立相关的记录集 rs=mdb.executeQuery(sql);下面只需要查看记录集是不是为空,如果为空,则说明登录失败;否则,登录成功。登陆界面截图如下: 登陆后信息如下: 4.2用户注册模块注册模块,会出现在很多程序中,这里借鉴了其他注册程序的流程。注册模块的核心思想是向数据库中输入数据,并且数据要不能重复,下面是注册模块的程序流程图如下图4.2所示:图 4.2 注册程序流程图注册模块中的主要程序介绍:String sql1; sql1=Insert intomember(user_name,user_pass,user_adds,user_mail,user_

24、tel,user_regip,user_postcode,user_namec,user_type) values(+user_name+,+user_pass+,+user_adds+,+user_mail+,+user_tel+,+request.getRemoteHost()+,+user_postcode+,+getStr(request.getParameter(user_namec)+,会员);mdb.executeInsert(sql1);数据通过验证后,向数据库输入数据,数据库会保存相关的注册信息。注册页面如下:4.3管理员功能模块网站管理员登陆到管理员界面后,可以对图书数据进

25、行添加,修改,删除操作,管理图书信息,方便管理员和用户浏览图书信息,管理员可以添加需要上架的新书以不断的补充书店的图书,让书店的图书更加丰富,对于已经明显显示出下滑趋势的图书,管理员可以进行删除处理,之后用户便不能再看到该书的信息。管理员可以添加公告信息等。进入管理员登陆模块:管理员的具体职能如图:管理员的查看与修改功能部分代码如下:String action=request.getParameter(action);if(action!=null) action=action.trim(); if(action.equals(del) int n=0; sql=delete * from h

26、w where hw_id=+Cint(request.getParameter(hw_id); mdb.executeDelete(sql); out.print(图书删除成功); out.print(); out.print (返回);4.4定单处理模块网上书店建立的目的之一就是为了经济利益,定单处理是和经济利益有直接关系的模块,有效定单都是预付书款的定单,会增加书店的营业收入,可以说本模块是系统的核心模块,是系统的心脏,数据转存的中心。下面会详细介绍本模块。定单处理模块的设计思路:用户提交定单后,管理员通过后台数据处理,可以查看全部的定单信息,由于定单编号是按照时间来命名的,管理员很容易

27、查看到最新的定单信息。同时,本模块还和其他两个系统有间接的关系,一个是付款系统,另外一个是物流系统。定单的有效性和付款系统有直接关系,管理员处理的定单,通过审核的条件必须是付过书款的。另外,如果是有效定单,必须通过物流给用户寄发图书。定单处理程序流程图如下图4.4所示:图4.4定单处理程序流程图主要代码实现:tryClass.forName(sDBDriver);/处理异常catch(java.lang.ClassNotFoundException e)System.err.println(数据库连接:+e.getMessage();/数据库的连接conn=DriverManager.getC

28、onnection(sConnStr); stmt=conn.createStatement(); for(int i=0;iid.length;i+) int myUpdate=stmt.executeUpdate(update sub set sub_check=true where sub_number=+idi+); int mUpdate=stmt.executeUpdate(update basket set basket_admincheck=true where sub_number=+idi+);/对定单数据进行具体到更新操作,更新两张表中的信息。 本模块是系统的核心,主要负

29、责定单的审查,是定单的流程最后一个环节,也是最重要的一个环节。书店的任何数据都和定单数据有直接或者间接的关系,有效的定单和书店的经济利益有直接的关系,收入和支出都是由定单引起的。程序当中也严格限制数据的有效性,无效数据不会录入到数据库中。4.5图书查询模块大量的数据中找到用户需要的数据,这样的数据挖掘很有必要。同样,系统中也提供这样的查询,在数据库的SQL中,查询实现很简单,本系统的查询也是根据SQL的查询语句实现的,通过模糊匹配,实现对图书信息的查询。其具体实现是输入关键字,如果数据库中有记录,便会显示出查询的结果,没有记录则显示找不到与之对应的书。这其中主要是在系统的数据库中进行查找。查询

30、界面如下图4.5所示:图4.5查询页面图主要的查询代码:String hw_name,sort_id; if(session.getAttribute(sort_id)=null) hw_name=getStr(request.getParameter(hw_name); sql=select * from hw where hw_name like %+hw_name+% order by hw_id DESC; rs=mdb.executeQuery(sql); else sort_id=request.getParameter(sort_id); hw_name=getStr(reque

31、st.getParameter(hw_name); sql=select * from hw where sort_id=+sort_id+ and hw_name like %+hw_name+% order by hw_id DESC;rs=mdb.executeQuery(sql);主要的程序设计思路是通过控件传递关键字给SQL语句,然后在数据库中进行查询操作。4.6辅助功能模块为了让系统功能更加丰富,系统还提供了公告发布和友情连接管理的功能,在公告发布模块中,系统管理员可以添加公告,用户登陆网站的时候可以查看公告。友情链接也是网站常见的一种形式,主要是实现页面的跳转,增加网站的点击率。

32、本系统也提供本功能。(注:公告功能并未实现)5部分页面运行结果以及系统配置说明:(首页)(用户123的购书车)系统的配置主要包括JDK,Tomcat和数据源的配置:JDK和Tomcat安装步骤很简单,按照提示就可以安装,主要是JDK的环境变量的设置: JDK的默认安装目录为C:jdk;本系统安装在E:jdk;更新环境变量在系统桌面中;右击我的电脑图标;选择属性命令;弹出系统特性对话框。在高级选项卡中;单击环境变量按钮;弹出环境变量对话框;该对话框分为Administrator 的用户变量和系统变量两个选项组。在系统变量选项组中;找到path变量后单击编辑按钮;弹出编辑系统变量对话框。在变量值文

33、本框最前面输入“E:jdkbin;”,然后单击确定按钮。在系统变量选项组中单击新建按钮,在变量名文本框中输入“classpath”,在变量值文本框中输入“E:jdklibtools.jar; E:jdklibdt.jar;” 然后单击确定按钮。用同样的方法把E:jdk添加到JAVA_HOME环境变量中;单击应用按钮再单击确定按钮。至此JDK的安装及配置完成。数据源的配置则比较难:首先,从控制面板的管理工具中打开“ODBC数据源管理器”,单击系统DSN选项卡,单击添加按钮;然后,从“名称”列表栏中选择Microsoft Access Driver(*.mdb),在弹出的“ODBC Microsoft Access安装”对话框中,填入数据源名为“shnxn”然后对数据库进行选择。最后点击“确定”完成对数据源的配置。系统操作说明:在地址栏中键入:http:/localhost:8181Bookshopindex.jsp,便可以进入骊苑网上书店的首页面了。管理员用户名:admin,密码:admin会员用户名:123,密码:123.

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号