首页 JSP网上书店开发完整实例(含完整源代码)

JSP网上书店开发完整实例(含完整源代码)

举报
开通vip

JSP网上书店开发完整实例(含完整源代码)JSP网上书店开发完整实例(含完整源代码) 完整的简单jsp网上书店详细实例 计算机web编程jsp毕业论文、考试复习资料必备 其中包括的详细需求、业务分析、数据库、源代码 我们使用JSP和Java Bean来构建一个网上书店。介绍的例子可以分成两大部分,第一部分是普通程序,用于客户在网上选购图书,第二部分是管理程序,用于在服务器端处理客户的定单。客户端程序由以下几个部分构成: default.jsp:会员登录界面(首页); checklogon.jsp:检测登录代码和密码是否一致,根据由JavaBea...

JSP网上书店开发完整实例(含完整源代码)
JSP网上 关于书的成语关于读书的排比句社区图书漂流公约怎么写关于读书的小报汉书pdf 店开发完整实例(含完整源代码) 完整的简单jsp网上书店详细实例 计算机web编程jsp 毕业论文 毕业论文答辩ppt模板下载毕业论文ppt模板下载毕业论文ppt下载关于药学专业毕业论文临床本科毕业论文下载 、考试复习资料必备 其中包括的详细需求、业务 分析 定性数据统计分析pdf销售业绩分析模板建筑结构震害分析销售进度分析表京东商城竞争战略分析 、数据库、源代码 我们使用JSP和Java Bean来构建一个网上书店。介绍的例子可以分成两大部分,第一部分是普通程序,用于客户在网上选购图书,第二部分是管理程序,用于在服务器端处理客户的定单。客户端程序由以下几个部分构成: default.jsp:会员登录界面(首页); checklogon.jsp:检测登录代码和密码是否一致,根据由JavaBean返回的结果显示不同的信息。 BuyerBean:会员的合法性检验所用的Bean; booklist.jsp:给登录会员显示当前书店中可供选择的图书; addcart.jsp:将所选的图书加入购物车; shoppingcart.jsp:查看购物车的内容; 本例的数据库采用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”选项下单击“添加”按钮,来添加一个系统的数据源(DSN),则出现如图15-2所示数据源驱动程序选择界面: 38 3 图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。 384 图15-4 数据库选择界面 15.1 会员登录 做一个网上书店,在顾客开始购书之前,必须要记录用户的一些信息以便用户在不同的分类、不同的页面购书时,最后能够去收款台统一结帐,而且网上书店同时有许多人在选购图书,也要求对不同的顾客进行区分,我们可以要求顾客在购书之前进行注册成为会员,以后只用会员代码和密码即可登录。 为了便于 说明 关于失联党员情况说明岗位说明总经理岗位说明书会计岗位说明书行政主管岗位说明书 现在的电子商务网站,由JSP做页面 关于同志近三年现实表现材料材料类招标技术评分表图表与交易pdf视力表打印pdf用图表说话 pdf 现,由Java Bean做应用逻辑的结构,在本例中将会员登录程序分成两大部分:一、Java Bean用于对数据库的操作,验证用户名和密码是否正确;二、JSP页面部分,用于供用户会员代码和密码以及显示验证结果。 38 5 15.1.1 会员登录Java Bean 我们网上书店中的会员信息的库结构如图15-5所示: 图15-5 会员信息库 其中memberID 是主键,用于区分不同的会员,新会员注册时只能使用没有被使用的用户代码。 在验证时我们只要使用验证用户的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()— 取该会员登录的次数 *getMenberName()获得该会员的真实姓名,用于显示欢迎信息。 *main()方法用于将BEAN作为一个 Application进行测试时使用,正式发布时可以删除。 **/ package cuug; import Java.sql.*; public class BuyerBean { private String memberID = null ; //会员ID 386 private String memberName = null; //会员姓名 private String pwd = null; //密码 private int logontimes = -1; //登录的次数 private 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.ClassNotFoundException e){ System.err.println(―BuyerBean():‖ + e.getMessage()); } } //获得登录次数,登录的会员的名字也在该方法调用时获得 public int getLogontimes(){ String strSql = null; try{ conn = DriverManager.getConnection(strDBUrl); Statement stmt = conn.createStatement(); strSql = ―Select logonTimes,membername from buyerInfo where memberID = ?‖ + memberID + ―‘ and pwd =‘‖ + pwd + ―‘‖; rs = stmt.executeQuery(strSql); while (rs.next()){ // 登录的次数 logontimes = rs.getInt(―logonTimes‖); 38 7 //会员姓名 memberName = rs.getString(―membername‖); } rs.close(); //如果是合法会员则将其登录次数加1 if (logontimes != -1 ) { strSql = ―Update buyerInfo set logonTimes = logonTimes +1 where memberID = ?‖ + memberID + ―‘‖; 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 = password; } //获得该会员的真实姓名,必须在取该会员登录的次数之后才能被赋予正确的值 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.getMemberName()); 388 } } 在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 CUUG ON LINE BOOK STORE – MEMBER LOGIN

CUUG 网上书店

会员登录页

 

 


请输入会员代号和密码:
38 9 会员代码:
密    码:

在本例中提供了一个文本框供用户输入会员代号和登录密码,其运行结果如图15-6所 示,当会员输入其代码和密码后调用checklogon.jsp 来验证该网络用户是否是合法会员。 图15-6 会员登录页 在checklogon.jsp 中接收从default.htm中由用户所填的会员代码和密码,把它传给 BuyerBean,由BuyerBean判断该用户的会员代码和密码的正确性,若正确显示欢迎信息; 若不正确,则提供一个重新登录的链接。 Checklogon.jsp的源代码如下: 清单15-3 checklogon.jsp <%@ page language=‖Java‖ contentType=‖text/html;charset=GB2312‖%> 390 CUUG ON LINE BOOK STORE – MEMBER LOGIN

CUUG 网上书店

<% String memberID = request.getParameter(―memberID‖); String pwd = request.getParameter(―pwd‖); buyer.setMemberID(memberID); buyer.setPwd(pwd); %> <% int logonTimes = buyer.getLogontimes() ; if (logonTimes > 0){ session.putValue("memberID",memberID); %>

<%= buyer.getMemberName() %>欢迎你第 <%= logonTimes +1%>次来到CUUG网上书店

进入书店

<% } else{ %>

对不起,<%= memberID %>你的用户名和密码不一致

重新登录

<% } %> 39 1 登录正确时的结果如图15-7所示,错误时的结果如图15-8所示。 图15-7 用户登录正确(会员abcd的真实姓名是cuug001) 图15-8 用户登录错误 15.2 选书 会员登录之后,合法的用户将可以看到本书店中可供选择的图书,并且将他感兴趣的书放入“购物车”,在去“收银台”结帐之前,该用户可以放弃购买其购物车中的任何一本书。在此处我们用BookBean来获取图书的信息,在Booklist.jsp中显示这些书。 在会员选书部分,我们仍用Java Bean来操作数据库,用jsp来做页面表现。 15.2.1 选书Java Bean 图书信息的表结构如图15-9所示,为了便于说明,在本例中price也设置成了String型,在实际应用中应该设置成货币或浮点型: 392 图15-9 图书信息的表结构 其中,bookISBN是主键,区分不同的图书。Java Bean要根据不同的图书的bookISBN来获得其相应的书名、作者、出版社、价格、简介等信息。同时Java Bean还要有列出书店中所有图书的信息的功能。 清单15-4 BookBean..Java /* *BuyerBean.Java 1.10.2001 *Copyright ? 2000, 2001 by cuug ,llp. *本Bean中的各个方法的功能介绍如下: *setBookISBN():设置图书的编号,同时根据编号更新相应的书名、作者、出版社、价 格*和简介 *getBookList()— 取得书库中全部书的书名、出版社、价格、作者等信息; *getBookISBN()— 取得当前图书的编号 ; *getBookName()—取得当前图书的书名; *getBookAuthor()—取得当前图书的作者; *getPublisher()—取得当前图书的出版社信息; *getPrice()—取得当前图书的价格; * getIntroduce()取得当前图书的简介信息。 *main()方法用于将BEAN作为一个 Application进行测试时使用,正式发布时可以删除。 **/ package cuug; 39 3 import Java.sql.*; public class BookBean { private String bookISBN = null; //图书编号 private String bookName = null; //书名 private String bookAuthor = null; //作者 private String publisher = null; //出版社 private 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(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,price from bookInfo "; rs = stmt.executeQuery(strSql); } //捕获异常 catch(SQLException e){ System.err.println("BookBean.getBookList():" + e.getMessage()); } return rs ; } 394 //根据图书的编号给图书的其他信息赋值 private void getBookInfo(String ISBN){ String strSql = null; bookName = null; bookAuthor = null; publisher = null; introduce = null; price = 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.getString("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); 39 5 } //取图书编号 public String getBookISBN (){ 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进行测试用 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()); try{ ResultSet tmpRS = book.getBookList(); while (tmpRS.next()){ System.out.println(tmpRS.getString("bookname")); 396 } tmpRS.close(); } //捕获异常 catch(Exception e){ System.err.println("main()" + e.getMessage()); } } } 15.2.2 选书JSP 会员正确登录之后,即可进入书店进行选书,我们已经在checklogon.jsp中将会员的代 码(memberID)放入系统的session中,为了保证用户只能从主页面登录进入书店,我们 在给会员显示可供选择的图书之前,先检查session中是否有memberID的合法值,如果没 有则提示用户先去登录。 清单15-5 booklist.jsp <%@ page language="Java" import="Java.sql.*" contentType="text/html;charset = gb2312"%> CUUG Book Store On Line -member:<%= session.getValue("memberID") %>

CUUG 网上书店

<% if (session.getValue("memberID") == null||"".equals(session.getValue("memberID"))){ %>

请先登录,然后再选书

登录

<% } else{ %> <% ResultSet rs = book.getBookList(); while(rs.next()){ String ISBN = rs.getString("bookISBN"); %> <% 398 } %>
书名 作者 出版社 定价  
<%= rs.getString("bookName")%> <%= rs.getString("bookAuthor")%> <%= rs.getString("publisher")%> <%= rs.getString("price")%> 加入购物车
查看购物车

 

<% } %> 已经登录过的会员和没有登录过的会员进入该页面是的结构分别如图15-10和图15-11 所示:正确登录的会员的会员代码在浏览器的标题栏显示为:member:“会员代码”。 39 9 图15-10 会员abcd正确登录 图15-11 会员未登录直接来选书 在本例中利用JavaScript语句定义了一个函数来将所调用另外的一个jsp来处理把 书加入购物车的操作: 该函数用于打开addcart.jsp并切将图书编号作为参数传给addcart.jsp。 addcart.jsp利用Cookie来保存所选购的图书信息,Cookie相当于一个购物车。为了与 其他的Cookie变量区分,每个写入Cookie的图书编码前面都加上“ISBN”作为标志,向 购物车中加入图书的代码如下:] 清单15-6 addcart.jsp <%@ page language="Java" contentType="text/html;charset=GB2312"%> <% /*Cookie信息处理*/ /*增加Cookie*/ if (request.getParameter("isbn")!=null) { Cookie cookie=new Cookie("ISBN"+request.getParameter("isbn"),"1"); cookie.setMaxAge(30*24*60*60);//设定Cookie有效期限30日 response.addCookie(cookie); } %> 购物车——CUUG 网上订书系统 40 1
图书已经成功放入购物车~
查看购物车SHOPPING CART
提交定单 ORDER
(此窗口将为您在10秒内自动关闭,您的商品已经安全地保存在购物车中。)
在addcart.jsp中利用JavaScript定义了一个函数Timer(),由它来控制该窗口的显示时 间()。继续购买部分也是由JavaScript定义的函数来控制关闭本 窗口。其运行结果如图15-12所示。 图15-12 加入购物车 无论从图15-12还是图15-13所示的界面中,都提供了一个查看购物车的超链接,查看 购物车的程序如下所示,它从Cookie中取出图书的编号,并将它传给BookBean,由 BookBean来获得图书的详细资料。查看购物车的JSP代码shoppingcart.jsp代码如下: 清单15-7 shoppingcart.jsp <%@ page language="Java" contentType="text/html;charset=gb2312"%> <% /*禁止使用浏览器Cache*/ response.setHeader("Pragma", "No-cache"); 402 response.setHeader("Cache-Control", "no-cache"); response.setDateHeader("Expires",0); %> 查看购物车 -member:<%= session.getValue("memberID") %>

CUUG 网上书店购物车

<% /*读取购物车信息*/ Cookie[] cookies=request.getCookies(); for (int i=0;i <% } } %>
ISBN 书名 单价 数量
<%=bookinfo.getBookISBN()%> <%= bookinfo.getBookName()%> <%= bookinfo.getPrice()%> 删除

返回首页 清空购物车 修改数量 填写,提交订单
查看购物车的结果如图15-13所示: 404 图15-13 查看购物车内容 在查看购物车内容时提供了一个删除图书的功能,其目的是从购物车删除不想购买的 图书,其源代码如下: 清单15-8 delbook.jsp <%@ page language="Java" contentType="text/html;charset=GB2312"%> <% /*Cookie信息处理*/ /*清除Cookie*/ if (request.getParameter("isbn")!=null) { Cookie cookie=new Cookie("ISBN"+request.getParameter("isbn"),"0"); cookie.setMaxAge(0);//设定Cookie立即失效 response.addCookie(cookie); } %> 40 5 删除图书 ...... 本例中利用jsp:forward动作在删除图书动作完成之后,将页面继续转向购物车页面。 即图15-14只显示一瞬间,浏览器的内容由成为购物车内容的页面。 图15-14 删除图书的页面 如果一个会员选了很多书,逐个删除比较麻烦。为了方便会员放弃选购的所有图书, 重新开始选书,本例提供了清空购物车程序(emptycart.jsp),用于清空购物车,其原理与 删除图书相同,只是把全部的Cookie中图书的有关的内容都清空了。其代码如下: 清单15-9 emptycart.jsp <%@ page language="Java" contentType="text/html;charset=GB2312"%> <% /*清空Cookie(购物车)信息*/ Cookie[] cookies=request.getCookies(); for (int i=0;i 清空购物车...... 图15-15 清空购物车的页面 从图书选择页面和购物车页面,点图书名称,都可以查看图书的详细信息,查看图书 详细信息的jsp仍用BookBean来获取图书的详细信息,只是在该页中可以看到更加详细的 40 7 信息: 清单15-10 bookinfo.jsp <%@ page language="Java" contentType="text/html;charset=gb2312"%> 图书信息
<% /*读取购物车信息*/ if (request.getParameter("isbn")!=null) { String isbn = request.getParameter("isbn"); bookinfo.setBookISBN(isbn); %> 408 40 9
ISBN <%= bookinfo.getBookISBN()%>
书名 <%= bookinfo.getBookName()%>
出版社 <%= bookinfo.getPublisher()%>
作者/译者 <%= bookinfo.getBookAuthor()%>
图书价格 <%= bookinfo.getPrice()%>
内容简介

<% } else { out.println("没有该图书数据"); } %>
加入购物 车 查看购物车 返回首页
其运行结果如图15-16所示。 图15-16 图书详细信息 410 15.3 定单提交及查询 用户一旦确定购物车中所选的图书都是其所要购买的,就要到去提交其定单,以便书店按照相应的方式进行处理。而且,为方便用户是否已经提交定单,及定单的状态,本例提供了定单查询功能。在此处我们用OrderBean来将定单提交到数据库中,在order.jsp中显示并提交定单信息,queryorder.jsp来查询定单。 在会员选书部分,我们仍用Java Bean来操作数据库,用jsp来做页面表现。 15.3.1 定单提交Java Bean 为了减少数据冗余,定单信息由两张表来记录其信息:orderInfo,记录定单的有关公用信息,orderdetail,记录该定单包含哪些书籍及数量,表结构分别如下: 图15-17 定单信息表结构 图15-18 定单详细 所有的对数据库的操作都由JavaBean来完成,其代码如下: 清单15-11 OrderBean.Java 41 1 package 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 =null; 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.lang.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[]){ } /** * 返回定单的总价。 * @return Java.lang.String */ public Java.lang.String getOderprice() { 412 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 getOrderID() { return orderID; } /** * 返回定单的备注信息。 * @return Java.lang.String */ public Java.lang.String getOrderRem() { return orderRem; } /** * 返回接收者的地址 * @return Java.lang.String 41 3 */ public Java.lang.String getReceiverAddress() { return receiverAddress; } /** * 返回接收者的姓名。 * @return Java.lang.String */ public Java.lang.String 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 setBookinfo(Java.lang.String newBookinfo) { bookinfo = newBookinfo; createNewOrder(); int fromIndex = 0; int tmpIndex = 0; int tmpEnd = 0; 414 String strSql = null; try{ conn = DriverManager.getConnection(strDBUrl); Statement stmt = conn.createStatement(); while(bookinfo.indexof(';',fromIndex) != -1 ){ tmpEnd = bookinfo.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; } stmt.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; } /** 41 5 * 给定单的备注赋值。 * @param newOrderRem Java.lang.String */ public 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 */ public 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 void setUserID(Java.lang.String newUserID) { userID = newUserID; } /** 416 * 创建一个新定单 */ private void createNewOrder() { String strSql = null; try{ conn = DriverManager.getConnection(strDBUrl); Statement stmt = conn.createStatement(); strSql = "insert into orderInfo (userID,receiverName, receiverAddress,receiverZip,orderRem,orderPrice,Orderdate)" + " values( '" getUserID() + "', '" + getReceiverName() + "', '" + getReceiverAddress() + "', '" + getReceiverZip() + "', '" + getOrderRem() + "', " + getOrderPrice() + " ,'" getOrderDate() + "')" ; stmt.executeUpdate(strSql); strSql = "select max(OrderID) from orderInfo where userID = '" getUserID() + "' and receiverName = '" + getReceiverName() + "' and receiverAddress = '" + getReceiverAddress() +"' and receiverZip = '" + getReceiverZip() +"' and orderRem = '" + getOrderRem() + "' and orderPrice = " + getOrderPrice() +" and Orderdate = '" getOrderDate() + "'" ; orderID = 0; rs = stmt.executeQuery(strSql); while (rs.next()){ orderID = rs.getString("OrderID"); } rs.close(); stmt.close(); conn.close(); 41 7 } catch(SQLException e){ System.err.println("BuyerBean.getLogontimes():" + e.getMessage()); } } } 在本Bean中,如果一张定单中有多种书籍,可以以“BOOKISBN = BOOKCOUNT; BOOKISBN = BOOKCOUNT;”的形式组成字符串,来向JAVABEAN中的bookinfo赋值。 在赋值后,Bean内部完成创建定单,并将各个图书信息拆分,提交定单的详细信息。 15.3.2 定单提交JSP 用jsp页面来显示用户所选的图书的信息,并提供一个提交按纽,为便于程序的管理, 我们将显示和处理结果放在一个JSP中,其代码如下: 清单15-12 order.jsp <%@ page language="Java" contentType="text/html;charset=GB2312"%> <% /*禁止使用浏览器Cache,网页立即失效*/ response.setHeader("Pragma", "No-cache"); response.setHeader("Cache-Control", "no-cache"); response.setDateHeader("Expires",0); %> 填写订单 <% if ("send".equals(request.getParameter("send"))) { orderBean.setUserID(session.getValue("memberID")); String str=request.getParameter("receivername"); orderBean.setReceiverName(str==null?"":str); 418 str=request.getParameter("orderprice"); orderBean.Oderprice(Java.lang.Float.valueOf(str==null?"0":str).floatValue()); str=request.getParameter("address"); orderBean.setReceiverAddress(str==null?"":str); str=request.getParameter("postcode"); orderBean.setReceiverZip(str==null?"":str); str=request.getParameter("bookinfo"); orderBean.setBookinfo(str==null?"":str); str=request.getParameter("memo"); orderBean.setMemo(str==null?"":str); int orderID=orderBean.getOrderID(); if (orderID>0) { /*清空Cookie(购物车)信息*/ Cookie[] cookies=request.getCookies(); for (int i=0;i

订购成功!

订单号:<%=orderID%>

返回首页

<% } else { 41 9 out.print("订购失败\n"); } } else { float price=0; String bookInfo=""; %>
<% /*读取购物车信息*/ Cookie[] cookies=request.getCookies(); for (int i=0;i 420 <% price += bookPrice.floatValue()*Java.lang.Integer.parseInt(num); bookInfo += bookinfo.getBookISBN()+"="+num+";"; } } %>
ISBN 书名 单价 数量 价格
<%= bookinfo.getBookISBN()%> <%= bookinfo.getBookName()%> <%= bookPrice%> <%= bookPrice.floatValue() * Java.lang.Integer.parseInt(num)%>

 

   

如以上信息无误,请填写以下信息并按提交按钮提交订 单,完成网上订书:

42 1
收书人姓名
订单总金额
发送地址
邮编
备注
<% } %> 422 在本JSP中将图书信息按照“BOOKISBN = BOOKCOUNT;BOOKISBN = BOOKCOUNT;”的形式组成字符串,用来向JAVABEAN中的bookinfo赋值,并根据JSP的处理结果进行响应的处理:如果定单被正确处理则,显示定单号并清空cookie(购物车)信息,如果定单未被正确提交,则显示出错信息。运行结果如图15-19所示,定单正确提交后的结果如图15-20所示,定单未被正确提交的结果如图15-21所示。 图15-19 定单提交信息 图15-20 定单正确提交 42 3 图15-21 定单未正确提交 小结: 本文提供的是一个简单的网上书店的例子,本文提供的例子中尚有许多可以改进的地方。例如,文中数据库表orderinfo中提供了handled字段,在对定单进行处理发出书之后,可对该字段进行设置,将其值设成非0值,另增加一个供用户对定单进行查询的JSP页面。对定单的处理程序可用JSP,也可以用传统MIS来实现。希望读者对本例进行进一步的完善。 424
本文档为【JSP网上书店开发完整实例&#40;含完整源代码&#41;】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_314871
暂无简介~
格式:doc
大小:485KB
软件:Word
页数:58
分类:生活休闲
上传时间:2018-04-25
浏览量:81