基于javabean的在線日常事務管理系統(tǒng)畢業(yè)設計_第1頁
已閱讀1頁,還剩40頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、<p>  基于JavaBean的在線日常事務管理系統(tǒng)</p><p>  [摘要] 隨著計算機技術的飛速發(fā)展,計算機技術在信息管理中的應用也越來越普及。人們可以脫離傳統(tǒng)的記事本,通訊錄,越來越多的靠計算機來幫助人們完成這些功能,非常的快捷方便。所以使用計算機來實現(xiàn)記事本,通訊錄以及類似的其他功能也是大勢所趨的。本系統(tǒng)是一個在線的日常事務管理系統(tǒng),采用J2EE,JavaBean,Jsp,MySql等技術

2、來實現(xiàn)。系統(tǒng)包括了記事本,通訊錄,資源的上傳下載,收藏夾這幾個主要功能,還有用戶登錄以及后臺管理的輔助功能,界面友好,操作簡單。本系統(tǒng)集成了這幾個日常常用的功能,幫助人們擺脫使用傳統(tǒng)記事本等帶來的麻煩,方便了人們的日常生活。</p><p>  [關鍵詞] J2EE MySql 管理系統(tǒng)</p><p>  Online Management System Of Daily Routine

3、 Based on JavaBean</p><p>  [Abstract] With the rapid development of computer technology, computer technology is becoming increasingly popular in information management applications. People can get rid of tr

4、aditional notepad and address book, rely on computers to help them accomplish these functions more and more, very quick and easy. So the use of computers to achieve notepad, address book and other features is the general

5、 trend. This system is an online management system of daily routine, using J2EE,JavaBean,Jsp,MySql an</p><p>  [Key words] J2EE MySql Management System </p><p><b>  目 錄</b></p>

6、;<p><b>  1 引言1</b></p><p>  1.1 項目開發(fā)背景和意義1</p><p>  1.2 論文研究的內容1</p><p>  2 系統(tǒng)解決方案2</p><p>  2.1 需求分析2</p><p>  2.1.1 功能需求2</p

7、><p>  2.1.2 系統(tǒng)實現(xiàn)過程分析2</p><p>  2.1.3 開發(fā)環(huán)境分析3</p><p>  2.2 技術簡介3</p><p>  2.2.1 Java Enterprise Edition簡介3</p><p>  2.2.2 JavaBean簡介4</p><p>

8、;  2.2.3 Jsp 簡介4</p><p>  3 系統(tǒng)總體設計6</p><p>  3.1 系統(tǒng)結構圖6</p><p>  3.2 系統(tǒng)模塊劃分6</p><p>  3.2.1 用戶注冊和登錄模塊6</p><p>  3.2.2通訊錄功能模塊6</p><p>  3

9、.2.3 記事本功能模塊7</p><p>  3.2.4 收藏夾功能模塊7</p><p>  3.2.5 存儲模塊7</p><p>  3.2.6 后臺管理模塊7</p><p><b>  4 數(shù)據(jù)庫設計8</b></p><p>  4.1 數(shù)據(jù)庫分析8</p>

10、<p>  4.2 數(shù)據(jù)庫概念結構設計8</p><p>  4.3 數(shù)據(jù)庫邏輯結構設計10</p><p>  5 系統(tǒng)詳細設計13</p><p>  5.1 用戶注冊和登錄模塊13</p><p>  5.1.1 登錄功能13</p><p>  5.1.2 注冊功能15</p>

11、;<p>  5.2 通訊錄功能模塊16</p><p>  5.2.1 添加聯(lián)系人16</p><p>  5.2.2 刪除聯(lián)系人17</p><p>  5.2.3 查詢聯(lián)系人18</p><p>  5.3 記事本功能模塊19</p><p>  5.3.1添加事件19</p>

12、;<p>  5.3.2 查詢事件19</p><p>  5.4 收藏夾功能模塊20</p><p>  5.4.1 添加收藏20</p><p>  5.4.2 修改收藏21</p><p>  5.5 存儲資源模塊22</p><p>  5.5.1 上傳文件22</p>

13、<p>  5.5.2 下載文件23</p><p>  5.5.3 刪除文件24</p><p>  5.6 后臺管理模塊24</p><p>  5.6.1 管理員登錄24</p><p>  5.6.2 刪除注冊用戶26</p><p>  5.6.3 修改管理員信息27</p&g

14、t;<p>  5.7 數(shù)據(jù)庫操作模塊28</p><p>  5.7.1 數(shù)據(jù)庫操作28</p><p>  5.7.2 分頁技術28</p><p>  6系統(tǒng)測試與維護30</p><p>  6.1系統(tǒng)測試30</p><p>  6.2系統(tǒng)維護32</p><p&

15、gt;<b>  7 結論33</b></p><p><b>  致 謝34</b></p><p><b>  參考文獻35</b></p><p><b>  1 引言</b></p><p>  1.1 項目開發(fā)背景和意義</p>

16、<p>  隨著時代的發(fā)展,科技也在不斷地改變和發(fā)展。作為21世紀的新人類,網(wǎng)絡已經(jīng)成為我們生活中不可或缺的一部分。越來越多的人依賴網(wǎng)絡,需要網(wǎng)絡的各種服務來為自己的生活提供便利。現(xiàn)在網(wǎng)絡上的各種服務和不同功能的網(wǎng)站也越來越多,發(fā)展也在日趨成熟。我們可以在網(wǎng)絡上購物,充話費,也可以利用網(wǎng)絡分享資源,可以在網(wǎng)絡上或者利用云來存儲我們的日常信息和資源。而且網(wǎng)絡可以讓我們更快的獲取資訊,能夠實時的觀測某些數(shù)據(jù)的變化,能夠隨時隨地

