JSP网上书店实例详解_第1页
JSP网上书店实例详解_第2页
JSP网上书店实例详解_第3页
JSP网上书店实例详解_第4页
JSP网上书店实例详解_第5页
已阅读5页,还剩32页未读 继续免费阅读

下载本文档

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

文档简介

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

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

3、DSN),则出现如图15-2所示数据源驱动程序选择界面:图15-2 数据源驱动程序选择界面(4)在图15-2中选择“Microsoft Access Driver (*.mdb)”单击“完成”加载Access数据库的驱动,则出现如图15-3所示数据库ODBC安装界面:图15-3 数据库ODBC安装界面(5)在图15-3中单击“选择(S)”按钮,启动一个类似资源管理器的界面来选择数据库,如图15-4所示,在图15-4所示的界面中选择bookstore.mdb。图15-4 数据库选择界面15.1 会员登录做一个网上书店,在顾客开始购书之前,必须要记录用户的一些信息以便用户在不同的分类、不同的页面购

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

5、时只能使用没有被使用的用户代码。在验证时我们只要使用验证用户的memberID和其pwd是否一致即可判断该用户是否合法,如果合法则其登录次数加1。下面是用户验证部分的Java Bean的代码清单15-1 BuyerBean.Java/* *BuyerBean.Java 1.10.2001 *Copyright 2000, 2001 by cuug llp.*本Bean中有两个set方法和两个get 方法:*setMemberID( ) 对BuyerBean中的memberID属性进行赋值;*setPwd( )对BuyerBean中的 pwd 属性进行赋值; *getLogontimes( )

6、取该会员登录的次数*getMenberName()获得该会员的真实姓名,用于显示欢迎信息。*main( )方法用于将BEAN作为一个 Application进行测试时使用,正式发布时可以删除。 */package cuug;import Java.sql.*;public class BuyerBean private String memberID = null ; /会员IDprivate String memberName = null; /会员姓名private String pwd = null;/密码private int logontimes = -1;/登录的次数private

