版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p><b> 目錄</b></p><p><b> 前 言2</b></p><p> 第一章概 述3</p><p> 1.1 開發(fā)背景3</p><p> 1.2 JSP簡介4</p><p> 1.2.1 JSP的運行原理
2、4</p><p> 1.2.2 JSP頁面的組成6</p><p> 1.2.3 JavaBean技術(shù)介紹6</p><p> 1.2.4 JSP的運行環(huán)境7</p><p> 1.3 系統(tǒng)開發(fā)環(huán)境7</p><p> 1.3.1 服務(wù)器的配置7</p><p>
3、 1.3.2 數(shù)據(jù)庫后臺環(huán)境的配置11</p><p> 第二章 需求分析14</p><p> 2.1 系統(tǒng)說明14</p><p> 2.2 系統(tǒng)功能簡介15</p><p> 2.2.1 基本功能15</p><p> 2.2.2 用戶界面設(shè)計15</p><p&
4、gt; 2.3 系統(tǒng)運行環(huán)境15</p><p> 第三章 系統(tǒng)設(shè)計17</p><p> 3.1 系統(tǒng)設(shè)計思想17</p><p> 3.2 系統(tǒng)功能模塊化18</p><p> 3.3 數(shù)據(jù)庫設(shè)計18</p><p> 3.3.1 數(shù)據(jù)庫需求分析19</p><
5、p> 3.3.2 數(shù)據(jù)庫概念結(jié)構(gòu)19</p><p> 3.3.3 數(shù)據(jù)庫邏輯機構(gòu)設(shè)計20</p><p> 第四章 詳細設(shè)計22</p><p> 4.1 系統(tǒng)概述22</p><p> 4.2 系統(tǒng)主要文件22</p><p> 4.3 詳細代碼及說明23</p>
6、<p> 4.3.1實現(xiàn)用戶實體的Bean23</p><p> 4.3.2實現(xiàn)商品實體的Bean26</p><p> 4.3.3 實現(xiàn)訂購單實體的Bean27</p><p> 4.3.4 實現(xiàn)購物車實體的Bean29</p><p> 4.3.5 實現(xiàn)購物實體的Bean30</p><p
7、> 4.3.6 前臺運行程序cart.jsp35</p><p> 第五章 總結(jié)41</p><p><b> 致謝42</b></p><p><b> 參考文獻43</b></p><p><b> 前 言</b></p><
8、p> 理,鍛煉了自己的動手實踐能力。更重要的是,通過這次的畢業(yè)設(shè)計,我培養(yǎng)出了刻苦鉆研的學(xué)習(xí)精神和嚴(yán)肅認真的學(xué)習(xí)態(tài)度,這對我以后的學(xué)習(xí)和工作有很大的益處。</p><p> 在這次畢業(yè)設(shè)計過程中,我得到了指導(dǎo)老師xx老師和其他同組同學(xué)的悉心指導(dǎo)。在此,我對他們表示衷心的感謝!隨著Internet國際互聯(lián)網(wǎng)的發(fā)展,越來越多的企業(yè)開始建造自己的網(wǎng)站?;贗nternet的信息服務(wù),商務(wù)服務(wù)已經(jīng)成為現(xiàn)代企業(yè)一
9、項不可缺少的內(nèi)容。很多企業(yè)都已不滿足于建立一個簡單的僅僅能夠發(fā)布信息的靜態(tài)網(wǎng)站?,F(xiàn)代企業(yè)需要的是一個功能強大的,能提供完善的電子商務(wù)服務(wù)的動態(tài)商務(wù)網(wǎng)站。</p><p> JSP是Sun公司推出的一種網(wǎng)站開發(fā)技術(shù),Sun公司借助自己在Java上的不凡造詣,又把人們引進JSP時代,JSP即Java Server Page,它可以在Servlet和JavaBean的支持下,完成功能強大的Web應(yīng)用程序。所以,在我的
10、畢業(yè)設(shè)計中,我采用了JSP作為開發(fā)工具,構(gòu)建了一個能實現(xiàn)簡單的電子商務(wù)的小型動態(tài)商務(wù)網(wǎng)站——網(wǎng)上書店銷售系統(tǒng)。該系統(tǒng)能實現(xiàn)用戶的注冊、登錄功能;能夠?qū)崿F(xiàn)商品的查詢,訂購等功能。該系統(tǒng)基本上具備一個網(wǎng)上商品銷售系統(tǒng)應(yīng)該具備的功能,該設(shè)計項目基本上體現(xiàn)了構(gòu)建一個動態(tài)商務(wù)網(wǎng)站所需要的技術(shù),可以說,目前的大型商務(wù)網(wǎng)站也就是我們這個小型網(wǎng)站在內(nèi)容上的擴充和重復(fù)。</p><p> 通過這次的畢業(yè)設(shè)計,我了解了目前流行的動
11、態(tài)商務(wù)網(wǎng)站的構(gòu)成和運作原理,掌握了用JSP構(gòu)建動態(tài)網(wǎng)站的相關(guān)知識和技術(shù)原</p><p><b> 概 述</b></p><p><b> 1.1 開發(fā)背景</b></p><p> 隨著時代的發(fā)展,信息技術(shù)、Internet/Intranet技術(shù)、數(shù)據(jù)庫技術(shù)的不斷發(fā)展完善,網(wǎng)絡(luò)進程的加快,傳統(tǒng)的購物方式也越來
12、越不能滿足人們快節(jié)奏的生活需求,使得企業(yè)的IT部門已經(jīng)認識到Internet的優(yōu)勢,電子商務(wù)就是在這樣一個背景下產(chǎn)生發(fā)展起來的。伴隨著電子商務(wù)技術(shù)的不斷成熟,電子商務(wù)的功能也越來越強大,注冊用戶可以在網(wǎng)上搜索購買到自己想要的各種商品,初步讓人們體會到了足不出戶,便可隨意購物的快感。我的畢業(yè)設(shè)計也就正是一個電子商務(wù)系統(tǒng)的開發(fā)---網(wǎng)上商品銷售系統(tǒng)。</p><p> 1.2 JSP簡介</p>&
13、lt;p> JSP(Java Server Pages)是由Sun Microsystems 公司倡導(dǎo)、許多公司參與一起建立的一種動態(tài)網(wǎng)頁技術(shù)標(biāo)準(zhǔn),JSP技術(shù)在Servlet技術(shù)基礎(chǔ)上發(fā)展起來的,它正在飛速發(fā)展中,現(xiàn)已成為Java服務(wù)器編程的重要組成部分。它雖然還未成型,但是它必將和J2EE(Java 2 Enterprise Edition)一起發(fā)展。</p><p> JSP是結(jié)合markup(HT
14、ML和XML)和Java代碼來處理一種動態(tài)頁面。每一頁第一次被調(diào)用時,通過JSP引擎自動被編譯成Servlet,然后被執(zhí)行,以后每次調(diào)用時,執(zhí)行編譯過的Servlet。JSP提供了多種方式訪問Java class、Servlet、Applets和Web Server,因此,Web應(yīng)用的功能可以分成多個明確定義公用接口的組件,通過JSP將它們結(jié)合在一起。</p><p> 1.2.1 JSP的運行原理</
15、p><p> 在JSP第一次獲得來自于客戶端瀏覽器的請求時,JSP文件將被JSP引擎(JSP engine)轉(zhuǎn)換成一個Servlet,即將”.jsp”文件編譯成Java Class文件。當(dāng)Servlet引擎接收到請求后,如果設(shè)置了使用最新的JSP,它就會去找JSP文件,檢查該文件在上次編譯后是否改動過。如果改動過,就會重新編譯生成新的Servlet,最終將請求轉(zhuǎn)交給編譯好的Servlet引擎執(zhí)行。如圖1-1:<
16、;/p><p> 圖1-1 JSP運行原理</p><p> 在編譯時如果發(fā)現(xiàn)JSP文件有任何語法錯誤,轉(zhuǎn)換過程將中斷,并向客戶端發(fā)出出錯信息;如果編譯成功,則所轉(zhuǎn)換產(chǎn)生的Servlet代碼被編譯,然后該Servlet被JSP引擎加載到內(nèi)存中。此時JSP引擎還請求了jspInit()方法的執(zhí)行,并對此Servlet初始化。JspInit()方法在Servlet的生命周期中只被請求一次,然
17、后將被調(diào)用來處理客戶端的請求和回復(fù)操作。對于所有隨后對該JSP文件的請求,服務(wù)器將檢查該JSP文件自最后一次被存取后是否經(jīng)過修改。如果沒有修改,則將請求交還給還在內(nèi)存中的Servlet的jspService()方法,執(zhí)行回復(fù)操作。由于Servlet始終駐于內(nèi)存,所以響應(yīng)是非??斓?。Jsp頁面在第一次訪問時由于要轉(zhuǎn)化和編譯,運行速度較慢,但是當(dāng)?shù)诙卧L問該頁時,由于文件已經(jīng)被編譯成字節(jié)碼文件了,所以速度非常得快。</p>&
18、lt;p> 1.2.2 JSP頁面的組成</p><p> JSP頁面看上去像標(biāo)準(zhǔn)的HTML和XML頁面,并附帶有JSP引擎能夠處理和解析執(zhí)行的代碼與組件。通常,JSP代碼和組件用于創(chuàng)建在最終頁面上顯示的文本。通常來說,JSP頁面包括編譯指令,動作指令,聲明,表達式和程序段等內(nèi)容。</p><p> 1)編譯指令:使用JSP編譯指令(〈%@ 和 %〉內(nèi)的)來指定所使用的腳本語
19、言,Servlet實現(xiàn)的接口,Servlet擴展的類,Servlet導(dǎo)入的軟件包。JSP指令的一般語法形式為:<%@ 指令名=“值”%>。</p><p> 2)動作指令(標(biāo)識):動作指令用于執(zhí)行某些動作。在JSP規(guī)范中有2種類型的動作指令的標(biāo)識。第一種是標(biāo)準(zhǔn)動作,它定義的是無論在什么版本的JSP引擎或Web服務(wù)器下總是可用的動作。第二種是自定義動作,它通過使用taglib指令來實現(xiàn)。例如JSP:u
20、seBean;JSP:setProperty;JSP:getProperty就是標(biāo)準(zhǔn)動作。</p><p> 3)聲明:用于聲明合法的變量和方法。與任何語言相同,JSP語言使用變量來保存數(shù)據(jù)。這些變量用declaration元素聲明,聲明的語法為<%! declaration(s) %>。當(dāng)頁面被初始化的時候,JSP頁面中的所有聲明都被初始化。除了簡單的變量,方法也能被聲明。聲明不對當(dāng)前的輸出流產(chǎn)生
21、任何影響。</p><p> 4)表達式:通過計算表達式所得到的結(jié)果來表示某個值。表達式的形式為:<%=expression>。表達式求值的結(jié)果被強制轉(zhuǎn)換為一個字符串,并插入到當(dāng)前的輸出流中。</p><p> 5)程序段:JSP可以在頁面中包含的一段程序,稱之為程序段。程序段是一個代碼片斷,在請求的處理過程中被執(zhí)行。程序段可以和頁面中的靜態(tài)元件組合起來創(chuàng)建動態(tài)生成的頁面。
22、程序段在“<% %>”中定義,在這對標(biāo)識中的所有東西都會被當(dāng)成JSP程序執(zhí)行。</p><p> 1.2.3 JavaBean技術(shù)介紹</p><p> JavaBean技術(shù)是一種基于Java的組件技術(shù),JavaBean組件可以用來執(zhí)行復(fù)雜的計算任務(wù),或負責(zé)與數(shù)據(jù)庫的交互以及數(shù)據(jù)的提取等,是解決代碼重用問題的一種策略。</p><p> 以前的組
23、件無法實現(xiàn)真正的代碼重用,其主要原因就是它們對于處理平臺的依賴和對開發(fā)語言的依賴過重。由于Java語言在這些方面所具有的特點和優(yōu)勢,使得基于它的軟件JavaBean組件技術(shù)倍受人們的關(guān)注。它的任務(wù)就是:一次編寫,可以在任何地方執(zhí)行,</p><p> 可以在任何地方重用。JavaBean組件可以在任何地方?jīng)_用包括了可以在應(yīng)用程序、其他組件、文檔、Web站點和應(yīng)用程序構(gòu)造器工具等多種方案中再利用。</p&g
24、t;<p> 為了創(chuàng)建和使用Java軟件組件,JavaBean被實現(xiàn)為一種獨立于平臺和結(jié)構(gòu)的應(yīng)用程序接口,它的實現(xiàn)可以忽略內(nèi)部的結(jié)構(gòu)及細節(jié)問題,只需要定義其外部的特征及對外功能就行。其中,屬性、方法和事件三種接口可以獨立對外進行開發(fā)。</p><p> JavaBean的實質(zhì)就是一個.class文件,也可以成為類文件。JavaBean以binary格式保存,可以保護Java源代碼不容易被他人抄襲
25、。</p><p> 1.2.4 JSP的運行環(huán)境</p><p> 要運行Jsp(注意,不是瀏覽Jsp頁面),需要有支持Jsp的服務(wù)器。這里分2種情況:一種是自身就支持Jsp的服務(wù)器,如Jrun,Weblogic,JSWDK等;而另一種則是在不支持Jsp的服務(wù)器上安裝Jsp引擎的插件,如在IIS,Apache等服務(wù)器上安裝WebSphere,tomcat,Resin等插件。其中主流服
26、務(wù)器是Weblogic和tomcat.</p><p> Weblogic是一款功能強大的服務(wù)器軟件,配置比較簡單,而且Jsp的擴展功能較多,附帶了數(shù)據(jù)庫的JDBC驅(qū)動程序。,支持JHTML(一種與Jsp十分相似的技術(shù)),是目前市場占有率最高的服務(wù)器。不過,Weblogic的運行情況不太穩(wěn)定,使用它調(diào)試Jsp文件,出現(xiàn)語法錯誤或者數(shù)據(jù)庫連接錯誤時,Weblogic就有可能崩潰。</p><p
27、> Tomcat服務(wù)器是Apache Group Jakarta小組開發(fā)的一個免費服務(wù)器軟件,適合于嵌入Apache中使用,而且,它的源代碼可以免費獲得,你可以自由地對它進行擴充。訪問的地址 http://jakarta. apache.org/tomacat/index.html, Tomcat服務(wù)器的兼容性很好,如WebLogic服務(wù)器采用其為Web服務(wù)器引擎,Jbuilder將其作為標(biāo)準(zhǔn)的測試服務(wù)器,Sun公司也將其作為J
28、SP技術(shù)應(yīng)用的示例服務(wù)器。不足之處是它的配置比較麻煩,而且有一些安全性的問題沒有解決。但是Tomcat服務(wù)器有眾多大軟件公司的支持,而且服務(wù)器的性能穩(wěn)定,其發(fā)展前景很好。</p><p> 1.3 系統(tǒng)開發(fā)環(huán)境</p><p> 1.3.1 服務(wù)器的配置</p><p> 前面介紹了JSP的生命周期,為了說明JSP對運行環(huán)境的要求,先簡單的介紹一下它的運作過
29、程。服務(wù)器在接收到客戶端傳過來的一個頁面請求時,先判斷是否是JSP頁面請求(從擴展名來判斷),如果不是,只是一般的HTML頁面請求,則直接把HTML文檔傳給客戶端,完成客戶端與服務(wù)器的一次連接。如果判斷是JSP頁面請求,則由JSP引擎(或Servlet引擎)將JSP頁面代碼轉(zhuǎn)換成Servlet代碼,再通知服務(wù)器上的JVM(Java虛擬機)對轉(zhuǎn)換過來的Servlet代碼進行編譯,將生成的字節(jié)碼文件放在服務(wù)器上相應(yīng)的地方,并執(zhí)行編譯后得到的
30、字節(jié)碼,然后把結(jié)果傳送給客戶端,這樣就完成一次連接。以后如果有相同的JSP頁面的請求,則直接由JSP引擎通知JVM執(zhí)行已有的字節(jié)碼,并把結(jié)果傳送給客戶端。</p><p> 從上面JSP運作全過程可見,運行JSP最少需要三樣?xùn)|西:JSP引擎、Web服務(wù)器和JVM。最常用的Java開發(fā)工具就是JDK和Jbuilder,它們之間的很大不同就是JDK是字符界面,而Jbuilder是窗口界面。本系統(tǒng)直接采用JDK作為J
31、VM和java編譯器。所用的操作系統(tǒng)是Windows2000,服務(wù)器采用的是tomcat,利用了它充當(dāng)Jsp引擎,同時還利用了它的信息發(fā)布功能。首先把JDK,tomcat安裝到本地硬盤D盤根目錄下,下面詳細的介紹如何配置運行環(huán)境:</p><p><b> 配置環(huán)境變量</b></p><p> 第一步:進入我的桌面,右擊“我的電腦”,選擇“屬性”選項,進入“系統(tǒng)
32、屬性“對話框,單擊”高級標(biāo)簽“,如圖1-2所示:</p><p><b> 圖1-2</b></p><p> 第二步:點擊上圖箭頭所示“環(huán)境變量”,進入圖1-3畫面。</p><p><b> 圖1-3</b></p><p> 第三步:單擊 “系統(tǒng)變量”部分的 “新建按扭”,創(chuàng)建JAVA
33、-HOME變量,在變量值欄內(nèi)輸入C:\jdk1.4.2_05; 如圖1-4所示:JAVA_HOME指明JDK安裝路徑,就是剛才安裝時所選擇的路徑C:\jdk1.4.2_05,此路徑下包括lib,bin,jre等文件夾(此變量最好設(shè)置,因為以后運行tomcat,eclipse等都需要依靠此變量)</p><p><b> 圖1-4</b></p><p> 第四步:
34、同樣的方法創(chuàng)建CLASSPATH 變量,在變量欄內(nèi)輸入,.;%JAVA_HOME%\lib;</p><p> %JAVA_HOME%\lib\tools.jar (要加.表示當(dāng)前路徑)CLASSPATH為java加載類(class or lib)路徑,只有類在classpath中,java命令才能識別。</p><p> 第五步:創(chuàng)建PATH變量,在變量欄內(nèi)輸入,%JAVA_HOME
35、%\bin;%JAVA_HOME%\jre\bin</p><p> Path使得系統(tǒng)可以在任何路徑下識別java命令。</p><p> 第六步:創(chuàng)建Tomcat-Home變量,在變量欄內(nèi)輸入</p><p> C:\Tomcat5.0; 如圖1-5所示:</p><p><b> 圖1-5</b></p
36、><p> 第七步:檢測配置是否成功:</p><p> 檢測JDK是否配置成功</p><p> 編寫一個java程序,例如:</p><p> public class HelloWorldApp</p><p><b> {</b></p><p> publ
37、ic static void main(String args[])</p><p><b> {</b></p><p> System.out.println(“HelloWorld!”);</p><p><b> }</b></p><p><b> }</b>
38、</p><p> 首先把它放到一個名為HelloWorldApp.java的文件中,這里,文件名應(yīng)和類名相同,因為java解釋器要求公共類必須放在與其同名的文件中。然后對它進行編譯:</p><p> c:\>javac –g HelloWorldApp.java</p><p> 編譯的結(jié)果是生成字節(jié)碼文件HelloWorldApp.class。最后
39、用java解釋器來運行該字節(jié)碼文件:</p><p> c:\>java HelloWorldApp</p><p> 結(jié)果是在屏幕上顯示“Hello World!”</p><p> 至此,JDK完全安裝成功。</p><p> 檢測tomcat是否配置成功</p><p> 進入C:\Tomcat
40、5.0\bin目錄,雙擊startup.bat執(zhí)行文件啟動Tomcat服務(wù)器,成功啟動后的界面如圖1-6所示:</p><p> 我們現(xiàn)在就可以通過瀏覽器看Tomcat服務(wù)器的示例程序了,打開瀏覽器,鍵入http://localhost:8080/index.jsp進入Tomcat服務(wù)器的主頁面。 </p><p><b> 圖1-6</b>
41、;</p><p> 1.3.2 數(shù)據(jù)庫后臺環(huán)境的配置</p><p> SQSQL Server是由Microsoft開發(fā)和推廣的關(guān)系數(shù)據(jù)庫管理系統(tǒng)(DBMS),它最初是由Microsoft、Sybase和Ashton-Tate三家公司共同開發(fā)的,并于1988年推出了第一個OS/2版本。 SQL Server近年來不斷更新版本,1996年,Microsoft 推出了SQL Serve
42、r 6.5版本;1998年,SQL Server 7.0版本和用戶見面;SQL Server 2000是Microsoft公司于2000年推出的最新版本。</p><p> JSP與SQL Server數(shù)據(jù)庫的連接</p><p> 本系統(tǒng)使用ODBC驅(qū)動程序建立SQL Server的數(shù)據(jù)連接。創(chuàng)建步驟如下:</p><p> (1)選擇任務(wù)欄的 “
43、開始” “控制面板” “性能與維護” “管理工具” 雙擊ODBC數(shù)據(jù)源 單擊系統(tǒng)DSN標(biāo)簽,單擊“添加”選擇SQL Server的ODBC數(shù)據(jù)源,如圖1-7所示: </p><p><b> 圖1-7</b></p>&
44、lt;p> 定義ODBC數(shù)據(jù)源的名字和SQL Server所在的服務(wù)器,如圖1-8所示:</p><p><b> 圖1-8</b></p><p> 定義連接數(shù)據(jù)庫的方式,使用Windows的驗證連接數(shù)據(jù)庫。</p><p> 選擇要連接的數(shù)據(jù)庫,如圖1-9所示:</p><p> 其于各項保留默認值,
45、最后單擊“完成”進入數(shù)據(jù)源的測試窗口,測試成功后顯示如圖1-10,這樣就完成了本系統(tǒng)數(shù)據(jù)庫的ODBC數(shù)據(jù)源的創(chuàng)建。</p><p><b> 圖1-9</b></p><p><b> 圖1-10</b></p><p><b> 建立數(shù)據(jù)庫</b></p><p>
46、選擇任務(wù)欄的 “開始” “所有程序” “Microsoft SQL Server” </p><p> “企業(yè)管理器”,然后右擊數(shù)據(jù)庫選 “新建數(shù)據(jù)庫”,如圖1-11,在彈出的對話框中輸入數(shù)據(jù)庫名,完成后回到圖1-11的界面,單擊 “數(shù)據(jù)庫”,選擇你剛剛建立的數(shù)據(jù)庫cart,右擊選擇新建表選項,這樣就可以創(chuàng)建自己的數(shù)據(jù)表了,通過建好的數(shù)據(jù)表就組成了數(shù)據(jù)庫。</p><
47、;p><b> 圖1-11</b></p><p><b> 第二章 需求分析</b></p><p><b> 2.1 系統(tǒng)說明</b></p><p> 本系統(tǒng)是一個中小型的電子商務(wù)系統(tǒng)----網(wǎng)上書店,可以為各類用戶提供方便的在線買書環(huán)境,符合目前國內(nèi)流行的電子商務(wù)模式。用戶可
48、以在系統(tǒng)中實現(xiàn)注冊、瀏覽商品、搜索查詢商品、下定單、處理定單等功能;管理員可以通過用戶管理、定單管理、商品管理、評論管理等管理功能來對系統(tǒng)進行維護更新。</p><p> 網(wǎng)站的組成有以下幾個子系統(tǒng)組成:</p><p> 1. 主頁,顯示歡迎界面,提供近期的書本。</p><p> 2. 購物車,處理訂購并顯示想要訂購的書本。</p><
49、p> 3. 查詢系統(tǒng),通過書本編號、書本名稱來查詢是否有自己需要的書本。</p><p> 4. 用戶注冊系統(tǒng),處理新用戶的注冊和老用戶買書時的確認。</p><p> 2.2 系統(tǒng)功能簡介</p><p> 2.2.1 基本功能</p><p><b> 游客可以瀏覽網(wǎng)站</b></p>
50、<p><b> 用戶登陸</b></p><p><b> 用戶能夠瀏覽網(wǎng)站</b></p><p> 提供搜索引擎,使用戶能夠按特定的條件對所需商品進行搜索</p><p><b> 用戶下定單購買商品</b></p><p><b> 用戶
51、處理定單</b></p><p> 2.2.2 用戶界面設(shè)計</p><p> 2.3 系統(tǒng)運行環(huán)境</p><p> 操作系統(tǒng):Windows 9X、Windows NT Workstation/Server 4.0以上、Windows 2000 Server/Professional、Windows XP Professional。</
52、p><p> CPU:沒有很高的要求,只要能夠順利運行Windows系列操作系統(tǒng)就可以了。當(dāng)然,CPU的處理速度越快,運行JSP代碼的效率越高。</p><p> 內(nèi)存:最低配置32MB,建議使用64MB以上內(nèi)存,如果使用Windows 2000或Windows XP建議使用128MB以上內(nèi)存。</p><p> 硬盤空間:至少需要50MB以上的硬盤空間來安裝所需
53、的組件。</p><p> 運行JSP的服務(wù)器端要求:(如表2.1所示)</p><p><b> 表2.1</b></p><p><b> 第三章 系統(tǒng)設(shè)計</b></p><p> 3.1 系統(tǒng)設(shè)計思想</p><p> 本系統(tǒng)采用三層架構(gòu)設(shè)計,它的工作原
54、理如圖3-1所示。</p><p><b> 圖3-1</b></p><p> 采用三層構(gòu)架以后,用戶界面層通過統(tǒng)一的接口向業(yè)務(wù)層發(fā)送請求,業(yè)務(wù)層按自己的邏輯規(guī)則將請求處理之后進行數(shù)據(jù)庫操作,然后將數(shù)據(jù)庫返回的數(shù)據(jù)封裝成類的形式返回給用戶界面層。這樣用戶界面層甚至可以不知道數(shù)據(jù)庫的結(jié)構(gòu),它只要維護與業(yè)務(wù)層之間的接口即可。</p><p>
55、 3.2 系統(tǒng)功能模塊化</p><p> 如圖3-2為本系統(tǒng)的功能模塊圖。</p><p><b> 圖3-2</b></p><p><b> 3.3系統(tǒng)功能劃分</b></p><p> 根據(jù)需求分析與系統(tǒng)功能設(shè)計目標(biāo),結(jié)合實際情況本系統(tǒng)功能模塊設(shè)計分為如下幾個模塊:</p&
56、gt;<p> 1.主頁:在這里我們可以看見本系統(tǒng)的主要功能和信息。</p><p> 2.用戶注冊:在這里用戶可以注冊基本信息,其中登陸帳戶和密碼是比較重要的,因為我們需要對這些信息進行處理,以方便用戶的購書。</p><p> 3.用戶登陸:用戶輸入正確的口令才能登陸成功否則提示錯誤。</p><p> 4.書目瀏覽:成功登陸后的用戶可以瀏
57、覽圖書書目,并將想要的圖書提交到填寫訂單頁面。如果用戶還沒有注冊就直接進入或者沒有成功登陸就進入頁面,將被連接到“提示用戶登錄頁面”。</p><p> 5.訂購圖書:成功登陸的用戶可以在該頁面定購所需要的圖書。如果用戶還沒有注冊就直接進入或者沒有成功登陸就進入頁面,將被連接到“提示用戶登陸頁面”。</p><p> 6.查看訂單:成功登陸的用戶可以在該頁查詢已經(jīng)訂購的圖書。再此還可以
58、修改個人信息,查看個人信息,如果用戶還沒有注冊就直接進入或者沒有成功登陸就進入頁面,將被連接到“提示用戶登陸頁面”。</p><p> 7.書目查詢:成功登陸的用戶可以在該頁查找自己需要的圖書。如果用戶還沒有注冊就直接進入或者沒有成功登陸就進入頁面,將被連接到“提示用戶登陸頁面”。</p><p> 8.圖書管理:管理員對圖書信息進行添加,修改,刪除操作。</p><
59、;p> 9.訂單管理:查看用戶訂單,訂單執(zhí)行操作,主頁顯示用戶訂單執(zhí)行情況。</p><p> 10.用戶管理:查看用戶基本信息,用戶凍結(jié)、解凍操作。</p><p> 11.公告管理:更新公告信息。</p><p> 4.4系統(tǒng)模塊結(jié)構(gòu)圖</p><p> 圖4.1 系統(tǒng)結(jié)構(gòu)模塊</p><p>
60、圖4.2 用戶模塊圖</p><p> 5.2系統(tǒng)主要界面和功能模塊設(shè)計</p><p> 1 .主頁面模塊 </p><p> 主頁面中上部包含:①標(biāo)題:歡迎光臨網(wǎng)上書店</p><p> ?、诖丝淘L問的時間和訪問本站的人數(shù)等部分。</p><p><b> 圖5.1 主頁面</b>&
61、lt;/p><p><b> 2.用戶登錄模塊 </b></p><p> ?、儆脩舻卿洶ǎ旱卿浢Q,輸入密碼。</p><p> ?、诋?dāng)用戶登錄后由管理員核對該用戶的名稱和密碼是否正確,如果無誤的話用戶可以通過檢查直接進入網(wǎng)站的其它頁面進行瀏覽和訂購。</p><p><b> 圖5.2 登錄窗體</
62、b></p><p><b> 3.用戶注冊模塊 </b></p><p> 用戶注冊是為第一次登錄網(wǎng)站的用戶所設(shè)計的。在用戶成為本站用戶之前一定要注冊才可以訪問我網(wǎng)站的其它網(wǎng)頁。</p><p> ①用戶注冊包括:登錄名稱,真實姓名,設(shè)置密碼,電子郵件等。</p><p> ?、谧猿晒螅趴梢栽L問本站的
63、其他頁面。</p><p><b> 圖5.3 用戶注冊</b></p><p> 5.2.3圖書信息模塊設(shè)計</p><p> 主要實現(xiàn)了新書發(fā)布,圖書查詢,圖書分類,圖書瀏覽操作。</p><p> 1.新書發(fā)布主要實現(xiàn)的是顯示最新添加的圖書信息,查詢語句為select top 4 * from bookin
64、fo order by BOOK_DATE desc,將數(shù)據(jù)庫的圖書按添加時間降序排序查找出4條記錄顯示出來。圖書查詢主要實現(xiàn)了按書名模糊查詢,在主頁查詢欄中輸入書名(此處也應(yīng)用到了form表單操作),點擊查詢按鈕(圖書查詢也應(yīng)用到了check.jsp登錄判斷)將調(diào)用search.jsp進行查詢處理,查詢語句為SELECT * FROM bookinfo where TITLE like '%"+bookname+&q
65、uot;%',bookname為從提交表單里取出的用戶輸入的信息,在數(shù)據(jù)庫中查找符合的圖書信息,并顯示出來,并能購買圖書,添加進購物車。</p><p> 2.圖書分類(list.jsp)</p><p> 圖5.4 圖書分類查看</p><p> 3.圖書瀏覽(show.jsp)</p><p> 書目瀏覽:成功登陸后的用戶
66、可以分頁瀏覽圖書書目,并將想要的圖書提交到填寫訂單頁面。</p><p><b> 圖5.5 圖書瀏覽</b></p><p> 主要實現(xiàn)從數(shù)據(jù)庫中查詢所有圖書信息并顯示出來。由于數(shù)據(jù)量非常大,顯然將如此大量的數(shù)據(jù)顯示在一個頁面是不可能的也是效率非常低下的,這種情況下就需要采用分頁顯示技術(shù)將數(shù)據(jù)庫中符合條件的數(shù)據(jù)逐頁顯示在頁面,</p><p&
67、gt; 5.2.4購物車模塊設(shè)計</p><p> 購物車操作,充分利用了session對象,如果需要訂購某本書,單擊相應(yīng)的購買按鈕,就會打開show.jsp頁面,在該頁面顯示該圖書的詳細信息,用戶還可以設(shè)置要購買的數(shù)量,程序所接收的是從圖書分類或者瀏覽圖書頁面?zhèn)鬟f過來的ISBN號,然后以此ISBN在數(shù)據(jù)庫中查詢該書信息,并顯示出來,程序也用到了form表單操作,用來接受用戶輸入的購書數(shù)量。</p>
68、;<p><b> 1.購物車界面</b></p><p> 圖5.6 購物車界面</p><p> 2.查看訂單:成功登陸的用戶可以在該頁修改已經(jīng)訂購的圖書。</p><p><b> 圖5.7 訂單界面</b></p><p> 3.修改密碼:成功登陸的用戶可以在該頁修改
69、自己的密碼及信息。</p><p><b> 圖5.8 修改密碼</b></p><p> 4.訂單查詢:可以查詢已近購買的圖書具體信息。</p><p><b> 圖5.9 訂單查詢</b></p><p> 3.3 數(shù)據(jù)庫設(shè)計</p><p> 數(shù)據(jù)庫在一個信
70、息管理系統(tǒng)中占有非常重要的地位,數(shù)據(jù)庫結(jié)構(gòu)設(shè)計的好壞將直接對應(yīng)用系統(tǒng)的效率,以及實現(xiàn)的效果產(chǎn)生影響。合理的數(shù)據(jù)庫結(jié)構(gòu)設(shè)計可以提高數(shù)據(jù)存儲的效率,保證數(shù)據(jù)的完整和一致。</p><p> 3.3.1 數(shù)據(jù)庫需求分析</p><p> 針對一般在線書店的需求,得出如下需求信息。</p><p> 用戶分為游客和已注冊用戶。</p><p>
71、; 訂單分為單張詳細訂單和總訂單。</p><p> 一個用戶可以購買多本圖書。</p><p> 一個用戶對應(yīng)一張訂單。</p><p> 一個列表對應(yīng)多張訂單。</p><p> 針對本系統(tǒng)功能分析,總結(jié)出如下的需求信息。</p><p> 用戶,包括數(shù)據(jù)項:用戶ID、用戶名、密碼。</p>
72、<p> 圖書,包括數(shù)據(jù)項:圖書編號、圖書名、價格、圖書介紹。</p><p> 訂單列表,包括數(shù)據(jù)項:訂單編號、圖書編號、購書數(shù)量。</p><p> 訂單,包括數(shù)據(jù)項:訂單編號、用戶編號、下單時間。</p><p> 3.3.2 數(shù)據(jù)庫概念結(jié)構(gòu)</p><p> 從本系統(tǒng)中規(guī)劃出的實體有:用戶實體、圖書實體、訂單
73、實體、訂單列表實體。</p><p> 實體之間關(guān)系的E-R圖如圖3-3所示。</p><p> 1 N</p><p> M N</p><p><b> 1</b></p><p><b> L</b><
74、/p><p><b> N</b></p><p><b> 圖3-3</b></p><p> 用戶信息實體的E-R圖如圖3-4所示。</p><p> 圖書實體的E-R圖如圖3-5所示。</p><p> 訂單實體的E-R圖如圖3-6所示。</p>&
75、lt;p> 訂單列表實體的E-R圖如圖3-7所示。</p><p> 3.3.3 數(shù)據(jù)庫邏輯機構(gòu)設(shè)計</p><p> 在線書店數(shù)據(jù)庫中各個表的設(shè)計結(jié)果如下面的標(biāo)和所示。</p><p> 表3-8為圖書信息列表。</p><p><b> 表3-8</b></p><p>
76、表3-9為用戶信息列表。</p><p><b> 表3-9</b></p><p> 表3-10為訂單總表,記錄某個用戶的訂單信息。</p><p><b> 表3-10</b></p><p> 表3-11為訂單表,記錄但張訂單的具體信息。</p><p><
77、;b> 表3-11</b></p><p><b> 第四章 詳細設(shè)計</b></p><p><b> 4.1系統(tǒng)主要文件</b></p><p> 這個購書系統(tǒng)主要有2類文件,一類是Bean文件,我把它們統(tǒng)一放在了cart文件夾里,保存在jakarta-tomcat-5.0.27\commo
78、n\classes\cart下,(這是tomcat要求的默認存放Bean的路徑);另一類是jsp文件,保存在jakarta-tomcat-5.0.27\webapps\ROOT。(這是tomcat的默認工作環(huán)境)</p><p> Bean文件:CartManager.java,OrderEntity.java,OrderItemEntity.java</p><p> Product
79、Entity.java,UserEntity.java</p><p> Jsp文 件:cart.jsp</p><p> 4.2詳細代碼及說明</p><p> 4.2.1實現(xiàn)用戶實體的Bean</p><p> 1)用戶作為實體,我把他的id, 姓名,密碼作為其屬性在Bean里面做了定義,它們都是和數(shù)據(jù)庫里的user表相對應(yīng)的,
80、在這個Bean里封裝的方法也主要是對這個表進行操作.這個幾個屬性都被定義為類的私有成員,外界不可訪問</p><p> private String id;</p><p> private String userName;</p><p> private String userPassword;</p><p> 2)構(gòu)造函數(shù)里做
81、了2件事情,第一:尋找數(shù)據(jù)庫連接驅(qū)動;第二:對上面的3個私有成員初始化:</p><p> public static String sDBDriver = "sun.jdbc.odbc.JdbcOdbcDriver";</p><p> public static String sConnStr = "jdbc:odbc:cart";</
82、p><p> public static Connection conn = null;</p><p> public UserEntity(String id,String userName,String userPassword)</p><p><b> {</b></p><p><b> try
83、 </b></p><p><b> {</b></p><p> Class.forName(sDBDriver); </p><p> //采用Class.forName方法顯式加載一個驅(qū)動程序</p><p><b> }</b></p><p>
84、 catch(java.lang.ClassNotFoundException e) </p><p><b> {</b></p><p> System.err.println("UserEntity: " + e.getMessage());</p><p><b> }</b></p
85、><p> this.id=id;</p><p> this.userName=userName;</p><p> this.userPassword=userPassword;</p><p><b> }</b></p><p> 根據(jù)上面對變量sDBDriver ,sConnStr
86、的定義和初始化可以看出,我在連接數(shù)據(jù)庫的時候采用的是jdbc-odbc橋的方式,這種方式采用的驅(qū)動是JDK自帶的,不需要另外安裝。但是,為了與特定的數(shù)據(jù)庫連接,我們必須建立一個數(shù)據(jù)源:cart。給3個屬性賦值,我利用了this指針。</p><p> 3)這個類我封裝了2類方法:一是查找特定用戶名的所有記錄,代碼如下:</p><p> public static UserEntity
87、 queryUser(String userName) throws SQLException</p><p><b> {</b></p><p><b> try </b></p><p><b> {</b></p><p> Class.forName(sDBD
88、river); </p><p><b> }</b></p><p> catch(java.lang.ClassNotFoundException e) </p><p><b> {</b></p><p> System.err.println("UserEntity: &
89、quot; + e.getMessage());</p><p><b> }</b></p><p> //query from database</p><p> String sql="select id,user_name,user_password from user where user_name= ? "
90、;</p><p> ResultSet rs = null;</p><p><b> try </b></p><p><b> {</b></p><p> conn = DriverManager.getConnection(sConnStr); </p><p&
91、gt; PreparedStatement prepStmt = conn.prepareStatement(sql);</p><p> prepStmt.setString(1,userName);</p><p> rs = prepStmt.executeQuery();</p><p><b> } </b></p>
92、;<p> catch(SQLException ex) </p><p><b> { </b></p><p> System.err.println("OrderItemEntity executeQuery: " + ex.getMessage());</p><p><b> }&l
93、t;/b></p><p> UserEntity user=null;</p><p> if(rs.next())</p><p> user=new UserEntity(rs.getString(1),rs.getString(2),rs.getString(3));</p><p> return user;</
94、p><p><b> }</b></p><p> 這個函數(shù)有1個參數(shù),String userName,就是通過這個用戶名在user表里查詢相應(yīng)的用戶的。要查詢數(shù)據(jù)庫里user表,就必須先連接數(shù)據(jù)庫。連接數(shù)據(jù)庫第一步是加載驅(qū)動,之后就是進行連接。我采用DriverManager類的getConnection方法來建立與cart數(shù)據(jù)源的連接,連接成功后,返回一個Conn
95、ection類的對象conn.要查找特定用戶名的紀(jì)錄,其實就是對uesr進行查詢操作。PreparedStatement對象就是用于查詢語句的執(zhí)行,它是Statement的子類,與Statement不同的地方,PreparedStatement對象可以接受參數(shù),這里需要接受的參數(shù)是user_name,然后進行預(yù)編譯。在每一次執(zhí)行這個查詢,都可以給sql語句傳輸不同的user_name,這樣大大提高了靈活性。要想查詢后的結(jié)果最后顯示給用戶
96、,必須對ResultSet對象進行操作,即對rs進行操作。我在程序里是把該記錄賦給一個UserEntity對象。</p><p> 該類封裝的另一種方法是:用戶名和密碼的獲得。這個主要是為了方便后面驗證用戶合法性使用</p><p> public String getUserName()</p><p><b> {</b></p
97、><p> return userName;</p><p><b> }</b></p><p> public String getUserPassword()</p><p><b> {</b></p><p> return userPassword;<
98、/p><p><b> }</b></p><p> 4.3.2實現(xiàn)商品實體的Bean</p><p> 雖然我做的是一個購書系統(tǒng),但考慮到系統(tǒng)的可擴展性,我把書當(dāng)作一種商品來進行定義。同樣,參照數(shù)據(jù)庫里的product表,我給商品這個類定義了如下4個屬性,商品id,商品名稱,商品價格,商品note,其類型同樣是該類的私有屬性:</p&
99、gt;<p> private String id;</p><p> private String productName;</p><p> private String productPrice;</p><p> private String productNote;</p><p> 其構(gòu)造函數(shù)和用戶實體類基
100、本上一致,所以代碼及其說明我在這里就省略了。</p><p> 對商品的操作也主要是2類,一類是對特定商品的查詢,其原理和查詢用戶是一樣的,但是有一點小小的區(qū)別,即查詢商品可以使查詢所有的商品,或者是查詢特定id的商品,我通過以下代碼把這2種查詢合在了queryProduct這個函數(shù)里:</p><p> String sql="select id,product_name,
101、product_price,product_note from product ";</p><p> if(productId.compareTo("")!=0)</p><p> sql=sql+" where id = ? ";</p><p> Vector v=new Vector();</p&
102、gt;<p> ResultSet rs = null;</p><p> 其關(guān)于連接數(shù)據(jù)庫,查詢記錄的代碼和上面的大致雷同,所以在這里就省略了。</p><p> 顯示商品是分頁顯示的,其代碼如下:</p><p> while(rs.next())</p><p><b> {</b><
103、;/p><p><b> ++i;</b></p><p> if(i>pageCount*pageSize)</p><p><b> {</b></p><p> if(i<=(pageCount+1)*pageSize)</p><p> v.add(
104、new ProductEntity(rs.getString(1),rs.getString(2),rs.getString(3),rs.getString(4)));</p><p><b> else</b></p><p><b> break;</b></p><p><b> }</b>
105、;</p><p><b> }</b></p><p> 這一段代碼的主要功能是:每一頁最多顯示pageSize個商品,如果超過pageSize個,就分頁顯示。PageSize在后面將會定義,其值我設(shè)置為10。</p><p> 第二類方法是查詢商品的id,全稱,價格和note. 例如查找商品的ID:</p><p&
106、gt; public String getProductId()</p><p><b> {</b></p><p> return id;</p><p><b> }</b></p><p> 4.3.3 實現(xiàn)訂購單實體的Bean</p><p> 客
107、戶每次購買一種商品都會產(chǎn)生一次訂購單,它包括訂單號,所購買的書號,所購買這種書的數(shù)量,這些構(gòu)成了這個類的私有屬性:</p><p> private String id;</p><p> private String orderId;</p><p> private String productId;</p><p> priva
108、te String productNum;</p><p> 客戶每次選中一種商品后,點擊放入購物車,就會產(chǎn)生一個訂單,其實現(xiàn)代碼如下:</p><p> String sql="insert into order_item(order_id,product_id,product_num) values(?,?,?) ";</p><p>
109、 ResultSet rs = null;</p><p><b> try </b></p><p><b> {</b></p><p> conn = DriverManager.getConnection(sConnStr); </p><p> PreparedStatement
110、prepStmt = conn.prepareStatement(sql);</p><p> prepStmt.setString(1,orderId);</p><p> prepStmt.setString(2,productId);</p><p> prepStmt.setString(3,productNum);</p><p&
111、gt; prepStmt.executeUpdate();</p><p><b> }</b></p><p> 訂購單,書號,購買數(shù)量都是作為參數(shù)傳過來的。很明顯,新建一張訂購單其實就是在order_item表里插入一條新紀(jì)錄就可以了。其原理已經(jīng)在上面說過來了,就不在此重復(fù)了。</p><p> 2)在后面的購物車?yán)?,一名顧客的最終
112、消費總額就是根據(jù)這里一張張的訂購單得到的,所以查找特定訂單號的訂購單是這個類里面不可缺少的方法,它的算法實質(zhì)上就是條件查詢,和前面的無條件查詢相比,我只把sql語句作了改動:</p><p> String sql="select id,order_id,product_id,product_num from order_item where order_id= ? ";</p>
113、<p> 第3個被封裝的方法是設(shè)置,獲得訂購單號,書號,定購數(shù)量,并且還可以獲得session price.</p><p> 4.3.4 實現(xiàn)購物車實體的Bean</p><p> 在現(xiàn)實生活中,人們?nèi)コ匈I東西,都是把商品放在一個購物籃里,等到把所有要買的東西選購?fù)戤吅?,一起拿到收銀臺前付錢。我在程序里定義的購物車實體就是模擬這個功能.作為購物車,購物人,購物時間,
114、所購書的總價格都是必不可少的:</p><p> private String id;</p><p> private String userName;</p><p> private String orderDate;</p><p> private String orderPrice;</p><p>
115、; 我覺得在這個Bean里面主要要解決的一個問題,如何解決一個新的購物車。當(dāng)一個顧客買完書提交購物車后,我們必須插入一個新的購物車紀(jì)錄,這是由insertOrder()方法來實現(xiàn)的:其插入代碼如下:</p><p> conn = DriverManager.getConnection(sConnStr); </p><p> PreparedStatement prepStmt =
116、 conn.prepareStatement(sql);</p><p> String curDate=(java.util.Calendar.getInstance().getTime()).toString();</p><p> prepStmt.setString(1,userName);</p><p> prepStmt.setString(2,
117、curDate);</p><p> prepStmt.setString(3,orderPrice);</p><p> prepStmt.executeUpdate();</p><p> 這里,插入的原理和前面是相同的,但是有一個地方需要解釋:即購物時間字段,是采用的java.util.Calendar.getInstance().getTime(),這
118、是一個庫函數(shù),被封裝在java.util,在這個類定義的開頭,我把這個庫文件包含進來:</p><p> import java.util.*;</p><p> 這個方法返回的結(jié)果必須把轉(zhuǎn)化成String,否則后面插入數(shù)據(jù)庫時會出現(xiàn)類型不匹配的錯誤。toString()就是用來實現(xiàn)類型轉(zhuǎn)換的。</p><p> 為了方便后面對這個購物車進行操作,我在這個方法
119、里還獲得了該購物車的id:</p><p> String selectStatement ="select id " +"from orderlist where user_name=? order by id desc ";</p><p> PreparedStatement prepStmt = conn.prepareStatemen
120、t(selectStatement);</p><p> prepStmt.setString(1,userName);</p><p> ResultSet rs = prepStmt.executeQuery();</p><p> rs.next();</p><p> String result=rs.getString(1)
121、;</p><p> return result;</p><p> 在sql里,查詢特定用戶購物車的id號,并且按照降序排列。是因為,針對一個網(wǎng)上購書系統(tǒng),顧客可以多次在這里購書,那么在購物車表單里,針對一個顧客會有很多條他的購物紀(jì)錄,而在數(shù)據(jù)庫里,各條記錄的id是安裝時間先后順序逐漸遞增的,如果安裝降序排列,那么得到的第一條記錄則是最新插入的紀(jì)錄。result=rs.getStr
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- jsp網(wǎng)上書店系統(tǒng)畢業(yè)論文
- 畢業(yè)論文——jsp網(wǎng)上書店
- jsp網(wǎng)上書店——畢業(yè)論文
- 畢業(yè)論文——jsp網(wǎng)上書店
- 畢業(yè)論文——jsp網(wǎng)上書店
- 網(wǎng)上書店畢業(yè)論文---網(wǎng)上書店系統(tǒng)
- 基于jsp網(wǎng)上書店系統(tǒng)設(shè)計-畢業(yè)論文
- 畢業(yè)論文范文——jsp網(wǎng)上書店
- 基于jsp的網(wǎng)上書店畢業(yè)論文
- 基于jsp的網(wǎng)上書店畢業(yè)論文
- jsp網(wǎng)上書店——論文
- 網(wǎng)上書店系統(tǒng)畢業(yè)論文
- 網(wǎng)上書店系統(tǒng)畢業(yè)論文
- 畢業(yè)論文—網(wǎng)上書店系統(tǒng)
- 網(wǎng)上書店系統(tǒng)畢業(yè)論文
- 畢業(yè)論文---網(wǎng)上書店系統(tǒng)
- 網(wǎng)上書店系統(tǒng)畢業(yè)論文
- 網(wǎng)上書店系統(tǒng)_畢業(yè)論文
- 網(wǎng)上書店系統(tǒng)畢業(yè)論文--網(wǎng)上書店系統(tǒng)的設(shè)計與實現(xiàn)
- 網(wǎng)上書店畢業(yè)論文
評論
0/150
提交評論