17、的實現(xiàn)某些需求,如查詢信息,查詢路況等。</p><p>  而隨著網(wǎng)絡的普及和這些功能的需求的增長,有很多不同的網(wǎng)站出現(xiàn),紛繁復雜。當我們想要使用它們來完善日常的生活和辦公時,可能需要登錄不同的網(wǎng)站和系統(tǒng),來滿足自己的各種不同的需求。而這個系統(tǒng)的開發(fā),就是為了方便人們的生活和工作,將一部分人們日常用的比較多的功能集合在一個系統(tǒng)平臺上,這樣,人們就能使用同一個賬戶,在同一個平臺上,實現(xiàn)不同的需求操作。</p

18、><p>  本系統(tǒng)主要集合的功能有四個,包括通訊錄,收藏夾,存儲資源,事件記錄。而且這幾個功能一般都是以客戶端單機版的形式出現(xiàn)。這幾個功能在生活中比較常用,而且,有時候,我們會遇到想要使用其中某個功能,但是由于沒有攜帶的原因而無法實現(xiàn)。而這個系統(tǒng)就是為了解決人們的這些麻煩而設計的。有了它,就可以隨時隨地的上網(wǎng)查看自己所需的信息,而且可以使用一個賬號,在同一個平臺上實現(xiàn)這些不同的功能,省去了不同賬號密碼的記憶混淆等麻

19、煩。這個系統(tǒng)可以更加方便我們的生活。</p><p>  1.2 論文研究的內容 </p><p>  要設計并實現(xiàn)這個系統(tǒng),主要要實現(xiàn)的內容如下:</p><p>  ·要能實現(xiàn)用戶的注冊和登錄,以及用戶信息的修改。</p><p>  ·要能支持對聯(lián)系人的添加,刪除,修改和查詢。</p><p>

20、;  ·要能支持對記事本中事件信息的添加,刪除,查詢等。</p><p>  ·要能查詢,添加,刪除用戶感興趣的網(wǎng)站url地址。</p><p>  ·要能支持用文件的上傳,下載和刪除的功能。</p><p>  ·要能實現(xiàn)管理員對后臺的管理,包括用戶信息的修改,刪除以及管理員信息的修改。</p><p&g

21、t;<b>  2 系統(tǒng)解決方案</b></p><p><b>  2.1 需求分析</b></p><p>  本系統(tǒng)需要用戶先注冊,若已有賬號,則需要登錄,然后就能進入主界面。在主界面中,用戶可以根據(jù)自己的需求選擇不同的模塊,不同模塊都有一個圖標,可以鏈接到不同模塊的主界面。而不同模塊中又有刪除,添加,查詢等不同功能,會通過鏈接以及數(shù)據(jù)提交

22、等轉到各自對應的頁面。</p><p>  2.1.1 功能需求</p><p>  下面就是本系統(tǒng)的具體功能需求:</p><p><b>  通訊錄模塊</b></p><p>  這個模塊主要實現(xiàn)的功能是保存用戶聯(lián)系人的姓名,電話,郵箱,地址等信息,并能夠查詢,刪除,修改聯(lián)系人的信息。</p><

23、;p><b>  記事本模塊</b></p><p>  這個模塊用來記錄用戶想要記住的日常事務,待辦事項,或者一些用戶感興趣的</p><p>  信息,同時能夠查詢,刪除,修改事件的信息。</p><p><b>  收藏夾模塊</b></p><p>  這個模塊主要實現(xiàn)保存用戶感興趣的

24、網(wǎng)頁的url地址,并能查詢,添加,刪除收</p><p><b>  藏的url地址。</b></p><p><b>  存儲資源模塊</b></p><p>  主要實現(xiàn)文件的上傳和下載,還有刪除功能,滿足用戶文件的共享。</p><p><b>  用戶注冊和登錄</b>

25、</p><p>  用戶可以注冊成為普通用戶,然后可以登錄系統(tǒng),使用系統(tǒng)的其他功能,并且可以修改用戶自己的密碼,郵箱等信息。</p><p><b>  后臺管理模塊</b></p><p>  管理員可以登錄系統(tǒng),對后臺進行管理,包括普通用戶信息的修改,刪除等,也可以進行管理員信息的修改。</p><p>  2.1

26、.2 系統(tǒng)實現(xiàn)過程分析</p><p>  首先根據(jù)系統(tǒng)功能分析設計出數(shù)據(jù)庫,以及數(shù)據(jù)庫中的各個數(shù)據(jù)表。在實現(xiàn)各個功能模塊時,采用先模塊化,后集成的方式。即對系統(tǒng)各個功能模塊分別獨立設計和調試,在創(chuàng)建系統(tǒng)主窗體時再將各個功能模塊通過主窗體的功能按鈕集成到一起,最后進行系統(tǒng)整體設計調試。</p><p>  在訪問數(shù)據(jù)庫時,采用公用數(shù)據(jù)模塊存放訪問數(shù)據(jù)庫需要的對象。該模塊在各功能模塊中被直接

27、調用,避免對數(shù)據(jù)庫的反復連接,并可減少代碼編寫,從而提高系統(tǒng)開發(fā)效率。</p><p>  2.1.3 開發(fā)環(huán)境分析</p><p>  開發(fā)環(huán)境:Windows 7</p><p><b>  開發(fā)工具:Java</b></p><p>  開發(fā)平臺:MyEclipse 8.6</p><p>

28、  數(shù)據(jù)庫管理系統(tǒng):Mysql</p><p>  運行環(huán)境:Windows 7</p><p><b>  2.2 技術簡介</b></p><p>  2.2.1 Java Enterprise Edition簡介</p><p>  Java企業(yè)版(Java Enterprise Edition),是Sun公司為企

29、業(yè)級應用推出的標準平臺[5]。核心是一組技術規(guī)范與指南,其中所包含的各類組件、服務架構及技術層次,均有共同的標準及規(guī)格,讓各種依循J2EE架構的不同平臺之間,存在良好的兼容性,解決過去企業(yè)后端使用的信息產(chǎn)品彼此之間無法兼容,企業(yè)內部或外部難以互通的窘境。</p><p>  J2EE為搭建具有可伸縮性、靈活性、易維護性的商務系統(tǒng)提供了良好的機制:</p><p>  (1) 保留現(xiàn)存的IT

