javaweb課程設計說明書.doc
《javaweb課程設計說明書.doc》由會員分享,可在線閱讀,更多相關《javaweb課程設計說明書.doc(41頁珍藏版)》請在裝配圖網(wǎng)上搜索。
1、 長 沙 學 院 課程設計說明書 題目 Web應用程序設計 系(部) 數(shù)學與計算機科學系 專業(yè)(班級) 姓名 學號 指導教師 起止日期 2015.11.30~2015.12.11 課程設計任務書 課程名稱:Web應用程序課程設計 設計題目:網(wǎng)上商店前臺功能的設計與實現(xiàn) 已知技術參數(shù)和設計要求: 1. 問題描述(功能要求): (1) 分析設計一個網(wǎng)上商店的前臺功能部分。完成本系統(tǒng)的如下功能: l 用戶注冊和登陸 l 展示特定的某類商品:展示的方式有多種,可以按類別、按銷
2、售排行榜、按上架時間等,有層次的展示商品,提高用戶的購買興趣。對于某種商品,除顯示商品信息以外,還可以附加評論、推薦相關類型商品。 l 商品查詢:根據(jù)多種條件來查詢,比如商品名稱、價格、顏色等特征信息。能進行模糊匹配,包含關鍵字的商品都能查到。 l 購物車:只有注冊用戶才能購買。為用戶提供購物車,購物車內(nèi)同類商品的數(shù)量可以修改,也可以刪除購物車里已有的商品。購物車信息保存,便于下次購物時繼續(xù)選購商品。 2. 運行環(huán)境要求: 正確安裝、配置和運行Tomcat。 正確安裝、配置和運行MyEclipse。 正確安裝、配置和運行MySQL數(shù)據(jù)庫和JDBC驅(qū)動程序。 3. 技術
3、要求: 要求使用Java語言,利用面向?qū)ο蟮姆椒?、編程思想來完成系統(tǒng)的設計;在設計的過程中,建立清晰的類層次;在系統(tǒng)設計中要分析和定義各個類,每個類中要有各自的屬性和方法。寫出需求分析,UML設計圖,數(shù)據(jù)庫設計圖。 設計工作量: 40課時 工作計劃: 1.班級 13計科1、2班、13信息1、2班 2.課時及教室安排 4課時:相關知識介紹。機房內(nèi)多媒體教室 10課時:設計。普通教室。 24~26課時:上機、調(diào)試。計算機系機房 4~6課時:調(diào)試答辯。計算機系機房 長沙學院課程設計鑒定表 姓名 學號 3 專業(yè) 班級 設計題目 Web應用程序
4、課程設計 指導教師 指導教師意見: 評定等級: 教師簽名: 日期: 答辯小組意見: 評定等級: 答辯小組長簽名: 日期: 教研室意見: 教研室主任簽名: 日期: 系(部)意見: 系主任簽名: 日期: 說明 課程設計成績分“優(yōu)秀”、“良好”、“中等”、“及格”、“不及格”五類; 摘要 為了更好的鞏固和加強本學期所學的知識,
5、把所學的東西轉(zhuǎn)化為實際應用。我們學習了MyEclipse、Dreamweaver、Tomcat等應用程序的使用。并應用了SQL語言。對數(shù)據(jù)庫的創(chuàng)建、修改、刪除方法有了一定的了解。通過導入表和刪除表、更改表學會了對表的一些操作。為了建立一個好的合理的網(wǎng)上商店,我們必須經(jīng)過需求分析、數(shù)據(jù)邏輯分析、用戶接口類設計及界面布局的設計。最后編碼實現(xiàn),調(diào)試及系統(tǒng)維護的一般過程,為畢業(yè)設計打下基礎。 需求分析階段,建立UML用例圖,并給出復雜用例(如“展示商品”)的功能說明。數(shù)據(jù)邏輯分析階段,建立數(shù)據(jù)存儲結構,類圖,ER圖。用戶接口類設計階段,并建立實體類之間的關系,界面布局的設計階段,使用Dreamwea
6、ver應用程序進行設計,使用CSS、HTML語言進行實現(xiàn)。 通過網(wǎng)上書店的構造以及用戶的信息、購物車的信息、還有商品的相關信息制成表格,輸入到數(shù)據(jù)庫中,使之能夠進行查詢、修改、刪除、插入并且與網(wǎng)上商店執(zhí)行相同的操作。 關鍵詞:MyEclipse、Dreamweaver、SQL語言、數(shù)據(jù)存儲結構、UML用例圖、CSS、HTM 目錄 1 需求分析 1 1.1 UML用例圖 1 1.2 ER圖 3 2 程序設計 4 2.1 實體類 4 2.2 用戶接口類 5 2.2.1 登錄界面 5 2.2.2 注冊界面 6 2.2.3 主界面 7 2.2.
7、4 商品詳情頁面 8 2.2.5 購物車界面 9 3 編碼 10 3.1 程序流程圖 10 3.2 模塊列表 11 4 測試 11 4.1 用戶登錄 12 4.2 用戶注冊 14 4.3 用戶注銷 16 4.5 商品瀏覽 17 4.6 商品搜索 18 4.7 商品購買 20 4.8 從購物車中刪除 25 5 總結 26 參考文獻 27 附錄 28 附錄A 部分程序源代碼 28 1 需求分析 1.1 UML用例圖 圖1-1 用例圖 用例說明: 用例:商品查詢 參與者:游客或者用戶 說明: 1. 游客或者
8、用戶進入主頁,用例開始。 2. 游客或者用戶在搜索框輸入搜索關鍵字。 3. SearchServlet接收到關鍵字,調(diào)用SearchDAO的相關方法,找出與之相關的商品。 4. SearchServlet將SearchDAO獲得的商品信息保存到request中,并且轉(zhuǎn)發(fā)到jsp頁面。 5. Jsp將搜索到的商品顯示出來。 用例:查看購物車 參與者:游客或者用戶 說明: 1. 游客或用戶在主頁點擊商品進入商品詳情頁面。 2. 游客或者用戶在商品詳情點擊查看購物車圖標。 3. CartServlet判斷用戶是否已經(jīng)登錄,若用戶還沒有登錄,則提示用戶先去登錄。
9、 4. 用戶去登錄后,在Login這個Servlet中調(diào)用CartDAO中相應的代碼將數(shù)據(jù)庫cart表中該用戶對應的記錄,讀取出來存入session中。執(zhí)行步驟5。 5. 若用戶已經(jīng)登錄,則跳轉(zhuǎn)到cart.jsp將session中該用戶所有的購買信息讀取,并顯示出來。 用例:購買商品 參與者:用戶 說明: 1. 用戶在主頁點擊商品進入商品詳情頁面。 2. 游客或者用戶在商品詳情點擊加入購物車圖標。 3. CartServlet將購買記錄存入session中。同時,調(diào)用CartDAO的相關方法,將該記錄插入數(shù)據(jù)庫cart 表中。 4. 彈出窗口顯示購物信息。 5. 回
10、到商品詳情頁面,點擊查看購物車就可以查看相關的購物記錄。 1.2 ER圖 用戶(user) name id password statue 1 1 擁有 訂單項(orderitem) n id userid 訂單(order) userid
11、 1 n number statue 購物車項(cartitem) orderid id goodsid goodid 商品(goods) n number 1 statue 1 包含 name id catid 1 price image 屬于 關于
12、 1 商品(goods) descript 商品(goods) 商品(goods) 商品(goods) statue author n stock 1 goodid id id n statue statue 評價(discuss) name 1 商品種類(category) comment 圖1-2
13、 ER圖 2 程序設計 2.1 實體類 圖2-1 實體類圖 2.2 用戶接口類 2.2.1 登錄界面 圖2-2 登錄界面 關聯(lián)的實體類:user(用戶)類 2.2.2 注冊界面 圖2-3 注冊界面 關聯(lián)實體類:user(用戶)類 2.2.3 主界面 圖2-4 主界面 關聯(lián)實體類:category(類別)類,goods(商品)類 2.2.4 商品詳情頁面 圖2-5 商品詳情界面 關聯(lián)的實體類:category(類別)類,goods(商品)類 ,goods(商品)類,discuss(評價)類
14、 2.2.5 購物車界面 圖2-6 購物車界面 關聯(lián)實體類:category(類別)類,goods(商品)類 ,cartitem(購物車項)類。 3 編碼 3.1 程序流程圖 首頁 入口 已登錄? 購物車頁 商品搜索 商品詳情頁 登錄 否 是 提交訂單 圖3-1 程序流程圖 3.2 模塊列表 功能模塊 功能說明 關聯(lián)模塊 商品展示 能夠?qū)母鱾€模塊轉(zhuǎn)發(fā)過來的商品列表進行分頁展示。 搜索模塊,分類模
15、塊 商品搜索 能夠根據(jù)輸入的關鍵字,搜索相關的商品轉(zhuǎn)發(fā)到商品展示模塊進行展示。 商品展示模塊 用戶登錄 能對輸入的用戶信息進行判斷,該用戶是否存在,從而決定是否登錄成功。登錄成功則跳轉(zhuǎn)到主界面。在該模塊還可已選擇跳轉(zhuǎn)到注冊界面進行注冊,或者跳轉(zhuǎn)到主界面繼續(xù)瀏覽商品。如果登陸成功可以將數(shù)據(jù)庫中的相對應的購物信息存入session中。 注冊模塊,商品展示模塊 用戶注冊 能夠注冊新用戶,可以登錄界面跳轉(zhuǎn)過來,也可以從主界面跳轉(zhuǎn)過來。 登錄模塊,商品展示模塊 用戶注銷 能夠結束當前的session,實現(xiàn)用戶注銷, 可以在主界面點擊注銷實現(xiàn)。 商品展示模塊 分類模塊 能夠根
16、據(jù)數(shù)據(jù)庫中不同的類別,生成相應的鏈接,當點擊不同的種類時,轉(zhuǎn)發(fā)不同的數(shù)據(jù)到商品展示頁面進行顯示,刷新該頁面。 商品展示模塊 購物車 能夠加入購物項購物車,從購物車中刪除購物項,能夠提交訂單,并把訂單信息,購物車信息存入數(shù)據(jù)庫??梢詮闹鹘缑孢M入該頁面,也能夠從商品詳情頁面進入該界面。 商品詳情模塊,商品展示模塊 商品詳情 能夠?qū)μ囟ǖ纳唐?,進行商品詳情的展示,以及可以查看當前商品的庫存。并且顯示最近瀏覽過的商品列表。 商品評價模塊,購物車模塊, 商品展示模塊 商品評論 和商品詳情在同一個頁面,能夠顯示當前商品的相關評價,能夠以當前用戶的名義對當前的商品進行評價。如果當前身份是
17、游客還沒有進行登錄。則再點擊提交評論時,提示還沒有登錄。 商品詳情模塊,登錄模塊 表3-1 模塊列表4 測試 4.1 用戶登錄 數(shù)據(jù)庫中的用戶信息 圖4-1 用戶信息圖 已有用戶登錄 測試數(shù)據(jù):用戶名:Alice 密碼:123 圖4-2 用戶登錄1 測試結果: 圖4-3 登錄成功 不存在的用戶登錄 測試數(shù)據(jù):用戶名:Alice 密碼:12 測試結果: 圖4-3 登錄失敗 4.2 用戶注冊 不重名用戶注冊 測試數(shù)據(jù):用戶名:what 密碼:123 確認密碼:123 圖4-
18、4 用戶注冊1 注冊結果:(跳轉(zhuǎn)到登錄頁面進行登錄) 圖4-5 注冊成功 重名用戶注冊 測試數(shù)據(jù):用戶名:what 密碼:12 確認密碼:12 圖4-6 用戶注冊2 注冊結果: 圖4-5 注冊成功 4.3 用戶注銷 注銷前: 圖4-6 注銷前 注銷后: 圖4-7 注銷后 4.5 商品瀏覽 圖4-8 商品瀏覽(文藝) 圖4-9 商品瀏覽2(科教) 4.6 商品搜索 測試數(shù)據(jù):不畏 圖4-10 商品搜索1 測試結果:
19、 圖4-11 商品搜索2 4.7 商品購買 測試數(shù)據(jù):庫存不足 圖4-11 商品購買1 圖4-12 商品購買2 圖4-12 商品購買3(查看購物車) 圖4-12 商品購買4(庫存不足) 測試數(shù)據(jù):庫存充足 圖4-13 商品購買5 圖4-14 商品購買6 圖4-15 商品購買7 圖4-16 商品購買8 4.8 從購物車中刪除
20、 圖4-17 刪除前 圖4-18 刪除后 5 總結 這次實訓我用了MyEclipse、Dreamweaver、Tomcat、Navicat等開發(fā)軟件,通過自己的努力和老師、同學的指導我完成了本次實訓。系統(tǒng)設計了用戶模塊,實現(xiàn)了用戶注冊、登錄,注銷一系列功能;系統(tǒng)設計了商品模塊實現(xiàn)了商品分類瀏覽、詳情展示、模糊搜索以及顯示商品評價和對特定商品進行評價、以及顯示最近瀏覽過的商品一系列功能;系統(tǒng)還設計了購物車模塊,實現(xiàn)了為每個用戶分配購物車、將商品加入購物車、將商品從購物車中刪除、查看購物車(重啟瀏覽器后查看上次加入購物車的商品)、提交訂單(當庫存不足時,提示用戶)。我覺得性能是還不錯
21、的。至少在自己測試過程中沒有出現(xiàn)異常,能夠達到預期的效果。 當然,系統(tǒng)也還存在一些不足的地方。在用戶模塊。用戶登錄時,我覺得可以設置一個30天免登陸的選項,這樣可以提高用戶體驗。用戶注冊時,讓用戶提供更加詳細的信息并且編寫js代碼對用戶輸入的信息做一些正確或錯誤的提示。在商品模塊。在進行模糊搜索時,可以設計不同的選項,例如,根據(jù)商品的價格進行模糊搜索等。在顯示最近瀏覽過的商品時也存在不足,沒有將瀏覽記錄存入數(shù)據(jù)庫導致關閉瀏覽器再次登錄的時候,無法看到上次的瀏覽記錄。在評價商品時,無法顯示對商品的全部評價而只能顯示最近兩條評價。在購物車頁面無法對購物項的數(shù)量進行修改,我覺得這是一個很大的不足之
22、處。 通過本次實訓,我掌握了簡單的動態(tài)網(wǎng)頁設計及制作基礎技術,通過對網(wǎng)上書店程序的編寫和對網(wǎng)頁的設計,熟悉掌握了設計和編寫網(wǎng)頁。尤其是在設計主頁時,我學會了iframe的使用。通過使用iframe我實現(xiàn)了在保持頁面框架不變的基礎上,實現(xiàn)對不同數(shù)據(jù)的加載,從而實現(xiàn)點擊不同分類顯示不同商品的效果。另外一個在頁面設計上的收獲就是,實現(xiàn)了對商品的分頁顯示。當然這并不僅僅是通過頁面布局實現(xiàn)的,也牽扯到了后臺的邏輯。商品分頁的實現(xiàn),很大程度的提高了用戶體驗,如果商品太多用戶不再需要拖動滾動條,而只要點擊鏈接就能看到后續(xù)的商品。不過,這次實訓最大的收獲是在后臺邏輯,在頁面的跳轉(zhuǎn),數(shù)據(jù)的傳遞。讓我感受最深的
23、就是在商品分類展示時,再點擊某一個書的種類時,我讓它跳轉(zhuǎn)到了一個servlet,servlet將該類的所有商品查找出來,轉(zhuǎn)發(fā)到一個頁面顯示出來。這里面有一個技巧就是利用target屬性設置顯示頁面的窗口,從而實現(xiàn)了在同一個頁面顯示不同分類的商品的效果。 在編寫商品評價時,也利用了這種技巧。例外,在算法上的收獲,就是在顯示最近瀏覽的商品是使用的一個算法,這個算法實現(xiàn)了一個刪選,實現(xiàn)了將相同的商品篩選掉。 這次實驗最大的一個收獲,就是體會到,前期的需求分析,數(shù)據(jù)庫設計,概要設計,頁面設計真的很重要。在編碼前,履清自己的思路。不要急于編碼,另外,在每編寫一段代碼后,檢驗代碼的正確性, 這樣可
24、以縮小出現(xiàn)錯誤時查找錯誤的范圍,提高編碼的效率。一定要養(yǎng)成一個編寫注釋習慣。否則,會增加測試,維護的難度。我想這些經(jīng)驗都會成為我以后一筆寶貴的財富。 最后,我要感謝老師對我課程設計的指導,使我能夠順利完成這次課程設計的內(nèi)容,以及在這期間無私幫助過我的同學。從他們身上,我學到了專業(yè)、先進的開發(fā)技術,使我的軟件開發(fā)水平有了提高。同時,他們開闊的視野,嚴謹?shù)膽B(tài)度深深地影響了我。這對于我的將來,無論在學習上,還是工作中,都是一筆寶貴的財富。 參考文獻 [1] 趙俊峰. Java Web應用開發(fā)案例教程. 北京:清華大學出版社,2012. [2] 白靈. . Java Web應用開發(fā)給力起飛.
25、 北京:電子工業(yè)出版社, 2011. 附錄 附錄A 部分程序源代碼 Main.jsp <%@ page language="java" import="java.util.*" contentType="text/html; charset=utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPor
26、t()+path+"/"; %>
31、curuser.username:"游客"},歡迎來到書房齋!
35、ava.util.ArrayList; import java.util.List; import javabean.Category; import javabean.Goods; import javabean.Page; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; im
36、port javax.servlet.http.HttpSession; import service.PageService; import dao.GoodsDAO; public class GoodsServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setCharacterEncoding("utf
37、-8"); String method = request.getParameter("method"); // 根據(jù)選擇的分類來顯示商品 if (method.equals("findByCategory")) { int cid = Integer.parseInt(request.getParameter("cid")); String pagenum = request.getParameter("pagenum"); Page page = PageService.findPageRecords(pagenum, cid);
38、 page.setUrl("/servlet/GoodsServlet?method=findByCategory&cid=" + cid); request.getSession().setAttribute("page", page); request.getSession().setAttribute("goodslist", page.getRecords()); // 判斷請求的來源,如果來自于導航欄轉(zhuǎn)發(fā)到導航欄,如果來自分頁則轉(zhuǎn)發(fā)到goodslist.jsp request.getRequestDispatcher(
39、"/jsp/goodslist.jsp").forward(request, response); } // 展示商品 if (method.equals("displayGoods")) { String pagenum = request.getParameter("pagenum"); Page page = PageService.findPageRecords(pagenum); page.setUrl("/servlet/GoodsServlet?method=displayGoods&flag=1");// 此處邏
40、輯差點沒發(fā)現(xiàn),細節(jié)寫法 request.getSession().setAttribute("goodslist", page.getRecords()); request.getSession().setAttribute("page", page); request.getRequestDispatcher("/jsp/goodslist.jsp").forward(request, response); } if (method.equals("search")) { request.setCharacterEncoding("ut
41、f-8"); String search = null; if (request.getParameter("flag") == null) { search = new String(request.getParameter("search")); HttpSession session = request.getSession(); session.setAttribute("search", search); System.out.println("goodservletsearch1:" + search); } else
42、 { HttpSession session = request.getSession(); search = (String) session.getAttribute("search"); System.out.println("goodservletsearch2:" + search); } if (search != null)// 防止傳入空字符串 { String pagenum = request.getParameter("pagenum"); Page page = PageService.get
43、SearchPage(pagenum, search); page.setUrl("/servlet/GoodsServlet?method=search&flag=1&search1=" + search);// 此處邏輯差點沒發(fā)現(xiàn),細節(jié)寫法 System.out.println("goodservletsearch2:" + page.getUrl()); request.getSession().setAttribute("goodslist", page.getRecords()); request.getSess
44、ion().setAttribute("page", page); request.getRequestDispatcher("/jsp/goodslist.jsp").forward( request, response); } else// 如果傳入空字符串則返回首頁 { request.setAttribute("errorinfo", "您還沒說要找什么呢!親~"); request.getRequestDispatcher("/jsp/error.jsp").forward(request, response); } } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } } 35
- 溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。