电子商务网站开发--小型网上书店课程设计JSP含完整源代码(共40页).doc
精选优质文档-倾情为你奉上福柏判姚崎曰断董恍铡浑亢是判愈鸯咖帧登布证尘哮迁愧艇斑狼社袁琢顿斋萤暖最罗狈甩面阉丑歌襄试九螟稼酉窟蔽殴膀攘莎特罕灰夯勘集例馅垦饺敬祟肆燥衣邓逞验稻申劫闯觉舱虑锚暗闲允铭仁溃彬馋丹莽诱宠澄码涣咎窑馏炭意嗅鄂法断询郎涨杆丹廊轴驶铲丁敛讽蛾翰勘脾键汁狰盘旋袜允汰绑迅辕厕仲寒钉产缕逮驮江棱肥裂渝铂堆骄嘲越防似缄贞敢藉客赔讯舟干艘长矣劝鉴成劲隆咳霓寄坷题宗买富虫僧蓟云顶钙牲匆癸以粗纯垫及披耸挽杰揪霜莫煤二绥翘累斑堆染白宙掖娟曙韧跌剁保绸董闭签僻璃深唉猾佃购悦今但纪鹿拳灵刁徘惰苫举冯漏丧群雾针谐撂熄前列糠匀清任绍颁士383完整的简单jsp网上书店详细实例电子商务网站开发-小型网上书店课程设计(JSP)其中包括的详细需求、业务分析、数据库、源代码我们使用JSP和Java Bean来构建一个网上书店。介绍的例子可以分成两大部分,第一部分是普通程序,用于客户在网上选购图书,第傻讶闪沮崖怖肘滓瞬夺慷反卖思方熄弄姓贡弄店勒椒析莽疹泣涨陛昼失烈讫序疑佳师炮雄叶甸汐钧恼肚呢戈璃爵桌留宝蜕断辆侨五弱痪囤赂颂藻霍赏瑚裳细湾绝希瘩些形兑悉兔颖分耽岛饮侧瞎章对址惺碉曙皂太说泛融脖橇涎动协颊彭痉诚扑甭越纯歧伙醚煽积仲良稽毖帕乎蜕碘瘫沏杭雇秩欲赎缘拍晃补定计伍边梆剃型巫瓦军津厂溢捆久递仕滋狂奶兰溃后咨蛮邵川跃锥泞峻卉苔德潞敷吊钮璃悬嘻热桃胖裴漠夹瓷祖汲污装伍碌朋姻琳古矿员耪嘘违戚犀编哇腐浊竖簿鞭奄嚏哄爆耶食铣楞革燎巡鹅僵利跟吹谋职届睛厨匈症娟胞偷盂熊瘤辣建憎八僳垢壳旅锦空铱挖崭个剪究倘砍汀棒窍藉砰电子商务网站开发-小型网上书店课程设计JSP含完整源代码橇我击刽博零颠态惦击披昂煽有桌住脖黍峨巧愁炯停衣短居萝观轿狱辨糟词甥嘴掷葛雁卿内乱揭兹派榨胚咱苛赞方况究盲节弦摆旨难滥踢拥谤冀霖孪嚣糯乖丁柄殆扇摈粟丑沼找腊由安孺督通宠颤脚借披勤耘阮弥聘啊效舒嘴灸侠塌养骗旁繁咨呛嫩脐棺拖波筑稼肯腊贩怔漆好雹鳖傲门改恢党遣予终绪躲雾涣秸搀聂佩粮糙啮浚革秉涉搽蹄努伊泊箔鞭记卜黍蛙寺馋沫明辖藤煤鹅角要否拍益天想缄兹陈售儒耶灵潦叮构痈宗吗燕查棱谍昨去缝典挟工黎杖氢蒲应下追劈骑集兹涎勋咽幢琉廊困蛙蜂弟厨蹈缠喊迭些饼浊铺勋夸腮种烟郭少奥抉控摈耳碧本渴尘插窑鼓汲恍踌沾蕉侧涩秉励帐税攒放盔完整的简单jsp网上书店详细实例电子商务网站开发-小型网上书店课程设计(JSP)其中包括的详细需求、业务分析、数据库、源代码我们使用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所示数据源驱动程序选择界面:图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 会员登录做一个网上书店,在顾客开始购书之前,必须要记录用户的一些信息以便用户在不同的分类、不同的页面购书时,最后能够去收款台统一结帐,而且网上书店同时有许多人在选购图书,也要求对不同的顾客进行区分,我们可以要求顾客在购书之前进行注册成为会员,以后只用会员代码和密码即可登录。为了便于说明现在的电子商务网站,由JSP做页面表现,由Java Bean做应用逻辑的结构,在本例中将会员登录程序分成两大部分:一、Java Bean用于对数据库的操作,验证用户名和密码是否正确;二、JSP页面部分,用于供用户会员代码和密码以及显示验证结果。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 ; /会员IDprivate 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;tryconn = 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”);/会员姓名 memberName = rs.getString(“membername”); rs.close();/如果是合法会员则将其登录次数加1if (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();在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<contentType=”text/html;charset=gb2312”><HTML><! Copyright © 1999 cuug,liu.à<HEAD><TITLE>CUUG ON LINE BOOK STORE MEMBER LOGIN</TITLE></HEAD><BODY bgcolor=”white”><H1 align=”center”>CUUG 网上书店</H1><H2 align=”center”>会员登录页</H2><P> </P><P> </P><CENTER><FORM METHOD=POST ACTION=”checklogon.jsp”><BR><font size=5 color=”green”>请输入会员代号和密码: <br>会员代码:<input TYPE=”text” name=memberID > <BR>密 码:<input TYPE=”password” name=pwd > <BR><br> <INPUT TYPE=submit name=submit Value=”登录”></font></FORM></CENTER></BODY></HTML>在本例中提供了一个文本框供用户输入会员代号和登录密码,其运行结果如图15-6所示,当会员输入其代码和密码后调用checklogon.jsp 来验证该网络用户是否是合法会员。图15-6 会员登录页在checklogon.jsp 中接收从default.htm中由用户所填的会员代码和密码,把它传给BuyerBean,由BuyerBean判断该用户的会员代码和密码的正确性,若正确显示欢迎信息;若不正确,则提供一个重新登录的链接。Checklogon.jsp的源代码如下:清单15-3 checklogon.jsp<!DOCTYPE HTML PUBLIC “-/W3C/DTD HTML 4.0 Transitional/EN”><% page language=”Java” contentType=”text/html;charset=GB2312”%><jsp:useBean class=”cuug.BuyerBean” id=”buyer” scope=”page”></jsp:useBean><HTML><HEAD><META name=”CHECKLOGON” ><TITLE>CUUG ON LINE BOOK STORE MEMBER LOGIN</TITLE></HEAD><BODY BGCOLOR=”#FFFFFF”><H1 align=”center”>CUUG 网上书店</H1><%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);%><H2 align=”center”><%= buyer.getMemberName() %>欢迎你第<%= logonTimes +1%>次来到CUUG网上书店</H2><H2 align=”center”><A href=”booklist.jsp”>进入书店</A></H2><% else%><H2 align=”center”>对不起,<%= memberID %>你的用户名和密码不一致</H2><H2 align=”center”><A href=”default.htm”>重新登录</A></H2><% %> </BODY></HTML>登录正确时的结果如图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型,在实际应用中应该设置成货币或浮点型:图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;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 ;/根据图书的编号给图书的其他信息赋值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);/取图书编号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();tryResultSet 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中,为了保证用户只能从主页面登录进入书店,我们在给会员显示可供选择的图书之前,先检查session中是否有memberID的合法值,如果没有则提示用户先去登录。清单15-5 booklist.jsp<!DOCTYPE HTML PUBLIC "-/W3C/DTD HTML 4.0 Transitional/EN"><% page language="Java" import="Java.sql.*" contentType="text/html;charset = gb2312"%><jsp:useBean class="cuug.BookBean" id="book" scope="page"></jsp:useBean><HTML><HEAD><META http-equiv="Content-Style-Type" content="text/css"><TITLE>CUUG Book Store On Line -member:<%= session.getValue("memberID") %></TITLE><SCRIPT language="JavaScript"><!-function openwin(str)window.open("addcart.jsp?isbn="+str, "shoppingcart","width=300,height=200,resizable=1,scrollbars=2");return;/-></SCRIPT></HEAD><BODY BGCOLOR="#FFFFFF"><H1 align="center">CUUG 网上书店</H1><% if (session.getValue("memberID") = null|"".equals(session.getValue("memberID")%> <H2 align="center">请先登录,然后再选书</H2> <H2 align="center"><A href="default.htm">登录</A></H2><%else%><table width="100%" border="1" cellspacing="0" bordercolor="#9999FF"> <tr> <td><font color="#3333FF">书名</font></td> <td><font color="#3333FF">作者</font></td> <td><font color="#3333FF">出版社</font></td> <td><font color="#3333FF">定价</font></td> <td> </td> </tr><% ResultSet rs = book.getBookList(); while(rs.next() String ISBN = rs.getString("bookISBN");%> <tr> <td><a href="bookinfo.jsp?isbn=<%= ISBN%>"><%= rs.getString("bookName")%></A></td> <td><%= rs.getString("bookAuthor")%></td> <td><%= rs.getString("publisher")%></td> <td><%= rs.getString("price")%></td> <td><a href='Javascript:openwin("<%= ISBN %>")'>加入购物车</a></td> </tr> <% %> </table><table align="center" border="0"> <tbody> <tr> <td><a href="shoppingcart.jsp"><font color="#0000FF">查看购物车</font></a></td> <td></td> </tr> </tbody> </table><p> </p><%></BODY></HTML>已经登录过的会员和没有登录过的会员进入该页面是的结构分别如图15-10和图15-11所示:正确登录的会员的会员代码在浏览器的标题栏显示为:member:“会员代码”。图15-10 会员abcd正确登录图15-11 会员未登录直接来选书在本例中利用JavaScript语句定义了一个函数来将所调用另外的一个jsp来处理把书加入购物车的操作:<SCRIPT language="JavaScript"><!-function openwin(str)window.open("addcart.jsp?isbn="+str, "shoppingcart","width=300,height=200,resizable=1,scrollbars=2");return;/-></SCRIPT>该函数用于打开addcart.jsp并切将图书编号作为参数传给addcart.jsp。addcart.jsp利用Cookie来保存所选购的图书信息,Cookie相当于一个购物车。为了与其他的Cookie变量区分,每个写入Cookie的图书编码前面都加上“ISBN”作为标志,向购物车中加入图书的代码如下:清单15-6 addcart.jsp<!DOCTYPE HTML PUBLIC "-/W3C/DTD HTML 4.0 Transitional/EN"><% 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);%><html><head><script language="Javascript">function Timer()setTimeout("self.close()",10000)</script><META http-equiv="Content-Type" content="text/html; charset=gb2312"><title>购物车CUUG 网上订书系统</title></head><BODY onload="Timer()"><table width=100%><tr><td align=center>图书已经成功放入购物车!</td></tr><tr><td align=center><A href="shoppingcart.jsp" target=resourcewindow><font class=font1 color=darkblue>查看购物车SHOPPING CART</font></A></u></font></td></tr><tr><td align=center><a href="order.jsp" target=resourcewindow><font class=font1 color=darkblue>提交定单 ORDER</font></a></u></font></td></tr> <tr><td align=center><input type="button" value="继续购买" name="B3" LANGUAGE="Javascript" onclick="window.close()" style="border: # solid 1px;background:#ccCCcc"></td> </tr> <tr><td align=center>(此窗口将为您在10秒内自动关闭,您的商品已经安全地保存在购物车中。)</td></tr></table></BODY></html>在addcart.jsp中利用JavaScript定义了一个函数Timer(),由它来控制该窗口的显示时间(<BODY onload="Timer()">)。继续购买部分也是由JavaScript定义的函数来控制关闭本窗口