30、資產(chǎn):</p><p>  J2EE架構可以充分利用用戶原有的投資,如一些公司使用的BEA Tuxedo、IBM CICS,IBM Encina,、Inprise VisiBroker 以及Netscape Application Server。這之所以成為可能是因為J2EE擁有廣泛的業(yè)界支持和一些重要的'企業(yè)計算'領域供應商的參與。每一個供應商都對現(xiàn)有的客戶提供了不用廢棄已有投資,進入可移植的J

31、2EE領域的升級途徑。由于基于J2EE平臺的產(chǎn)品幾乎能夠在任何操作系統(tǒng)和硬件配置上運行,現(xiàn)有的操作系統(tǒng)和硬件也能被保留使用。</p><p>  (2) 高效的開發(fā):</p><p>  J2EE允許公司把一些通用的、很繁瑣的服務端任務交給中間供應商去完成。這樣開發(fā)人員可以集中精力在如何創(chuàng)建商業(yè)邏輯上,相應地縮短了開發(fā)時間。</p><p>  (3) 支持異構環(huán)境

32、:</p><p>  J2EE能夠開發(fā)部署在異構環(huán)境中的可移植程序?;贘2EE的應用程序不依賴任何特定操作系統(tǒng)、中間件、硬件。因此設計合理的基于J2EE的程序只需開發(fā)一次就可部署到各種平臺。這在典型的異構企業(yè)計算環(huán)境中是十分關鍵的。J2EE標準也允許客戶訂購與J2EE兼容的第三方的現(xiàn)成的組件,把他們部署到異構環(huán)境中,節(jié)省了由自己制訂整個方案所需的費用。</p><p><b>

33、;  (4) 可伸縮性:</b></p><p>  企業(yè)必須要選擇一種服務器端平臺,這種平臺應能提供極佳的可伸縮性去滿足那些在他們系統(tǒng)上進行商業(yè)運作的大批新客戶。基于J2EE平臺的應用程序可被部署到各種操作系統(tǒng)上。例如可被部署到高端UNIX與大型機系統(tǒng),這種系統(tǒng)單機可支持64至256個處理器。(這是NT服務器所望塵莫及的)J2EE領域的供應商提供了更為廣泛的負載平衡策略。能消除系統(tǒng)中的瓶頸,允許多臺

34、服務器集成部署。這種部署可達數(shù)千個處理器,實現(xiàn)可高度伸縮的系統(tǒng),滿足未來商業(yè)應用的需要。</p><p>  (5) 穩(wěn)定的可用性:</p><p>  一個服務器端平臺必須能全天候運轉以滿足公司客戶、合作伙伴的需要。因為INTERNET是全球化的、無處不在的,即使在夜間按計劃停機也可能造成嚴重損失。若是意外停機,那會有災難性后果。J2EE部署到可靠的操作環(huán)境中,他們支持長期的可用性。一些

35、J2EE部署在WINDOWS環(huán)境中,客戶也可選擇魯棒性更好的操作系統(tǒng)如Sun Solaris、IBM OS/390。魯棒性最好的操作系統(tǒng)可達到99.999%的可用性或每年只需5分鐘停機時間。這是實時性很強商業(yè)系統(tǒng)理想的選擇。</p><p>  2.2.2 JavaBean簡介</p><p>  JavaBean 是一種JAVA語言寫成的可重用組件[1]。用戶可以使用JavaBean將功

36、能、處理、值、數(shù)據(jù)庫訪問和其他任何可以用java代碼創(chuàng)造的對象進行打包,并且其他的開發(fā)者可以通過內部的JSP頁面、Servlet、其他JavaBean、applet程序或者應用來使用這些對象。用戶可以認為JavaBean提供了一種隨時隨地的復制和粘貼的功能,而不用關心任何改變。</p><p>  JavaBean可分為兩種:一種是有用戶界面(UI,User Interface)的JavaBean;還有一種是沒有

37、用戶界面,主要負責處理事務(如數(shù)據(jù)運算,操縱數(shù)據(jù)庫)的JavaBean[13]。JSP通常訪問的是后一種JavaBean[2]。</p><p>  一個bean沒有必須繼承的特定的基類或接口??梢暬腷ean必須繼承的類是java.awt.Component,這樣它們才能添加到可視化容器中去,非可視化bean則不需要繼承這個類。有許多bean,無論是在應用程序構造器工具中,還是在最后創(chuàng)建好的應用程序中,都具有很

38、強的可視化特征,但這并非每個bean必須的特征。在使用Java編程時,并不是所有軟件模塊都需要轉換成bean。Bean比較適合于那些具有可視化操作和定制特性的軟件組件。</p><p>  2.2.3 Jsp 簡介</p><p>  JSP(Java Server Pages)是由Sun Microsystems公司倡導、許多公司參與一起建立的一種動態(tài)網(wǎng)頁技術標準[6]。JSP技術有點類

39、似ASP技術,它是在傳統(tǒng)的網(wǎng)頁HTML文件(*.htm,*.html)中插入Java程序段(Scriptlet)和JSP標記(tag),從而形成JSP文件(*.jsp)。 用JSP開發(fā)的Web應用是跨平臺的,既能在Linux下運行,也能在其他操作系統(tǒng)上運行[7]。</p><p>  全名為java server page,其根本是一個簡化的Servlet設計,他實現(xiàn)了Html語法中的java擴張(以 <%

40、, %>形式)。JSP與Servlet一樣,是在服務器端執(zhí)行的,通常返回給客戶端的就是一個HTML文本,因此客戶端只要有瀏覽器就能瀏覽。Web服務器在遇到訪問JSP網(wǎng)頁的請求時,首先執(zhí)行其中的程序段,然后將執(zhí)行結果連同JSP文件中的HTML代碼一起返回給客戶端。插入的Java程序段可以操作數(shù)據(jù)庫、重新定向網(wǎng)頁等,以實現(xiàn)建立動態(tài)網(wǎng)頁所需要的功能[4]。</p><p>  JSP技術使用Java編程語言編寫類

