资源描述
西安航空职业技术学院 课 程 设 计 说 明 书课程名称: jsp技术实 专 业: 软件技术 班级学号: 15303139 姓 名: 刘浩儒 指导教师: 陈洁 2016 年 12 月_12_日教务处印制西安航空职业技术学院课 程 设 计 任 务 书课题名称: 在线购物车系统 设计内容: 利用myEclipse8.5创建相关的java和servlet文件. 以及登陆界面的设置和界面的美化,利用tomcat7.0完成项目在 浏览器上的发布,利用mysql进行建立数据库,然后建立用户登录的的表,本次设计的主要设计内容是在线图书购物车系统,目的是为方便用户在输入正确的用户名和密码的的时候可以在线购书。 技术条件或要求: HTML+CSS、javascript、Tomcat7.0 Java Web程序设计、Mysql 、MyEclipse、PhotoShop等相关软件进行设计 指导教师(签名): 教研室主任(签名): 开题日期: 2016 年 12 月 12 日 完成日期: 2016 年 12 月 20 日摘要随着信息技术的高速发展和Internet的不断普及。人们对于互联网技术的要求不仅是浏览一下网页,收发电子邮件。日益忙碌的人们开始追求足不出户的利用互联网这一强大的平台来实现的网上购物,如网上订餐,网上订票,网上药店等。对于企业来讲,无论是企业之间(B to B),还是企业和客户之间(B to C)的交易,如果能够实现网上交易将大大提高交易速度节约交易成本。本文设计了基于JSP的在线购物车系统,整个开发环境是基于windows系统下的,运用的技术包括:B/S模式,MVC三层架构的思想,Servlet/JSP、JDBC、MySQL等。使用的工具有MySQL5.0作为数据库平台,Tomcat6.0作为服务器,JSP作为前台页面显示,实现了应用逻辑和页面分离使得界面设计更简单。在线购物车系统模拟了网上购物的基本功能,实现了产品的浏览,购物车管理,订单管理等功能。在在线购物车系统中,顾客可以很方便的对商品进行浏览检索,查看商品的详细资料。然后根据各人的喜好购买心仪的商品,系统会自动为顾客生成订单,按照顾客索填写的信息提交订单并发货。关键词:B/S模式; JSP; Servlet; MySQL AbstractWith the rapid development of information techniques and the continuous spread of Internet.People not only to the requirement of the Internet technology is browsing the web, send and receive email.Increasingly busy people begin to pursue the housebound use the Internet this a powerful platform for online shopping,such as online order,online booking,online pharmacies,etc.For the enterprise,Whether between enterprises (B to B), or between companies and customers (B to C),If can realize online trading will greatly improve the speed to save transaction cost.This paper design based on JSP online shopping cart system,Under the development environment is based on Windows system,Using the techniques include:B/S mode,The thought of the MVC three-tier architecture,The Servlet/JSP, JDBC, MySQL, etc.The tools used have MySQL5.0 as the database platform,Tomcat6.0 as a server,The JSP as the front desk page displays,Realize the separation of application logic and page makes the interface design is more simple.The basic function of an online shopping cart system to simulate the online shopping,Realized product browsing, shopping cart management, order management, and other functions.In the online shopping cart system,Customers can easily browse the retrieval,View the details of the goods.The right and then the be fond of according to each purchase the goods,The system will automatically generate orders for customers,According to the customer fill in the information submitted to the order and delivery.Keywords: B/S; JSP; Servlet; MySQL目录第一章 绪论61.1课题背景61.2网上购物的发展状况61.3项目提出的意义71.4本课题主要研究内容71.5 论文结构7第二章 系统所采用的技术82.1 MVC设计模式和B/S系统架构82.1.1 MVC设计模式82.1.2 B/S系统架构92.2 JavaScript技术92.3 JSP技术102.4 MySQL数据库技术102.5 通过JDBC对数据库进行访问11第三章 系统需求分析123.1系统的可行性研究123.1.1社会可行性123.1.2 技术可行性123.2需求分析133.2.1 业务需求分析133.2.2 用户需求分析133.2.4 运行环境和开发工具13第四章 登录界面的实现14第五章系统测试20第六章 总结与展望20参考文献21第一章 绪论随着互联网的快速发展,电子商务成为了主要的商业交易模式,网上购物是电子商务的一种基本形式,这个流行于二十一的购物方式已经被越来越多的人所接受1.1课题背景近年来,随着Internet的快速发展和普及化,使Internet成为报刊、电视、广播等传统媒体之后而兴起的一种新传媒介质,人们对于互联网技术的需求已不仅仅是浏览网站,收发电子邮件 。日益忙碌的人们开始追求足不出户就可以购买所需的商品。网上商城购物成了一种新型而热门的购物方式应运而生。在互联网日益流行的今天,网络是主角,是时代的宠儿。在网络大家族中,电子商务则是一个热点。电子商务一个最基本体现就是网上购物,从一定程度上讲它就是网上超市,也就是一种网上销售。“网”字意味着它具有信息时代的快捷方便等特征。事实上电子商务的出现,给消费者的地位,消费观念带来了重要的变化。网上购物系统作为B2B(Business to Customer),B2C(Customer to Customer)前端商务平台,在其商务活动中起到举足轻重的作用,本文主要考虑的是如何实现基于JSP的在线购物车系统。购物网站及购物车实现这一课题,是应用前景非常广阔的,它的解决方法不仅可以针对购物网站,同样可以应用于多种多样的网站建设。1.2网上购物的发展状况在我国,网上购物从无到有也不过短短几年时间。我国第一家网上购物发生在1996年,燕莎友谊商场首次通过网上商城售出一个景泰蓝,虽然货款的支付不是在网上进行的,但这毕竟为我国零售业奏出了网上购物的先声。根据CNNIC的统计结果,截止2004年1月中国有互联网用户7950万人,而又有40.7%以上的网民在过去的一年里有过网上购物经历,这就说明中国有网上购物的用户达是3235.7万人,并且这一数字还在以17%左右的速度增长,到2006年中国网上购物用户将达到6962万人,这说明在中国发展网上购物具有良好的群众基础,网上购物方式正逐渐被大家所接受。1.3项目提出的意义自我国加入WTO后,越来越多的传统企业进一步认识到企业经济发展的必然趋势是以网络化、全球化为主要特征。而企业实行电子商务则成为企业发展与国际接轨的必要条件。多年来国家十分重视企业的信息化建设,并做了大量工作,但目前企业开始实施信息化的比例还不到20%。所以电子购物网站的实现是一个非常迫切的需求。现代的网络,已经经历过迅速发展的时期,它的技术也已经相当成熟。因此,依靠网络技术来架设一个网站会在很多方面得到相关的支持。现在的网络对于人们来说,已不再是单单获得信息的意义,更反应了现代人生活的理念,更为重要的是成为企业与商家宣传产品,介绍自身的平台。因为现代社会愈发的依赖于网络,特别是“万维网”,为企业或商家量身设计一个网站被默认为必不可少的事情。利用电子商务的模式,在介绍推广自己的同时,以新的一种渠道销售自己的产品,也愈发被关注。因此,设计一个具有电子商务功能的企业网站具有非常好的开发与应用前景。1.4本课题主要研究内容随着网络技术的发展,特别是电子商务的普及和应用,开发一套简单实用的网上商城可谓当务之急。本文主要研究如何实现以下内容 :1 现用户的登录以及用户的注册。(2)实现购物车的功能。(3)实现订单模块的管理。1.5 论文结构本文分为七章,通过对购物网站的分析,设计与实现的过程的全面介绍来展示系统的全部特性。第一章 绪论,描述了课题背景、网上购物的发展状况、项目提出的意义,进而总结出此次课题的主要研究内容。第二章 相关技术,系统设计中一些相关技术的简介。第三章 系统分析,首先从几个角度阐述了系统开发的可行性,然后进行了系统的功能需求分析。第四章 系统实现,这一阶段是编码阶段,对各个模块进行具体实现第五章 系统测试,对系统进行了三方面的测试,以此确保系统的正确性。第六章 总结与展望。第二章 系统所采用的技术本章对设计与实现在线购物车系统所采用的技术进行概要简述,主要包括MVC设计模式,B/S系统架构、JavaScript技术,JSP技术,MySQL数据库以及通过JDBC接口访问数据库。2.1 MVC设计模式和B/S系统架构2.1.1 MVC设计模式MVC设计模式是一种流行的软件工程架构模式,它把系统分为三个基本部分:视图层(View)、模型层(Model)和控制层(Control)。这三个部分以最少的耦合协同工作,从而提高应用的可扩展性和可维护性。MVC的结构如图2-1。图2-1 MVC的结构图首先控制器接受用户的请求,并决定应该调用哪个模型来处理;然后模型根据用户请求进行相应的业务逻辑处理,并返回数据;最后控制器调用相应的视图格式化模型返回的数据,并通过视图呈现给客户。总的来说,MVC设计模式具有以下有点:首先,最重要的是是多个视图能共享一个模型,提高了代码的可重用性。由于MVC的三个模块相互独一,改变其中一个不会影响其它两个,所以依据这种设计思想能构造良好的松耦合的构件。此外,控制器提高了应用程序的可配置性和灵活性。可用来连接不同的视图和模型去完成用户需求,这样控制器可以为构造应用程序提供有力的手段。2.1.2 B/S系统架构网上的购物基于Web系统,传统的C/S架构已经不能满足大量的用户访问及操作。B/S是是浏览器/服务器英文的简写,具体的结构是浏览器&Web服务器&数据库服务器。相对于C/S架构的“胖”客户端,B/S架构不需要安装很多相应的操作软件,只需要安装一个浏览器。他将大量的数据处理工作交给服务器处理,客户端只需要通过浏览器就可以向服务器发送访问请求和接受处理结果。由于B/S架构的大多数功能都是在服务器上实现,所以降低了系统维护的工作。B/S架构将会成为越来越多软件开发的选择。2.2 JavaScript技术JavaScript的代码是一种文本字符格式,可以直接嵌入HTML文档中,并且可动态装载。编写HTML文档就像编辑文本文件一样方便。JavaScript 是一种描述性语言,它可以被嵌入 HTML 的文件之中。通过 JavaScript 可以做到响应用户的需求事件(如表单的输入),这样当一位使用者输入一项信息时,它不需要通过网络传送到服务器端进行处理再传回来的过程,而可以直接在客户端进行事件的处理。你也可以想像成有一个可执行程序在你的客户端上执行一样(但这种执行程序是有限的,它对客户端电脑的控制力很差)!JavaScript是一种基于对象和事件驱动并具有安全性能的脚本语言,有了JavaScript,可使网页变得生动。使用它的目的是与HTML超文本标识语言、Java 脚本语言一起实现在一个网页中链接多个对象,与网络客户交互作用,从而可以开发客户端的应用程序。它是通过嵌入或调入在标准的HTML语言中实现的。2.3 JSP技术本系统采用JSP技术开发。因为JSP与同类的ASP、PHP相比有着独特的优势。JSP是由Sun Microsystems公司推出的技术,它以Servlet技术为基础,又在许多方面作了改进,并且充分借鉴了ASP和PHP一些合理的地方。它的平台无关性胜过ASP技术,而强大的JDBC数据库接口规范又优于PHP技术,它在动态网页的建设中有强大而特别的功能。Web服务器在遇到访问JSP网页的请求时,首先执行其中的程序段,然后将执行结果连同JSP文件中的HTML代码一起返回给用户。如果第一次访问JSP文件,将被服务器翻译成对应的特殊Java文件,也就是Servlet。然后被编译成.class文件并加载到内存中。如果以后访问该JSP,那就直接访问内存中的JSP实例。所以第一次访问JSP慢,第二次以后访问该JSP文件的数度就会变快了。JSP的工作原理图如下图2-2所示:图2-2 JSP工作原理图2.4 MySQL数据库技术MySQL是一个小型关系型数据库管理系统,开发者为瑞典MySQL AB公司。目前MySQL被广泛地应用在Internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。MySQL具有以下特点。.用C和C+编写,并使用多种编译器进行测试,保证源代码的可移植性。.MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了数度并提高了灵活性。.MySQL是一种开放源代码软件,“开源代码”意味着任何人都能免费使用软件,甚至个性化的修改软件。.MySQL数据库服务器具有稳定,快速和易于使用的特点.可以处理拥有上千万条记录的大型数据2.5 通过JDBC对数据库进行访问JDBC(Java Data Base Connectivity)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一的访问,它由一组用Java语言编写的类和接口组成。JDBC为开发人员提供了统一的接口。有了JDBC,向各种关系数据发送SQL语句就是一件很容易的事情。换言之,有了JDBC API,就不必为访问MySQL数据库专门写一个程序,为访问Oracle数据库又专门写一个程序,或者为访问Sql Server又编写另一个程序等等。程序员只需要用JDBC API写一个程序就够了,它可以向相应数据库发送SQL调用。同时,将Java语句和JDBC结合起来就可以让它在任何平台上运行,这也有Java语言“编写一次,处处运行”的优势。JDBC访问数据库的应用步骤如图2-3所示:图2-3 JDBC访问数据库应用步骤第三章 系统需求分析在本系统开发之初,对系统需求进行了分析,明确了系统对功能与性能的要求,并进行了可行性分析。这里首先针对系统开发的可行性从社会和技术两方面进行了分析和研究。其次通过需求分析明确了系统的功能与性能目标,确定了系统的功能行需求。3.1系统的可行性研究可行性分析就是在项目开发之前,在系统调查的基础上,针对新系统开发的必要性和可能性进行多方面的分析和论证,以减少项目开发的盲目性。3.1.1社会可行性随着信息化社会的到来,电子商务成为新的经济增长方式,中国电子商务保持着快速发展的势头,已进入爆炸式增长阶段。90%选择网上购物的用户都认为,网上购物更加节约时间,操作更方便快捷。随着生活节奏的加快,越来越多的人开始选择网上购物。可以预计,随着网络的高速发展以及人们对电子商务的认识不断清晰。网购这一电子商务将成为市场的领跑者。3.1.2 技术可行性因为计算机硬件的发展已经越来越快,现在PC机的性能已经可以胜任普通网站的Web服务器。购买一台高性能PC机作为企业的网站服务器对于企业来说并不是问题。从软件角度来看,JSP+Servlet技术已经非常成熟,成为一种非常流行的网站开发技术。可以建立先进、安全和跨平台的动态网站。后台数据库也相当稳定。加以指导老师的帮助可以得到很多的技术支持。由于在学习数据库时一直以MySQL作为例子,所以采用MySQL作为数据库的后台。3.2需求分析需求分析分为业务需求分析、用户需求分析、功能需求分析以及性能需求分析。这一阶段的基本任务不是确定系统怎样完成它的工作,而是确定系统必须完成那些工作。3.2.1 业务需求分析业务需求反映了组织机构或客户对系统、产品高层次的目标要求。业务需求和分析对软件产品来说起到关键性作用,网站的制作已经不单单是把企业想要表达的内容摆放在网站上那么简单,如今的网站应包含更多的设计元素,以此给用户良好的使用体验。分析人员通过业务需求分析,确定一个电子商务网站必须具有的基本信息及功能。对业务需求进行分析,就是解决要输入什么数据,得到什么结果,最后应该输出什么的问题。3.2.2 用户需求分析用户需求分析在业务需求的基础上,进一步提出网站需要完成的任务。这一阶段一切信息与需求需要站在用户的角度上,尽量避免分析人员的主观想象。用户需求分析具体提出了商家和卖家所需要的具体系统功能,另一个重要的内容就是能够显示出该商城现有的各类型商品及其详细信息;由于消费者的需求在增长和变化,购物商城也要能应对发展的变化。3.2.4 运行环境和开发工具本系统开发的基本环境如表3-1表3-1 系统硬件配置及开发工具项目配置CPUP6200内存2G硬盘320G 操作系统Windows 7IDEMyEclipse8.5应用服务器Tomcat 7.0 第四章 登录界面的实现用户登录模块相对来说比较简单,当用户输入用户名及密码后点击登录,系统将会把登录信息发送给服务器,服务器根据浏览器的请求,执行相应的组件,完成用户身份的验证,如果验证通过,则显示系统的主界面,用户将可以浏览商品。如果用户验证身份不成功,则提示用户输入的信息不正确,并且停留在登录界面。另外,在线购物网站需要很高的稳定性和安全性,因此对用户名的约束是不允许使用恶意的代码作为用户名。启动服务器,在浏览器里输入相应的地址( 在本机上输入:http:/localhost:8080/BookShop),进入系统主界面,也就是登录界面,如图4-1所示: 图4-1具体实现代码如下:(1)Bookinfo.javaimport java.sql.Connection;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.ArrayList;import java.util.List;public class bookinfo /根据用户名和密码查询用户是否存在,如果存在则登录成功public static int select(String username,String password)Connection con=DBUtil.connection();/获得数据库连接 String url=select * from book where username=+username+and password=+password+; int flag = 0; try /创建数据库语句Statement st=con.createStatement();/用结果集来显示查询的结果ResultSet rs = st.executeQuery(url);/执行查询得到数据集if(rs.next() /rs.next()方法将指向记录的光标向下移动,每调用一次,光标便会向下移动一次flag=1;else/flag=0; catch (SQLException e) e.printStackTrace();return flag;public static void main(String args) System.out.println(bookinfo.select(sa, sa); (2) loginServlet.java import java.io.IOException;import java.io.PrintWriter;import java.sql.Connection;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.ArrayList;import java.util.List;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;public class LoginServlet extends HttpServlet public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException doPost(request, response);public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException response.setContentType(text/html;charset=utf-8);/获取表单数据String username=request.getParameter(username);String password=request.getParameter(password);if(username.equals()|password.equals()request.setAttribute(msg, 账号或密码不能为空);request.getRequestDispatcher(SIGN_IN.jsp).forward(request, response);else/接收bookinfo所返回来的结果,赋值给flag int flag= bookinfo.select(username, password); if(flag=1) request.setAttribute(msg, username); request.getRequestDispatcher(index.jsp).forward(request, response); if(flag=0) /返回的消息 request.setAttribute(msg, 账号或密码错误); request.getRequestDispatcher(SIGN_IN.jsp).forward(request, response); /请求转发,前后页面共享一个request int flag1= bookinfo.select(username, password); if(flag1=1) request.setAttribute(msg, username); request.getRequestDispatcher(index.jsp).forward(request, response); if(flag1=0) /返回的消息 request.setAttribute(msg, 账号或密码错误); request.getRequestDispatcher(SIGN_IN.jsp).forward(request, response); (3) SIGN_IN.jspSIGN IN#con height:520px;width: 1300px;background-color:#232F3E;margin-left: 5px;padding-left: 5px;#footer background-color:#131A22;height: 50px;width: 1300px;margin-left: 5px;padding-left: 5px;#boxwidth:1300px;height:60px;#box1width:500px;height:auto;#box2width:700px;height:auto;padding-left:500px;border-color:#FFF;border:thin;border:5px;.fontcolor:#FFF;font-size:20px;$msg Sign inEmail(Phone For Moblie Account)Password Forgot Your Password?Keep Me Signed In.Details New To iBook? Conditions Of Use Privacy Notice Help2016,12,14 #Johnnyyoung96116gmail.com 第五章系统测试IE浏览器支持360浏览器支持火狐浏览器支持第六章 总结与展望通过在线购物系统的开发工作,使我加深了信息系统开发的理解,在老师的帮助下,基本掌握了JSP开发面向对象应用程序的方法和过程。在开发本课题时,系统功能较多,我从需求分析入手,通过用例模型明确需求,当然在此之前的可行性分析等准备工作是必不可少的,实训报告首先介绍了这部分工作,然后给出了系统的架构设计和功能模块设计等,用图表加文字的方式对设计工作中的重点部分做了相应的阐述。论文把实现过程中的关键技术问题进行了充分的说明,并配有相关代码。论文的最后,我组织了系统的测试,并列举了典型的测试用例。在该系统的研究和开发过程中,由于时间和条件有限,在实现技术上还存在一些局限性,另外在开发过程中,也发现了一些需扩展的需求功能,但没能在有限的的时间内全部完成,例如用户支付,用户留言等,并且随着网络信息技术的飞速发展和快速普及,也要求拥有更为快捷、更为合理、功能更全面的在线购物系统。此外,安全性已经成为阻碍电子商务发展和普及的重要因素,信息的安全性是当前发展电子商务最迫切解决的问题,研究和分析电子商务的安全性问题,特别是针对我国自己的国情。充分借鉴国外的先进技术和经验,开发和研究出具有独立知识产权的电子商务产品,已经成为目前我国发展电子商务的关键,因此这也成为软件行业下阶段所需要研究的课题。参考文献1 朱利华、郭永洪.软件开发与项目管理.高等教育出版社,20132 张海藩.软件工程导论.清华大学出版社,20083 王珊、萨师煊.数据库系统概论.高等教育出版社,20064 屈鹏飞.JAVASCRIPT网页编程案例.清华大学出版社,20025 刘京华.Java Web整合开发.清华大学出版社,20106 张永常.Java程序设计实用教程.电子工业出版社,20087 卢翰、王国辉.JSP项目开发案例全程实录.清华大学出版社,20118 刘京华.Java Web整合开发王者归来.清华大学出版社,2010西安航空职业技术学院课程设计(论文)成绩评定表论文评语:答辩情况:成绩:签名: 年 月 日
展开阅读全文