7、 static String strDBDriver = “sun.jdbc.odbc.JdbcOdbcDriver”; /JDBC驱动private static String strDBUrl = “jdbc:odbc:bookstore”; /数据源 ,private Connection conn =null; /连接private ResultSet rs = null;/结果集public BuyerBean ( )/加载JDBC-ODBC驱动try Class.forName(strDBDriver );/捕获异常catch(Java.lang.ClassNotFoundExce

8、ption e)System.err.println(“BuyerBean():” + e.getMessage();/获得登录次数,登录的会员的名字也在该方法调用时获得public int getLogontimes()String strSql = null;tryconn = DriverManager.getConnection(strDBUrl);Statement stmt = conn.createStatement();strSql = “Select logonTimes,membername from buyerInfo where memberID = ” + membe

9、rID + “ and pwd =” + pwd + “”;rs = stmt.executeQuery(strSql);while (rs.next()/ 登录的次数logontimes = rs.getInt(“logonTimes”);/会员姓名 memberName = rs.getString(“membername”); rs.close();/如果是合法会员则将其登录次数加1if (logontimes != -1 ) strSql = “Update buyerInfo set logonTimes = logonTimes +1 where memberID = ” + me

10、mberID + “”;stmt.executeUpdate(strSql);stmt.close();conn.close();/捕获异常catch(SQLException e)System.err.println(“BuyerBean.getLogontimes( ):” + e.getMessage();return logontimes ;/设置memberID属性;public void setMemberID(String ID)this.memberID = ID;/设置pwd 属性public void setPwd(String password)this.pwd = pa

11、ssword;/获得该会员的真实姓名,必须在取该会员登录的次数之后才能被赋予正确的值public String getMemberName()return memberName;/测试Bean中的各个方法是否能够正常工作public static void main(String args)BuyerBean buyer = new BuyerBean();buyer.setMemberID(“abcd”);buyer.setPwd(“1234”);System.out.println(buyer.getLogontimes();System.out.println(buyer.getMemb

12、erName();在BuyerBean中用了package cuug; 在发布到WEB SERVER时,可以用JAR(JDK中带的打包工具)把编译后的BuyerBean.class 打包成JAR文件在服务器的环境变量classpath中给予指定,或者在服务器classpath环境变量指定的目录下建一个cuug文件夹,把BuyerBean.class放到cuug目录下。15.1.2 会员登录htm与JSP会员登录要由两个部分来完成,第一个页面用于会员输入其ID和密码,当然首页还可以加一些广告等的其它信息,在本例中略过。清单15-2 default.htm! Copyright 1999 cuug

13、,liu.CUUG ON LINE BOOK STORE MEMBER LOGINCUUG 网上书店会员登录页请输入会员代号和密码: 会员代码: 密码: 在本例中提供了一个文本框供用户输入会员代号和登录密码,其运行结果如图15-6所示,当会员输入其代码和密码后调用checklogon.jsp 来验证该网络用户是否是合法会员。图15-6 会员登录页在checklogon.jsp 中接收从default.htm中由用户所填的会员代码和密码,把它传给BuyerBean,由BuyerBean判断该用户的会员代码和密码的正确性,若正确显示欢迎信息;若不正确,则提供一个重新登录的链接。Checklogon

14、.jsp的源代码如下:清单15-3 checklogon.jspCUUG ON LINE BOOK STORE MEMBER LOGINCUUG 网上书店 0)session.putValue(memberID,memberID);%欢迎你第次来到CUUG网上书店进入书店对不起,你的用户名和密码不一致重新登录 登录正确时的结果如图15-7所示,错误时的结果如图15-8所示。图15-7 用户登录正确(会员abcd的真实姓名是cuug001)图15-8 用户登录错误15.2 选书会员登录之后,合法的用户将可以看到本书店中可供选择的图书,并且将他感兴趣的书放入“购物车”,在去“收银台”结帐之前,该用

15、户可以放弃购买其购物车中的任何一本书。在此处我们用BookBean来获取图书的信息,在Booklist.jsp中显示这些书。在会员选书部分,我们仍用Java Bean来操作数据库,用jsp来做页面表现。15.2.1 选书Java Bean图书信息的表结构如图15-9所示,为了便于说明,在本例中price也设置成了String型,在实际应用中应该设置成货币或浮点型:图15-9 图书信息的表结构其中,bookISBN是主键,区分不同的图书。Java Bean要根据不同的图书的bookISBN来获得其相应的书名、作者、出版社、价格、简介等信息。同时Java Bean还要有列出书店中所有图书的信息的功

16、能。清单15-4 BookBean.Java/* *BuyerBean.Java 1.10.2001 *Copyright 2000, 2001 by cuug ,llp.*本Bean中的各个方法的功能介绍如下:*setBookISBN():设置图书的编号,同时根据编号更新相应的书名、作者、出版社、价格*和简介*getBookList() 取得书库中全部书的书名、出版社、价格、作者等信息;*getBookISBN() 取得当前图书的编号 ; *getBookName()取得当前图书的书名;*getBookAuthor()取得当前图书的作者;*getPublisher()取得当前图书的出版社信息

17、;*getPrice()取得当前图书的价格;* getIntroduce()取得当前图书的简介信息。*main()方法用于将BEAN作为一个 Application进行测试时使用,正式发布时可以删除。 */package cuug;import Java.sql.*;public class BookBean private String bookISBN = null;/图书编号private String bookName = null;/书名private String bookAuthor = null;/作者private String publisher = null;/出版社pr

18、ivate String introduce = null;/简介private String price = null;/价格private static String strDBDriver = sun.jdbc.odbc.JdbcOdbcDriver;private static String strDBUrl = jdbc:odbc:bookstore;private Connection conn =null;private ResultSet rs = null;public BookBean()/加载驱动try Class.forName(strDBDriver );catch(

19、Java.lang.ClassNotFoundException e)System.err.println(BookBean (): + e.getMessage();/取当前书库中全部图书信息public ResultSet getBookList()String strSql = null;try/建立与数据库的连接conn = DriverManager.getConnection(strDBUrl);Statement stmt = conn.createStatement();strSql = Select bookISBN,bookName,bookAuthor,publisher

20、,price from bookInfo ;rs = stmt.executeQuery(strSql);/捕获异常catch(SQLException e)System.err.println(BookBean.getBookList(): + e.getMessage();return rs ;/根据图书的编号给图书的其他信息赋值private void getBookInfo(String ISBN)String strSql = null;bookName = null;bookAuthor = null;publisher = null;introduce = null;price

21、= null;try/建立和数据库的连接conn = DriverManager.getConnection(strDBUrl);Statement stmt = conn.createStatement();strSql = Select * from bookInfo where bookISBN = + ISBN + ;rs = stmt.executeQuery(strSql);while (rs.next()bookName = rs.getString(bookName);bookAuthor = rs.getString(bookAuthor);publisher = rs.ge

22、tString(publisher);introduce = rs.getString(introduce);price = rs.getString(price);/捕获异常catch(SQLException e)System.err.println(BookBean.getBookList(): + e.getMessage();/给图书的编号赋值,同时调用函数给图书的其他信息赋值public void setBookISBN (String ISBN)this.bookISBN = ISBN;getBookInfo(bookISBN);/取图书编号public String getBo

23、okISBN ()return bookISBN ;/取书名public String getBookName()return bookName ;/取作者信息public String getBookAuthor()return bookAuthor;/取出版社信息public String getPublisher()return publisher;/取图书简介public String getIntroduce()return introduce ;/取图书价格public String getPrice()return price;/将Bean作为一个application进行测试用

24、public static void main(String args)BookBean book = new BookBean ();book.setBookISBN(7-5053-5316-4);System.out.println(book.getBookName();System.out.println(book.getBookAuthor();System.out.println(book.getPublisher();System.out.println(book.getIntroduce();System.out.println(book.getPrice();tryResult

25、Set tmpRS = book.getBookList();while (tmpRS.next()System.out.println(tmpRS.getString(bookname);tmpRS.close();/捕获异常catch(Exception e)System.err.println(main() + e.getMessage();15.2.2 选书JSP会员正确登录之后,即可进入书店进行选书,我们已经在checklogon.jsp中将会员的代码(memberID)放入系统的session中,为了保证用户只能从主页面登录进入书店,我们在给会员显示可供选择的图书之前,先检查ses

26、sion中是否有memberID的合法值,如果没有则提示用户先去登录。清单15-5 booklist.jspCUUG Book Store On Line -member:CUUG 网上书店 请先登录,然后再选书 登录 书名 作者 出版社 定价 a href=bookinfo.jsp?isbn= a href=Javascript:openwin()加入购物车 der=0 查看购物车 已经登录过的会员和没有登录过的会员进入该页面是的结构分别如图15-10和图15-11所示:正确登录的会员的会员代码在浏览器的标题栏显示为:member:“会员代码”。图15-10 会员abcd正确登录图15-11

27、 会员未登录直接来选书在本例中利用JavaScript语句定义了一个函数来将所调用另外的一个jsp来处理把书加入购物车的操作:该函数用于打开addcart.jsp并切将图书编号作为参数传给addcart.jsp。addcart.jsp利用Cookie来保存所选购的图书信息,Cookie相当于一个购物车。为了与其他的Cookie变量区分,每个写入Cookie的图书编码前面都加上“ISBN”作为标志,向购物车中加入图书的代码如下:清单15-6 addcart.jspfunction Timer()setTimeout(self.close(),10000)购物车CUUG 网上订书系统图书已经成功放

28、入购物车!查看购物车SHOPPING CART提交定单 ORDER (此窗口将为您在10秒内自动关闭,您的商品已经安全地保存在购物车中。)在addcart.jsp中利用JavaScript定义了一个函数Timer(),由它来控制该窗口的显示时间()。继续购买部分也是由JavaScript定义的函数来控制关闭本窗口。其运行结果如图15-12所示。图15-12 加入购物车无论从图15-12还是图15-13所示的界面中,都提供了一个查看购物车的超链接,查看购物车的程序如下所示,它从Cookie中取出图书的编号,并将它传给BookBean,由BookBean来获得图书的详细资料。查看购物车的JSP代码

29、shoppingcart.jsp代码如下:清单15-7 shoppingcart.jsp查看购物车 -member:CUUG 网上书店购物车 ISBN 书名 单价 数量 %/*读取购物车信息*/Cookie cookies=request.getCookies();for (int i=0;i A href=bookinfo.jsp?isbn= INPUT size=5 type=text maxlength=5 value= name=num readonly A href=delbook.jsp?isbn=删除 返回首页 清空购物车 修改数量 填写提交订单 查看购物车的结果如图15-13所

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

31、15-9 emptycart.jsp%/*清空Cookie(购物车)信息*/Cookie cookies=request.getCookies();for (int i=0;i清空购物车 图15-15 清空购物车的页面从图书选择页面和购物车页面,点图书名称,都可以查看图书的详细信息,查看图书详细信息的jsp仍用BookBean来获取图书的详细信息,只是在该页中可以看到更加详细的信息:清单15-10 bookinfo.jsp图书信息 ISBN 书名 出版社 作者/译者 图书价格 内容简介 a href=Javascript:openwin()加入购物车 查看购物车 返回首页 其运行结果如图15-

32、16所示。图15-16 图书详细信息15.3 定单提交及查询用户一旦确定购物车中所选的图书都是其所要购买的,就要到去提交其定单,以便书店按照相应的方式进行处理。而且,为方便用户是否已经提交定单,及定单的状态,本例提供了定单查询功能。在此处我们用OrderBean来将定单提交到数据库中,在order.jsp中显示并提交定单信息,queryorder.jsp来查询定单。在会员选书部分,我们仍用Java Bean来操作数据库,用jsp来做页面表现。15.3.1 定单提交Java Bean为了减少数据冗余,定单信息由两张表来记录其信息:orderInfo,记录定单的有关公用信息,orderdetail

33、,记录该定单包含哪些书籍及数量,表结构分别如下:图15-17 定单信息表结构图15-18 定单详细所有的对数据库的操作都由JavaBean来完成,其代码如下:清单15-11 OrderBean.Javapackage cuug;import Java.sql.*;public class OrderBean private static String strDBDriver = sun.jdbc.odbc.JdbcOdbcDriver;private static String strDBUrl = jdbc:odbc:bookstore;private Connection conn =nu

34、ll;private ResultSet rs = null;private Java.lang.String bookinfo = null;private Java.lang.String oderprice = null;private Java.lang.String orderDate = null;private Java.lang.String orderID = null;private Java.lang.String orderRem = null;private Java.lang.String receiverAddress = null;private Java.la

35、ng.String receiverName = null;private Java.lang.String receiverZip = null;private Java.lang.String userID = null;public OrderBean()try Class.forName(strDBDriver );catch(Java.lang.ClassNotFoundException e)System.err.println(OrderBean (): + e.getMessage();public static void main(String args)/* * 返回定单的

36、总价。 * return Java.lang.String */public Java.lang.String getOderprice() return oderprice;/* *返回定单的日期 。 * return Java.lang.String */public Java.lang.String getOrderDate() orderDate = new Java.util.Date().toString();return orderDate;/* * 返回定单的ID号。 * return Java.lang.String */public Java.lang.String get

37、OrderID() return orderID;/* * 返回定单的备注信息。 * return Java.lang.String */public Java.lang.String getOrderRem() return orderRem;/* * 返回接收者的地址 * return Java.lang.String */public Java.lang.String getReceiverAddress() return receiverAddress;/* * 返回接收者的姓名。 * return Java.lang.String */public Java.lang.String

38、getReceiverName() return receiverName;/* * 返回接收者的邮政编码。 * return Java.lang.String */public Java.lang.String getReceiverZip() return receiverZip;/* * 获得用户ID。 * return Java.lang.String */public Java.lang.String getUserID() return userID;/* * 给图书信息赋值。 * param newBooks Java.util.Properties */public void

39、setBookinfo(Java.lang.String newBookinfo) bookinfo = newBookinfo;createNewOrder();int fromIndex = 0;int tmpIndex = 0;int tmpEnd = 0;String strSql = null;tryconn = DriverManager.getConnection(strDBUrl);Statement stmt = conn.createStatement();while(bookinfo.indexof(;,fromIndex) != -1 )tmpEnd = bookinf

40、o.indexOf(;,fromIndex);tmpIndex = bookinfo.lastIndexof(=,tmpEnd);strSql = insert into orderdetail (orderID ,bookISBN ,bookcount)+ values( getOrderID() + , + bookinfo.substring(fromIndex ,tmpIndex) + , + bookinfo.substring(tmpIndex+1 ,tmpEnd) + ) ;stmt.executeUpdate(strSql);fromIndex = tmpEnd + 1;stm

41、t.close();conn.close();catch(SQLException e)System.err.println(BuyerBean.getLogontimes(): + e.getMessage();/* *给定单的总价赋值。 * param newOderprice Java.lang.String */public void setOderprice(Java.lang.String newOderprice) oderprice = newOderprice;/* * 给定单的备注赋值。 * param newOrderRem Java.lang.String */publ

42、ic void setOrderRem(Java.lang.String newOrderRem) orderRem = newOrderRem;/* * 给接收者的地址赋值。 * param newReceiverAddress Java.lang.String */public void setReceiverAddress(Java.lang.String newReceiverAddress) receiverAddress = newReceiverAddress;/* * 给接收者的姓名赋值。 * param newReceiverName Java.lang.String */p

43、ublic void setReceiverName(Java.lang.String newReceiverName) receiverName = newReceiverName;/* * 给接收者的邮政编码代码赋值。 * param newReceiverZip Java.lang.String */public void setReceiverZip(Java.lang.String newReceiverZip) receiverZip = newReceiverZip;/* * 给用户代码赋值。 * param newUserID Java.lang.String */public

44、 void setUserID(Java.lang.String newUserID) userID = newUserID;/* * 创建一个新定单 */private void createNewOrder() String strSql = null;tryconn = DriverManager.getConnection(strDBUrl);Statement stmt = conn.createStatement();strSql = insert into orderInfo (userID,receiverName,receiverAddress,receiverZip,ord

45、erRem,orderPrice,Orderdate)+ values( getUserID() + , + getReceiverName() + , + getReceiverAddress() + , + getReceiverZip() + , + getOrderRem() + , + getOrderPrice() + , getOrderDate() + ) ;stmt.executeUpdate(strSql);strSql = select max(OrderID) from orderInfo where userID = getUserID() + and receiverName = +

温馨提示

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

评论

0/150

提交评论