41、XML的tags和scriptlets,來封裝產(chǎn)生動態(tài)網(wǎng)頁的處理邏輯。網(wǎng)頁還能通過tags和scriptlets訪問存在于服務端的資源的應用邏輯。JSP將網(wǎng)頁邏輯與網(wǎng)頁設計的顯示分離,支持可重用的基于組件的設計,使基于Web的應用程序的開發(fā)變得迅速和容易[11]。 JSP(JavaServer Pages)是一種動態(tài)頁面技術,它的主要目的是將表示邏輯從Servlet中分離出來[9]。</p><p>  JSP頁

42、面由HTML代碼和嵌入其中的Java代碼所組成。服務器在頁面被客戶端請求以后對這些Java代碼進行處理,然后將生成的HTML頁面返回給客戶端的瀏覽器。Java Servlet是JSP的技術基礎,而且大型的Web應用程序的開發(fā)需要Java Servlet和JSP配合才能完成[8]。JSP具備了Java技術的簡單易用,完全的面向對象,具有平臺無關性且安全可靠,主要面向因特網(wǎng)的所有特點。</p><p><b&g

43、t;  3 系統(tǒng)總體設計</b></p><p><b>  3.1 系統(tǒng)結構圖</b></p><p>  系統(tǒng)包括了用戶登錄,管理員登錄,通訊錄,記事本,收藏夾,存儲資源這幾個模塊,它們相互之間會傳遞信息,實現(xiàn)整個系統(tǒng)的聯(lián)通。系統(tǒng)的結構如圖3-1所示:</p><p>  圖3-1 系統(tǒng)結構圖</p><p&

44、gt;  3.2 系統(tǒng)模塊劃分</p><p>  根據(jù)初期的設計思想和需求分析的結果,根據(jù)本平臺要達到的功能要求,本系統(tǒng)大致可以抽象為以下幾個模塊:</p><p>  3.2.1 用戶注冊和登錄模塊</p><p>  用戶注冊和登錄模塊是整個系統(tǒng)的開始,一輸入本系統(tǒng)的url地址就會進入用戶登錄的界面。如果沒有注冊,需要通過鏈接進入注冊頁面來進行注冊。注冊后的用

45、戶名和密碼等信息會存入數(shù)據(jù)庫。若是管理員,可以選擇管理員登錄來進行后臺的登錄。</p><p>  在用戶輸入密碼和用戶名時都不能為空,使用javascript來檢測是否為空,并給予提醒。然后系統(tǒng)會根據(jù)數(shù)據(jù)庫中查詢到的密碼與輸入密碼是否相等來判斷是否轉到主頁面,若是不相等則會彈出警告,希望用戶重新輸入。</p><p>  3.2.2通訊錄功能模塊</p><p>

46、  當用戶進入這個模塊相對應的頁面時,用戶可以按條件分類搜索聯(lián)系人,系統(tǒng)會使用分頁技術把相關的信息顯示在這個頁面。當用戶想要添加或刪除聯(lián)系人時,可以通過圖標文字的鏈接,到相應操作的頁面去。</p><p>  在添加頁面,有一個表單,用戶可以在這個表單中輸入聯(lián)系人信息,電話,姓名,地址,郵箱,分類等。然后提交表單,系統(tǒng)會將相關信息存入對應的數(shù)據(jù)庫表中。</p><p>  刪除操作時,會到

47、刪除頁面,詢問是否刪除,確定的話就會執(zhí)行SQL語句,將信息刪除。</p><p>  3.2.3 記事本功能模塊</p><p>  這個模塊類似于通訊錄模塊,主要是執(zhí)行事件的添加,刪除,修改,查詢等。也是由表單來把數(shù)據(jù)提交給保存頁面,在保存頁面中會使用SQL語句,把事件內容存入數(shù)據(jù)庫中,修改,刪除等都有對應的頁面,會執(zhí)行對應的SQL語句,來實現(xiàn)對應的功能。</p><

48、p>  3.2.4 收藏夾功能模塊</p><p>  這個模塊會將用戶感興趣的網(wǎng)站的url存儲的到數(shù)據(jù)庫中,用戶可以查詢,刪除之前保存的地址。</p><p>  3.2.5 存儲模塊</p><p>  這個模塊中,可以實現(xiàn)用戶對文件的上傳下載,刪除等功能。在用戶注冊時,系統(tǒng)會為每個用戶建立一個文件夾,當有文件上傳時,會上傳到那個相應的文件夾中,當要下載時

49、,則會下載到用戶要求的本地位置。用戶也可以通過相應頁面的操作刪除上傳的文件。</p><p>  3.2.6 后臺管理模塊</p><p>  管理員可以在用戶登錄頁面中選擇相應鏈接到管理員的登錄頁面。進入后臺后,可以查看,修改,刪除普通用戶的信息。管理員也可以通過修改頁面修改管理員的相關信息,這些操作都會使用不同的SQL語句來對相應的數(shù)據(jù)庫進行操作。</p><p&g

50、t;<b>  4 數(shù)據(jù)庫設計</b></p><p>  數(shù)據(jù)庫是項目中非常重要的一個組成,沒有好的數(shù)據(jù)庫設計以及數(shù)據(jù)庫的選用,那么一個系統(tǒng)將可能無法真正的投入測試和使用。</p><p><b>  4.1 數(shù)據(jù)庫分析</b></p><p>  本系統(tǒng)使用MySQL數(shù)據(jù)庫,它是一個開放源碼的關系數(shù)據(jù)庫管理系統(tǒng)[10]

51、,開發(fā)者為瑞典MySQL AB公司[12],現(xiàn)為Sun公司的一部分。2009年Oracle宣布收購Sun公司,因此MySQL可能成為Oracle旗下產(chǎn)品。由于使用的是windows7的平臺,而sqlserver在這個平臺上不易安裝,所以考慮使用mysql數(shù)據(jù)庫,能夠安裝并且使用方便。</p><p>  4.2 數(shù)據(jù)庫概念結構設計</p><p>  將需求分析得到的用戶需求抽象為信息結構

52、即概念模型的過程就是概念結構設計[3]。它是整個數(shù)據(jù)庫設計的關鍵。概念結構是各種數(shù)據(jù)模型的共同基礎,它比數(shù)據(jù)模型更獨立于機器、更抽象,從而更加穩(wěn)定。</p><p>  描述概念模型的有力工具是E-R模型,通過對系統(tǒng)數(shù)據(jù)庫的需求分析得知應建立“管理員信息表”、“用戶信息表”、“通訊錄表”、“收藏夾表”、“記事本表”。</p><p>  系統(tǒng)中管理員的實體圖如圖4-1所示:</p&g

53、t;<p>  圖4-1 管理員實體圖</p><p>  系統(tǒng)的普通用戶的實體圖如圖4-2所示:</p><p>  圖4-2 用戶實體圖</p><p>  系統(tǒng)的通訊錄實體圖如圖4-3所示:</p><p>  圖4-3 通訊錄實體圖</p><p>  系統(tǒng)的記事本實體圖如圖4-4所示:</

54、p><p>  圖4-4 記事本實體圖</p><p>  系統(tǒng)的收藏夾實體圖如圖4-5所示:</p><p>  圖4-5 收藏夾實體圖</p><p>  4.3 數(shù)據(jù)庫邏輯結構設計</p><p>  關系模型主要是其中的實體和實體間的聯(lián)系均是由單一的結構類型即關系(表)來表示的。</p><p&

55、gt;  數(shù)據(jù)庫中兩實體間1:n聯(lián)系轉換為一個與n端對應的關系模式合并的關系模式的方法是將聯(lián)系的屬性與1端的碼加入n端作為屬性,主碼為n端實體的主碼。</p><p>  圖轉換為關系數(shù)據(jù)模型所要解決的問題是如何將實體和實體間的聯(lián)系轉換成關系模式,如何確定這些關系模式的屬性和碼。</p><p>  管理員信息表(admin表)用來存儲管理員編號,管理員用戶名,管理員密碼等,如表4-1所示

56、:</p><p>  表4-1 admin表</p><p>  用戶信息表(users表)用來存儲用戶的編號,用戶名,用戶密碼,用戶郵件地址,用戶注冊日期和用戶的qq號,如表4-2所示:</p><p>  表4-2 users表</p><p>  通訊錄表(list表)用來存儲聯(lián)系人編號,用戶編號,聯(lián)系人地址,電話等信息,如表4-3所

57、示:</p><p>  表4-3 list表</p><p> ?。?)記事本表(note表)用來存儲事件的編號,用戶姓名,事件的標題和內容,以及填寫該事件的時間。如表4-4所示:</p><p>  表4-4 note表</p><p> ?。?)收藏夾表(fav表)用來存儲用戶姓名,收藏信息的標題和收藏的地址等信息,如表4-5所示:&l

58、t;/p><p>  表4-5 fav表</p><p><b>  5 系統(tǒng)詳細設計</b></p><p>  經(jīng)過前期的需求分析、總體設計、數(shù)據(jù)庫分析,已經(jīng)為詳細設計做好了準備。本章將使用圖和部分代碼來實現(xiàn)詳細設計。</p><p>  5.1 用戶注冊和登錄模塊</p><p>  5.1.

59、1 登錄功能</p><p>  用戶登錄頁面如圖5-1所示:</p><p>  圖5-1 用戶登錄頁面</p><p>  登錄功能就是要實現(xiàn)用戶輸入用戶名和密碼后可以登錄到主頁上,若是管理員,則點擊圖5-1中的“管理員登錄”鏈接到管理員登錄界面,若是注冊,則點擊注冊按鈕鏈接到注冊頁面。部分實現(xiàn)代碼和說明如下:</p><p>  //獲

60、取用戶提交的登錄名和密碼</p><p>  sqlstr="select password,id from users where username='"+username+"'";</p><p>  //調用conn.jsp頁面中引入的JavaBean對象iCanDb的doSelect()方法執(zhí)行查詢操作</p>

61、<p>  rs=iCanDb.doSelect(sqlstr);</p><p>  //將查詢得到的結果集中的密碼字段與用戶輸入的密碼進行匹配</p><p>  if(rs.next())</p><p><b>  {</b></p><p>  String pwd=rs.getString(&quo

62、t;password").trim();</p><p>  String userid=rs.getString("id").trim();</p><p><b>  }</b></p><p>  //登錄成功,則轉向index.jsp頁面</p><p>  登錄成功后會進入主頁面,

63、進入這個主頁面后用戶可以選擇自己想要的功能模塊,完成相應的需求。主頁面如圖5-2所示:</p><p>  圖5-2 系統(tǒng)主頁面</p><p>  在主頁面中主要是四個模塊功能的鏈接。分別鏈接到每個模塊的主頁面,左邊的菜單欄也可以鏈接到各個模塊。部分實現(xiàn)代碼如下:</p><p>  //讀取存儲在session中的登錄用戶id查詢出登錄用戶存儲在通訊簿中聯(lián)系人的

64、數(shù)目</p><p>  int notecount=0;</p><p>  sqlstr="select id from note where user='"+iCan+"'";</p><p>  rs=iCanDb.doSelect(sqlstr);</p><p>  if(r

65、s.next())</p><p><b>  {</b></p><p>  rs.last();</p><p>  notecount=rs.getRow();</p><p><b>  }</b></p><p>  //使用File類中的各個方法,判斷用戶空間中上

66、傳文件的個數(shù)</p><p>  int boxcount=0;</p><p>  long userBoxSize=0;</p><p>  String iCanroot=dirPath.replace('\\','/');</p><p>  File userBox=new File(iCanroot

67、+"box/"+iCan);</p><p>  File userBoxfile[]=userBox.listFiles();</p><p>  Boxcount=userBoxfile.length;</p><p>  5.1.2 注冊功能</p><p>  注冊頁面如圖5-3所示:</p><

68、;p>  圖5-3 用戶注冊頁面</p><p>  注冊功能要實現(xiàn)的是用戶輸入用戶名和密碼等信息,然后系統(tǒng)檢測用戶名是否已經(jīng)被注冊,若沒有,則將這些信息保存到users表中,創(chuàng)建出一個新的用戶。然后會轉回到登錄頁面登錄進入主頁面。部分實現(xiàn)代碼如下:</p><p>  //將用戶輸入的注冊信息存儲到數(shù)據(jù)庫中</p><p>  sqlstr="in

69、sert into users(id,username,password,email,qq,date) values("+iCan+"'"+username+"','"+password+"','"+email+"','"+qq+"','"+date+&qu

70、ot;')";</p><p>  iCanDb.doAdd(sqlstr);</p><p>  sqlstr="select id from users where username='"+username+"'"; </p><p>  保存注冊信息后要為新用戶創(chuàng)建文件夾,以便文件的上傳

71、和下載。</p><p>  rs=iCanDb.doSelect(sqlstr);</p><p>  rs.next();</p><p>  String id=rs.getString("id");</p><p>  //String dirPath="D:\\java實例\\OnlineManager

72、";</p><p>  String iCanroot=dirPath.replace('\\','/');</p><p>  File boxPath=new File(iCanroot+"box",username);</p><p>  boxPath.mkdir();</p>&

73、lt;p>  5.2 通訊錄功能模塊</p><p>  5.2.1 添加聯(lián)系人</p><p>  通訊錄的添加頁面如圖5-4所示:</p><p>  圖5-4 添加聯(lián)系人頁面</p><p>  這個頁面可以添加聯(lián)系人的姓名,電話,地址,郵箱等信息,使用表單傳給頁面的保存操作,執(zhí)行SQL語句,把這些信息存入數(shù)據(jù)庫中。部分代碼如下:

74、</p><p>  //如果提交的參數(shù)為save時,執(zhí)行數(shù)據(jù)庫插入操作</p><p>  sqlstr="insert into list([user],[sort],[name],[mobile],[home],[office],[email],[qq],[msn],[post],[address],[other]) values('"+iCan+&quo

75、t;','"+sort+"','"+name+"','"+mobile+"','"+home+"','"+office+"','"+email+"','"+qq+"','&

76、quot;+msn+"','"+post+"','"+address+"','"+other+"')";</p><p>  //執(zhí)行數(shù)據(jù)庫中的插入記錄操作</p><p>  iCanDb.doAdd(sqlstr);</p><p&

77、gt;  5.2.2 刪除聯(lián)系人</p><p>  刪除聯(lián)系人的頁面如圖5-5所示:</p><p>  圖5-5 刪除聯(lián)系人頁面</p><p>  刪除聯(lián)系人主要是詢問一下是否確定刪除,若點提交就是確定,則會執(zhí)行刪除的SQL語句,把數(shù)據(jù)庫中對應姓名的聯(lián)系人信息刪除,若返回,則放棄刪除。部分代碼如下:</p><p>  //如果請求中的

78、參數(shù)為del,則執(zhí)行數(shù)據(jù)庫中刪除記錄的操作</p><p>  sqlstr="delete from list where id="+id;</p><p>  //調用JavaBean中的業(yè)務邏輯方法,進行數(shù)據(jù)庫刪除操作</p><p>  iCanDb.doDelete(sqlstr);</p><p>  if(a

79、ction.equals("confirm"))</p><p><b>  {</b></p><p><b>  try</b></p><p><b>  {</b></p><p>  sqlstr="select name from li

80、st where id="+id;</p><p>  rs=iCanDb.doSelect(sqlstr);</p><p>  rs.next();</p><p><b>  }</b></p><p><b>  }</b></p><p>  5.2.3

81、查詢聯(lián)系人</p><p>  查詢聯(lián)系人的頁面如圖5-6所示:</p><p>  圖5-6 查詢聯(lián)系人頁面</p><p>  查詢聯(lián)系人頁面,是在聯(lián)系人模塊主頁面上輸入查詢的條件,然后頁面會跳轉到這個顯示頁面,顯示有關這個聯(lián)系人的所有信息。所有信息都是從數(shù)據(jù)庫中查詢出來的。部分代碼如下:</p><p>  sqlstr="s

82、elect * from list where id="+id;</p><p>  //調用JavaBean中的業(yè)務邏輯方法,進行數(shù)據(jù)庫查詢操作</p><p>  rs=iCanDb.doSelect(sqlstr);</p><p>  //循環(huán)遍歷查詢后得到的結果集,得到記錄的每個字段</p><p>  if(rs.nex

83、t())</p><p><b>  {</b></p><p>  String sort=rs.getString("sort");</p><p>  String name=rs.getString("name");</p><p>  String mobile=rs.g

84、etString("mobile");</p><p>  if(mobile==null) mobile=" ";</p><p>  String home=rs.getString("home");</p><p>  if(home==null) home=" ";</p&

85、gt;<p>  String office=rs.getString("office");</p><p>  if(office==null) office=" ";</p><p>  String email=rs.getString("email");</p><p>  if(em

86、ail==null) email=" ";</p><p>  String qq=rs.getString("qq");</p><p><b>  }</b></p><p>  5.3 記事本功能模塊</p><p><b>  5.3.1添加事件</b>

87、;</p><p>  事件添加的頁面如圖5-7所示:</p><p>  圖5-7 事件添加頁面</p><p>  這個頁面用于添加事件,用戶可以輸入標題和內容,然后點提交按鈕,系統(tǒng)會將對應的內容存入數(shù)據(jù)庫中。部分代碼如下:</p><p>  sqlstr="insert into note1([user],[title],[

88、content],[date]) values('"+iCan+"','"+title+"','"+content+"','"+date+"')";</p><p>  iCanDb.doAdd(sqlstr);</p><p>  5.

89、3.2 查詢事件</p><p>  事件的查詢頁面如圖5-8所示:</p><p>  圖5-8 查詢事件頁面</p><p>  查詢頁面中會按用戶的搜索要求顯示相應的記事本中的事件信息,顯示標題,事件內容和存入事件的日期。部分代碼如下:</p><p>  sqlstr="select * from note where id

90、="+id;</p><p>  rs=iCanDb.doSelect(sqlstr);</p><p>  if(rs.next())</p><p><b>  {</b></p><p>  String title=rs.getString("title");</p>

91、<p>  String content=rs.getString("content");</p><p>  content=turn(content);</p><p>  Date datetemp1=rs.getDate("date");</p><p>  java.text.SimpleDateForma

92、t datetemp2=new java.text.SimpleDateFormat("yyyy-MM-dd"); </p><p>  String date=datetemp2.format(datetemp1);}</p><p>  5.4 收藏夾功能模塊</p><p>  5.4.1 添加收藏</p><p&g

93、t;  添加收藏的頁面如圖5-9所示:</p><p>  圖5-9 添加收藏頁面</p><p>  收藏夾添加頁面,可以輸入標題,要收藏的url地址,選擇url地址所屬分類,然后提交,系統(tǒng)會將數(shù)據(jù)存入數(shù)據(jù)庫。部分代碼如下:</p><p>  sqlstr="insert into fav([user],[sort],[title],[urlstr])

94、 values('"+iCan+"','"+sort+"','"+title+"','"+urlstr+"')";</p><p>  iCanDb.doAdd(sqlstr);</p><p><b>  }</b>

95、;</p><p>  5.4.2 修改收藏</p><p>  修改收藏夾的頁面如圖5-10所示:</p><p>  圖5-10 修改收藏頁面</p><p>  修改頁面和添加頁面非常類似,操作也非常類似,用戶輸入想要修改的信息,然后系統(tǒng)會把相應的數(shù)據(jù)使用update的SQL語句,更新原有的數(shù)據(jù)。部分代碼如下:</p>&

96、lt;p>  sqlstr="update [fav] set [sort]='"+sort+"',[title]='"+title+"',[urlstr]='"+urlstr+"' where id="+id;</p><p>  iCanDb.doUpdate(sqlstr);

97、</p><p>  sqlstr="select * from fav where id="+id;</p><p>  rs=iCanDb.doSelect(sqlstr);</p><p>  5.5 存儲資源模塊</p><p>  5.5.1 上傳文件</p><p>  上傳文件的頁面如

98、圖5-11所示:</p><p>  圖5-11 文件上傳頁面</p><p>  在這個頁面中,點擊文本框就會彈出文件的選擇框,用戶選擇自己想要上傳的文件,最多三個文件,點擊上傳按鈕提交表單到另外一個jsp文件,這個文件負責實現(xiàn)上傳。單個文件最大為5MB,若是超過了,系統(tǒng)會提示,并且要求重傳。上傳主要使用的是SmartUpload類,這個類中的upload方法可以實現(xiàn)文件上傳。部分代碼如

99、下:</p><p>  // 新建一個SmartUpload對象</p><p>  SmartUpload su = new SmartUpload();</p><p><b>  // 上傳初始化</b></p><p>  su.initialize(pageContext);</p><p

100、><b>  // 設定上傳限制</b></p><p>  // 1.限制每個上傳文件的最大長度。</p><p>  su.setMaxFileSize(5000000);//數(shù)據(jù) 以B為單位 </p><p>  // 2.限制總上傳數(shù)據(jù)的長度。</p><p>  su.setTotalMaxFileSiz

101、e(150000000);</p><p>  // 3.設定允許上傳的文件(通過擴展名限制)。</p><p>  su.setAllowedFilesList("rar,zip,txt.mp3,jpg,gif,ppt,doc,xls,bmp,wav,mid,dat");</p><p>  // 4.設定禁止上傳的文件(通過擴展名限制),禁止

102、上傳帶有exe,bat,jsp,htm,html擴展名的文件和沒有擴展名的文件。</p><p>  su.setDeniedFilesList("exe,bat,jsp,htm,html,asp,php,com");</p><p><b>  // 上傳文件</b></p><p>  su.upload();</

103、p><p>  // 將上傳文件全部保存到指定目錄</p><p>  String iCanroot=dirPath.replace('\\','/');</p><p>  su.save(iCanroot+"box/"+iCan);</p><p>  5.5.2 下載文件</p&g

104、t;<p>  文件下載的頁面如圖5-12所示:</p><p>  圖5-12 文件下載頁面</p><p>  這是資源存取的功能頁面。在這個頁面中點擊下載,就會把文件名傳給下載操作頁面,在下載操作頁面中執(zhí)行下載,頁面會彈出窗口讓用戶自行選擇存儲到哪個空間。部分代碼如下:</p><p>  // 新建一個SmartUpload對象,用于上傳和下載

105、 </p><p>  SmartUpload su = new SmartUpload();</p><p><b>  // 初始化</b></p><p>  su.initialize(pageContext);</p><p>  // 設定contentDisposition為null以禁止瀏覽器自動打開文件

106、,</p><p>  //保證點擊鏈接后是下載文件。而不用瀏覽器自行打開文件 </p><p>  su.setContentDisposition(null);</p><p><b>  // 下載文件</b></p><p>  su.downloadFile(iCanroot+"box/"+

107、iCan+"/"+filename);</p><p>  5.5.3 刪除文件</p><p>  刪除文件的頁面如圖5-13所示:</p><p>  圖5-13 文件刪除頁面</p><p>  當用戶在資源存取主頁面上選擇刪除時,系統(tǒng)就會執(zhí)行相應代碼,把用戶文件夾中用戶想要刪除的文件刪除掉。部分代碼如下:</

108、p><p>  //如果請求中的參數(shù)為del時,將調用File類中的delete()方法刪除文件</p><p>  if(action.equals("del"))</p><p><b>  {</b></p><p>  File delfile=new File(iCanroot+"bo

109、x/"+iCan+"/"+filename);</p><p>  delfile.delete();}</p><p>  5.6 后臺管理模塊</p><p>  5.6.1 管理員登錄</p><p>  管理員登錄的頁面如圖5-14所示,登錄成功以后的后臺頁面如圖5-15所示:</p>&l

110、t;p>  圖5-14 管理員登錄頁面</p><p>  管理員登錄界面如圖5-14,管理員輸入用戶名和密碼,點擊提交按鈕,表單數(shù)據(jù)會提交給另外一個驗證頁面,驗證通過,就會登錄進后臺,如圖5-15,在后臺中會顯示出普通用戶的使用本系統(tǒng)的相關情況,管理員可以管理普通用戶。</p><p>  圖5-15 后臺管理頁面</p><p>  這就是管理員登錄后的后

111、臺管理主頁面,輸入想要搜索的普通用戶用戶名,點擊搜索可得其詳細情況。部分代碼如下:</p><p>  //根據(jù)管理員登錄名進行查詢</p><p>  //將查詢后得到的結果集中的密碼字段與管理員登錄密碼進行匹配</p><p>  if(rs.next())</p><p><b>  {</b></p&g

112、t;<p>  String pwd=rs.getString("password");//.trim();</p><p>  //String id=rs.getString("id").trim();</p><p>  //如果匹配成功,則表示登錄密碼正確</p><p>  if(password==p

113、assword)</p><p><b>  {</b></p><p>  //session.setAttribute("iCanadmin",id);</p><p>  response.sendRedirect("admin.jsp");</p><p><b>

114、;  }</b></p><p>  //否則輸出登錄錯誤信息</p><p>  5.6.2 刪除注冊用戶</p><p>  刪除用戶的頁面如圖5-16所示:</p><p>  圖5-16 刪除用戶頁面</p><p>  在后臺管理主界面上有刪除鏈接,當想要刪除某個普通用戶時,就可以點擊其后相應

115、的刪除字樣的鏈接,然后會跳轉到這個頁面。點擊提交,就執(zhí)行刪除操作,把對應的用戶刪除掉。部分代碼實現(xiàn)如下:</p><p>  //如果請求中包含的參數(shù)為del,則執(zhí)行刪除用戶操作</p><p>  if(action.equals("del"))</p><p><b>  {</b></p><p&g

116、t;  //從不同的數(shù)據(jù)表中刪除該用戶的信息</p><p>  sqlstr="delete from list where user='"+id+"'";</p><p>  iCanDb.doDelete(sqlstr);</p><p>  sqlstr="delete from note1

117、where user='"+id+"'";</p><p>  iCanDb.doDelete(sqlstr);</p><p>  sqlstr="delete from fav where user='"+id+"'";</p><p>  iCanDb.doD

118、elete(sqlstr);</p><p>  sqlstr="delete from users where id="+id;</p><p>  iCanDb.doDelete(sqlstr);</p><p>  //從資源區(qū)的目錄中刪除所有上傳的文件</p><p>  String iCanroot=dirPa

119、th.replace('\\','/');</p><p>  File userBox=new File(iCanroot+"box/"+id);</p><p>  File userBoxfile[]=userBox.listFiles();</p><p>  if(userBoxfile.length&g

120、t;0)</p><p><b>  {</b></p><p>  for(int i=0;i<userBoxfile.length;i++)</p><p><b>  {</b></p><p>  userBoxfile[i].delete();</p><p>

121、;<b>  }</b></p><p><b>  }</b></p><p>  userBox.delete();</p><p><b>  }</b></p><p>  5.6.3 修改管理員信息</p><p>  修改管理員信息的頁面如

122、圖5-17所示:</p><p>  圖5-17 管理員信息修改頁面</p><p>  在這個頁面中,管理員可以修改自己的信息,包括用戶名和密碼,系統(tǒng)會把數(shù)據(jù)更新進數(shù)據(jù)庫中。部分代碼如下:</p><p>  //如果請求中提交的參數(shù)為save,則執(zhí)行數(shù)據(jù)庫更新操作</p><p>  sqlstr="update [admin]

123、 set [username]='"+username+"'";</p><p>  if(!password.equals(""))</p><p><b>  {</b></p><p>  sqlstr=sqlstr+",[password]='"

124、;+password+"'";</p><p><b>  }</b></p><p>  sqlstr=sqlstr+" where id="+(String)session.getAttribute("iCanadmin");</p><p><b>  try&

125、lt;/b></p><p><b>  {</b></p><p>  //如果管理員用戶名和密碼都正確,則執(zhí)行數(shù)據(jù)庫更新操作</p><p>  iCanDb.doUpdate(sqlstr);</p><p><b>  }</b></p><p><b&

126、gt;  }</b></p><p>  5.7 數(shù)據(jù)庫操作模塊</p><p>  5.7.1 數(shù)據(jù)庫操作</p><p>  本系統(tǒng)使用JavaBean來進行數(shù)據(jù)庫操作的封裝,其中封裝了數(shù)據(jù)庫的連接,添加數(shù)據(jù),刪除數(shù)據(jù),更新數(shù)據(jù),查詢數(shù)據(jù),以及關閉數(shù)據(jù)庫等的操作。使用時,在其他頁面的頂部使用java的usebean元素把這個數(shù)據(jù)庫JavaBean引用

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論