計算機專業(yè)畢業(yè)論文_第1頁
已閱讀1頁,還剩50頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  江蘇開放大學計算機本(論文) </p><p>  題 目 基于PHP的圖書管理系統(tǒng) </p><p><b>  年 月</b></p><p> 學院</p><p> 專業(yè)班級&l

2、t;/p><p> 姓名</p><p> 指導教師</p><p><b>  摘 要</b></p><p>  隨著科學技術的進步和計算機行業(yè)的迅速發(fā)展,人們的工作效率得到大大提高。計算機信息處理系統(tǒng)的引進已徹底改變了許多系統(tǒng)的經(jīng)營管理。</p><p>  圖書管理系統(tǒng)是學校管理機制中的重要

3、組成部分,通過對圖書館管理系統(tǒng)的運行管理機制進行調查和研究,開發(fā)了此圖書館管理系統(tǒng)。本文中主要介紹了圖書館管理事務中的常見基本問題等研究背景,進行了全面的可行性分析,詳細論證了系統(tǒng)的需求分析、系統(tǒng)設計、系統(tǒng)實現(xiàn)和系統(tǒng)測試過程。</p><p>  本系統(tǒng)使用PHP進行網(wǎng)頁界面的設計,使用MVC設計模式,采用集成開發(fā)環(huán)境DreamWeaver進行開發(fā)。后端的數(shù)據(jù)庫采用MySQL,通過ODBC驅動和數(shù)據(jù)庫進行無縫連接

4、。</p><p>  系統(tǒng)實現(xiàn)了用戶登錄、圖書管理、借書證管理、圖書借閱管理等功能模塊。用戶登錄模塊實現(xiàn)用戶的登錄和權限判定;圖書管理模塊實現(xiàn)了對圖書的添加、刪除、修改、查詢等功能;借書證管理模塊實現(xiàn)了對學生的添加、刪除、修改、查詢等功能;圖書借閱管理模塊實現(xiàn)了學生對圖書的借閱、還書和所借圖書的查看等功能。</p><p>  測試結果表明,本系統(tǒng)實現(xiàn)了圖書館圖書管理的主要功能,基本滿足

5、圖書管理的需要。</p><p>  關鍵詞:圖書館,圖書管理系統(tǒng),PHP, MySQL ,JavaScript.</p><p><b>  目 錄</b></p><p><b>  1 緒 論4</b></p><p>  1.1 目前圖書館管理系統(tǒng)存在的問題4</p>&

6、lt;p>  1.2 系統(tǒng)設計的目的和意義4</p><p><b>  2 可行性分析6</b></p><p>  2.1 技術可行性6</p><p>  2.2 經(jīng)濟可行性7</p><p>  2.3 操作可行性7</p><p><b>  3 需求分析8&

7、lt;/b></p><p>  3.1 圖書館管理系統(tǒng)需求概述8</p><p>  3.2 功能需求8</p><p>  3.2.1 與讀者相關的基本功能元素8</p><p>  3.2.2 與管理員相關的基本功能元素9</p><p>  3.2.3 總體系統(tǒng)的基本功能元素9</p>

8、;<p>  3.3 性能需求9</p><p>  3.4運行需求10</p><p><b>  4 系統(tǒng)設計11</b></p><p>  4.1 圖書館管理系統(tǒng)設計指導思想和原則11</p><p>  4.2 設計模式11</p><p>  4.3 圖書館管理

9、系統(tǒng)總體功能概述12</p><p>  4.4 圖書館管理系統(tǒng)各功能模塊概述13</p><p>  4.4.1 系統(tǒng)登錄模塊13</p><p>  4.3.2 圖書管理模塊14</p><p>  4.3.3 學生管理模塊15</p><p>  4.3.4 借閱信息管理模塊16</p>

10、<p>  4.3.5 圖書檢索模塊18</p><p>  4.4 系統(tǒng)數(shù)據(jù)庫設計19</p><p><b>  5 系統(tǒng)實現(xiàn)24</b></p><p>  5.1 系統(tǒng)的軟件結構24</p><p>  5.2 登錄系統(tǒng)模塊的實現(xiàn)24</p><p>  5.3 圖書

11、管理模塊的實現(xiàn)26</p><p>  5.3.1 圖書入庫功能的實現(xiàn)26</p><p>  5.3.2 圖書維護功能的實現(xiàn)27</p><p>  5.4 學生管理模塊的實現(xiàn)31</p><p>  5.4.1 學生添加功能的實現(xiàn)31</p><p>  5.4.2 學生維護功能的實現(xiàn)32</p&

12、gt;<p>  5.5 借閱信息管理模塊的實現(xiàn)35</p><p>  5.5.1 辦理圖書借閱功能的實現(xiàn)36</p><p>  5.5.2 辦理圖書歸還功能的實現(xiàn)37</p><p>  5.6 圖書檢索模塊的實現(xiàn)38</p><p>  5.7 系統(tǒng)設計的創(chuàng)新點39</p><p>  

13、5.7.1 系統(tǒng)后臺管理的安全性39</p><p>  5.7.2 DAO數(shù)據(jù)訪問接口40</p><p><b>  6 系統(tǒng)測試42</b></p><p>  6.1 系統(tǒng)測試的方法與步驟42</p><p>  6.2 模塊測試42</p><p>  6.2.1 登錄模塊測試

14、42</p><p>  6.2.2 圖書管理測試43</p><p>  6.2.3 學生管理測試43</p><p>  6.2.4 借閱信息管理測試44</p><p><b>  6.3 評價44</b></p><p><b>  7 結束語46</b>

15、;</p><p><b>  致 謝47</b></p><p><b>  參考文獻48</b></p><p><b>  1 緒 論</b></p><p>  1.1 目前圖書館管理系統(tǒng)存在的問題</p><p>  (1)檢索速度慢、效

16、率低</p><p>  因為圖書館的藏書種類多。數(shù)量大,將藏書準確的分門別類,快速檢索,手工進行非常困難,往往是終于查到了二維的信息,館中卻沒有此書或已被別人借走。圖書館的規(guī)模越大,這個問題就越突出。</p><p>  (2)借書、還書工作量大</p><p>  借書、還書頻率越大,說明圖書館的作用越大,然而隨之而來的大量的借書、還書登記、實存圖書的更新以及借

17、出圖書超期,遺失等的處理,其工作量之大,往往是人工操作所難以勝任的,而且經(jīng)常會出現(xiàn)這樣那樣的差錯。</p><p> ?。?)圖書統(tǒng)計工作難、藏書更新不能及時完成</p><p>  圖書館的圖書應根據(jù)科學技術的發(fā)展和教學工作的需要及時添加和更新,然而由于藏書數(shù)量及圖書種類越來越多,加上自然損耗,人為破壞,使圖書的統(tǒng)計工作難以及時完成,藏書的更新也就很難有針對性的進行,藏書的知識結構得不到

18、良好地控制。</p><p>  我校也是一所發(fā)展中的高校,近幾年的發(fā)展速度很快,圖書館的規(guī)模和藏書的數(shù)量也在不斷地擴大,為了解決海量圖書的管理問題,以及學生借閱圖書的信息問題,改變傳統(tǒng)的管理方式也就成了迫在眉睫的問題了。</p><p>  1.2 系統(tǒng)設計的目的和意義</p><p>  隨著計算機的廣泛應用,其逐步成為現(xiàn)代化的標志。圖書館或者一些企業(yè)內部,甚至

19、是書店,在正常運行的過程中總是面對大量的讀者信息,書籍信息以及兩者相互作用產(chǎn)生的借書信息,還書信息。因此需要對讀者資源,書籍資源,借書信息,還書信息進行管理,及時了解各個環(huán)節(jié)中信息的變更,要對因此而產(chǎn)生的單據(jù)進行及時的處理,為了提高圖書館或者企業(yè)內部對圖書存銷的自動化的管理,能夠更快速地滿足讀者的要求,提高各種工作效率,現(xiàn)對其設計相應的系統(tǒng),以達到上述的目的。</p><p>  圖書館管理系統(tǒng)的主要功能是實現(xiàn)圖

20、書館圖書的借閱和歸還的管理自動化,圖書新增及銷毀的及時化,用戶及圖書信息的更新,圍繞這些主要功能,本系統(tǒng)涉及到以下核心功能:借閱管理,歸還管理,圖書管理,學生管理。除了這些核心功能外,還包括一些基本和輔助的功能,它們是:圖書信息管理,查詢功能等。</p><p>  該系統(tǒng)設計的主要目標是:</p><p>  設計一個圖書館管理系統(tǒng),該系統(tǒng)主要功能分為圖書查詢、圖書借閱歸還和圖書管理三大

21、部分。在圖書查詢模塊中要求用戶能在瀏覽器中分別書名、著譯者、類型等條件查詢;在圖書管理模塊中要求能完成如辦理借書證(即添加新的學生)、新書錄入、借書還書登記、圖書修改等日常管理功能。</p><p>  網(wǎng)站前臺設計:前臺供學生使用,學生登錄后有如下權利</p><p>  ①圖書查詢:用戶可以按多種方式對圖書庫中的圖書進行查詢;</p><p> ?、诮栝喰畔⒉樵?/p>

22、:用戶可以查看自己的歷史借閱信息。</p><p> ?。?)網(wǎng)站后臺設計:后臺是供管理員使用的,管理員登陸后有如下權利  ①辦理借閱證:將學生信息填寫完整,在數(shù)據(jù)庫中注冊新用戶;</p><p> ?、跁匿浫爰皠h除:可以對現(xiàn)有圖書庫中的圖書進行刪除,也可以添加新書;</p><p> ?、劢钑€書登記:普通用戶借閱或歸還圖書時,管理員將在

23、借閱信息表中添加相應的記錄;</p><p> ?、軋D書修改:管理員可以對現(xiàn)有圖書的詳細信息進行修改。</p><p><b>  2 可行性分析</b></p><p>  采用現(xiàn)代化統(tǒng)一的計算機信息網(wǎng)站系統(tǒng),能夠有效優(yōu)化圖書館管理系統(tǒng),使其高校的發(fā)揮最大的作用,能夠迅捷的為讀者提供相應的服務。開發(fā)本系統(tǒng)的可行性如下:</p>

24、<p><b>  2.1 技術可行性</b></p><p>  在軟、硬件方面對系統(tǒng)的需求來看,由于中小企業(yè)信息化水平比較低,軟硬件配置較差;而且資金實力并不雄厚。所以其對硬件的配置要求是盡可能的低,對軟件配置的要求則是系統(tǒng)最好是基于日常辦公軟件如OFFICE系列上的應用系統(tǒng),這樣既不用花大量資金添置軟件,員工又較容易學會使用應用。本系統(tǒng)所實現(xiàn)的功能是一般性質的辦公業(yè)務,總體的

25、開發(fā)時間不用很長,它用到的硬件平臺不高,軟件基本上是開源且較易懂,項目開發(fā)過程中遇到的技術上的問題在網(wǎng)上或書上可找到,因此是在技術上是可行的。</p><p>  該系統(tǒng)所用的軟件平臺有數(shù)據(jù)庫MYSQL、開發(fā)工具包WAMP2.0、服務器Apache5.0,瀏覽器IE 8.0都是開源的其中操作的細節(jié)和配置都易學。 本系統(tǒng)開發(fā)出來時在技術上具有代表當時辦公自動化信息系統(tǒng)的先進性,本系統(tǒng)在建成后一段時間內,不會因技術的

26、落后而需要大規(guī)模的調整,并且能夠跟隨時逐步的升級而保持整個系統(tǒng)的先進性。同時本系統(tǒng)對計算機硬件要求不算太高,運行速度較快,對企業(yè)辦公很方便。</p><p>  本系統(tǒng)最重要的是基于php的Web應用程序開發(fā)提供了一個框架。本系統(tǒng)的工作流程,分為以下步驟:</p><p>  (1) 瀏覽器向服務器發(fā)出請求,Controller獲得這些請求。</p><p>  

27、(2) Controller根據(jù)配置文件php-config.xml中的定義將這些請求發(fā)送到相應的Action,對應圖中的Model。</p><p>  (3) Action完成相應的業(yè)務邏輯處理后,將處理結果返回到Controller。</p><p>  (4) Controller再根據(jù)配置文件config.xml中的定義將處理結果顯示到用戶視圖View。</p>

28、<p>  本系統(tǒng)正是利用了MVC工作流程來完成此次設計的整個流程,如圖2.2所示:</p><p>  圖2.2 本系統(tǒng)工作流圖</p><p>  2.2 經(jīng)濟可行性 </p><p>  根據(jù)成本/效益分析法,本系統(tǒng)所需的軟硬件資源都已具備,該系統(tǒng)簡單易懂,本系統(tǒng)具有成本相對較低、利益高的特點,經(jīng)濟上可行。</p><p>

29、;  2.3 操作可行性 </p><p>  本系統(tǒng)開發(fā)的開發(fā)宗旨是以便捷為中心。開發(fā)后的系統(tǒng)應具有美觀、大方、簡單、易操作等優(yōu)點,即使是不懂計算機的人員也可以根據(jù)系統(tǒng)提示使用和管理本系統(tǒng),它的操作簡單的特點使本系統(tǒng)在操作上可行。</p><p><b>  3 需求分析</b></p><p>  3.1 圖書館管理系統(tǒng)需求概述</p

30、><p>  圖書館管理系統(tǒng)的開發(fā)主要涉及到圖書的管理,學生信息的管理,借閱信息的管理三大功能的數(shù)據(jù)管理。從管理的角度可將圖書分為三類:圖書信息管理、系統(tǒng)用戶管理、讀者數(shù)據(jù)管理。圖書信息管理包括:添加新進圖書、刪除舊圖書、修改圖書信息。系統(tǒng)用戶管理包括:修改用戶信息、辦理新用戶、注銷用戶。讀者數(shù)據(jù)管理主要包括:讀者借閱信息的管理,借閱圖書以及歸還圖書。</p><p>  圖書借閱者的需求是查

31、詢圖書室所存的圖書。個人借閱情況以及個人信息的修改;圖書館工作人員對圖書借閱者的借閱及還書要求進行操作,同時形成借書或還書報表給借閱者查看確認;圖書管理人員的功能最為復雜,包括對圖書借閱者、圖書進行管理和維護、以及系統(tǒng)狀態(tài)的查詢和維護等。</p><p>  圖書館管理員可以瀏覽、查詢、添加、刪除、修改的基本信息;瀏覽、查詢、添加、刪除和修改圖書借閱者的基本信息;瀏覽、查詢、添加、刪除和修改圖書的借閱信息。<

32、;/p><p><b>  3.2 功能需求</b></p><p>  在本系統(tǒng)中,對讀者來說,他們關心的問題其實是如何方便的查詢到圖書館中的書籍以及自己正在借閱或者已經(jīng)借閱過一些什么書籍,也就是借閱歷史,另一個關心的問題就是所借閱的圖書是否到期等等。由此可以得出系統(tǒng)一些需求。</p><p>  3.2.1 與讀者相關的基本功能元素</p

33、><p>  (1)圖書查詢:應該能夠按照圖書不同信息對圖書進行查詢,如書名、作者、圖書類型等條件查詢。</p><p> ?。?)讀者信息查詢,讀者信息的查詢內容應包括以下幾個方面:</p><p> ?、僮x者信息——對讀者的基本信息進行顯示。</p><p> ?、跁栝啞獙υ撟x者借閱書籍記錄進行查詢。</p><p&

34、gt; ?、矍房畈樵儭獙υ撟x者超期圖書的欠款情況的查看。</p><p>  3.2.2 與管理員相關的基本功能元素</p><p>  在面向系統(tǒng)的管理員來說,應注意如下幾點:</p><p> ?。?)圖書館中有哪些書籍,是否可以被借閱;</p><p> ?。?)對學生的添加、修改和刪除操作的方便性;</p><p

35、> ?。?)查看學生都借閱著哪些書籍;</p><p>  (4)對書籍的添加、修改和刪除操作的方便性。</p><p>  3.2.3 總體系統(tǒng)的基本功能元素</p><p>  從以上問題出發(fā),可以得出本系統(tǒng)應該具有的功能:</p><p> ?。?)圖書查詢——對館內的圖書進行查詢;</p><p> ?。?/p>

36、2)借閱管理——對讀者的每一次借閱,還書進行登記和管理;</p><p> ?。?)圖書管理——對圖書館的書籍進行管理,添加、刪除以及修改信息;</p><p> ?。?)學生管理——對學生進行管理,添加、刪除以及修改信息;</p><p>  (5)欠款情況管理——對讀者借閱圖書超期欠款的情況進行管理。</p><p><b> 

37、 3.3 性能需求</b></p><p>  3.3.1人身和環(huán)境安全性需求</p><p> ?。?)系統(tǒng)中的軟件不構成對人身健康的損害;</p><p> ?。?)系統(tǒng)中的軟件失效時不造成財產(chǎn)的損失;</p><p> ?。?)系統(tǒng)中的軟件失效時不造成環(huán)境的破壞。</p><p>  3.3.2可靠性

38、和可用性需求</p><p>  (1)系統(tǒng)中的軟件可以每天使用24小時,每年使用365天;</p><p> ?。?)系統(tǒng)中的軟件故障率小于等于5%。</p><p>  3.3.3容錯性需求</p><p>  用戶輸入錯誤信息時,系統(tǒng)應提示,不應崩潰。</p><p><b>  3.3.4易用性<

39、;/b></p><p>  軟件適合12-70周歲的智力、視力、體力和肢體正常且具有圖書借閱相關知識的人使用;</p><p><b>  3.3.5易學性</b></p><p>  經(jīng)過1-2天培訓的使用者可以正常使用本軟件。</p><p><b>  3.4 運行需求</b><

40、/p><p>  3.4.1預期的物理環(huán)境</p><p> ?。?)系統(tǒng)在常溫環(huán)境下使用;</p><p>  (2)系統(tǒng)在潔凈的室內使用。</p><p>  3.4.2預期的技術環(huán)境</p><p> ?。?)寬帶網(wǎng)、1M以上寬帶互聯(lián)網(wǎng);</p><p> ?。?)臺式計算機:CPU P4 2

41、.0G以上,內存256M以上,硬盤40G以上,10M/100M網(wǎng)卡,Windows 2000/2003/NT/XP中文操作系統(tǒng);</p><p>  (3)數(shù)據(jù)庫管理系統(tǒng):MySQL5.0及以上。</p><p><b>  4 系統(tǒng)設計</b></p><p>  4.1 圖書館管理系統(tǒng)設計指導思想和原則</p><p&g

42、t; ?。?)利用軟件開發(fā)現(xiàn)有軟硬件環(huán)境,及先進的管理系統(tǒng)開發(fā)方案,從而到達充分利用現(xiàn)在資源提高系統(tǒng)開發(fā)水平和應用效果的目的。</p><p> ?。?)系統(tǒng)應該符合軟件工程開發(fā)的理論,開發(fā)方法等開發(fā)依據(jù)。</p><p> ?。?)系統(tǒng)應滿足圖書館管理工作的需要,并達到操作過程中的直觀,方便,實用,安全,準確等要求。</p><p> ?。?)系統(tǒng)應具備數(shù)據(jù)庫維護

43、功能,及時根據(jù)用戶需求進行數(shù)據(jù)庫的各種操作。</p><p> ?。?)系統(tǒng)采用原型,實用模塊化程序設計方法,便于系統(tǒng)功能的各種組合和修改,以及系統(tǒng)的測試與維護。</p><p> ?。?)圖書館管理系統(tǒng)的設計應適合校園的發(fā)展。</p><p> ?。?)圖書館管理系統(tǒng)的設計應當遵循數(shù)據(jù)庫設計規(guī)范。</p><p><b>  4.

44、2 設計模式</b></p><p>  設計模式是面向對象的程序設計人員用來解決編程問題的一種形式化表示。本系統(tǒng)開發(fā)采用目前一種廣泛流行的軟件設計模式MVC。MVC(Model—View—Controller)應用程序結構被用來分析分布式應用程序的特征。這種抽象結構能有助于將應用程序分割成若干邏輯部件,使程序設計變得更加容易。把一個應用的輸入、處理、輸出流程按照Model、View、Controll

45、er的方式進行分離,這樣一個應用被分成三個層——模型層、視圖層、控制層。</p><p>  圖4-1 MVC模式</p><p>  MVC模式的出現(xiàn),很好的解決了傳統(tǒng)開發(fā)WEB應用方式中存在的問題。M代表模型(Model),包含完成任務所需要的所有的行為和數(shù)據(jù);V代表視圖(View)界面,現(xiàn)實模型提供的數(shù)據(jù);C代表控制器(Controller),它將模型映射到界面中,處理用戶的輸入并相

46、應請求。其模型的關系如圖所示。在MVC模型中,三層各盡其職、相互獨立,各層內部的改變不會影響到其它層,從而降低了數(shù)據(jù)表達、數(shù)據(jù)描述和應該操作的耦合度,也能更好的實現(xiàn)開發(fā)中的分工,加速工程進度。</p><p>  4.3 圖書館管理系統(tǒng)總體功能概述</p><p>  圖書管理系統(tǒng)包含五個模塊分別是:系統(tǒng)登錄、圖書管理、學生管理、借閱信息管理、圖書檢索。</p><p&

47、gt;  系統(tǒng)登錄模塊:一般用戶和管理員都必須登錄才能進入系統(tǒng),用戶登錄時在后臺判斷用戶的權限類型,分為普通用戶和管理員,普通用戶可以對書籍進行瀏覽及個人借閱信息的查詢,管理員可以對多種信息進行操作。</p><p>  圖書管理模塊:管理員通過驗證界面進入系統(tǒng)后,進入到圖書管理模塊,可以對圖書進行添加,刪除、修改圖書信息、查詢、查看等一系列的操作。</p><p>  學生管理模塊:管理

48、員可以在此模塊中創(chuàng)建新的普通用戶,并且可以對用戶的信息進行修改,刪除等操作。</p><p>  借閱信息管理模塊:這是圖書管系統(tǒng)中最重要的模塊之一,管理員進入該模塊中可以為普通用戶辦理借閱圖書,歸還圖書的功能,并且能夠實現(xiàn)還款的操作。</p><p>  圖書檢索模塊:普通用戶通過驗證界面進入系統(tǒng)后,能夠按照書名,作者等多種條件對圖書進行查詢操作,確保查詢到的都是最新的信息。</p

49、><p>  整體系統(tǒng)的功能模塊如圖4-2所示:</p><p>  圖4-2 圖書館管理系統(tǒng)功能圖</p><p>  4.4 圖書館管理系統(tǒng)各功能模塊概述</p><p>  4.4.1 系統(tǒng)登錄模塊</p><p>  用戶進入系統(tǒng)時調用的一個模塊。該模塊根據(jù)用戶輸入的用戶名、密碼來判斷用戶的類型,跳轉到該類用戶的界

50、面。</p><p>  本模塊的功能點包括:</p><p>  判斷用戶名和密碼是否相符;</p><p>  根據(jù)用戶的權限類型,登錄到系統(tǒng)的制定界面操作使用。</p><p>  登錄功能模塊流程圖如圖4-3所示:</p><p>  圖4-3 登錄模塊流程圖</p><p>  4.3

51、.2 圖書管理模塊</p><p>  在本模塊中圖書館工作人員可以對圖書進行管理操作。</p><p>  本模塊的功能點包括:</p><p>  新書入庫,將新進圖書按其類型將圖書的基本信息錄入系統(tǒng)數(shù)據(jù)庫; </p><p>  圖書出庫,某一部分圖書會隨著時間的增長及知識的更新而變得不再有收藏的價值,或者圖書被損壞,這些圖書就要在圖

52、書庫中除去。即從圖書庫中刪除此圖書記錄;</p><p>  新書編碼,圖書入庫后,需要貼上條形碼,以便以后提供借閱,本系統(tǒng)不涉及到條形碼閱讀器,只是假定此過程已經(jīng)生成條形碼。編碼只是將條形碼帖于書上以唯一標識圖書;</p><p>  圖書信息修改,圖書信息由于工作人員的疏忽,而出現(xiàn)錄入錯誤,提供其圖書ID就可以查看圖書的基本信息并對其進行修改;</p><p>

53、  圖書管理功能模塊流程圖如圖4-4所示:</p><p>  圖4-4 圖書管理模塊流程圖</p><p>  4.3.3 學生管理模塊</p><p>  本模塊主要是工作者對學生信息(讀者借書證信息)進行管理。</p><p>  本模塊的功能點包括:</p><p>  辦理借書證,為新讀者辦理借書證,填寫用

54、戶基本信息;</p><p>  注銷借書證,輸入讀者借書證編號,根據(jù)借書證ID刪除讀者表中此借書證信息;</p><p>  掛失借書證,主要是將借書證的狀態(tài)改為掛失,更新讀者表狀態(tài)字段,有圖書管理員操作;</p><p>  修改圖書證信息,由于工作人員的疏忽,而出現(xiàn)辦理借書證時錄入信息有誤,則可根據(jù)借書證編號對其信息進行查看和修改。</p>&l

55、t;p>  借書證管理功能模塊流程圖如圖4-5所示:</p><p>  圖4-5 借書證管理模塊流程圖</p><p>  4.3.4 借閱信息管理模塊</p><p>  本模塊主要是工作者對圖書外借和歸還進行管理。</p><p>  本模塊的功能點包括:</p><p>  圖書借閱,記錄借閱證編號和圖書

56、編號,進行借書過程。在數(shù)據(jù)庫中插入一天借書記錄,該記錄包括圖書ID、借書證ID、借閱日期、歸還日期等;</p><p>  圖書歸還,輸入借書證編號,圖書編號,根據(jù)輸入的編號在借閱登記表中找到相應的記錄,將借閱記錄刪除,并將該記錄相應的數(shù)據(jù)更新到歷史借閱記錄信息表中;</p><p>  查看借閱記錄,可以根據(jù)借書證ID以及圖書ID查詢借閱記錄。</p><p> 

57、 辦理還款,如讀者有圖書超期的情況將會有欠款,可以根據(jù)借書證的ID來為讀者班里還款。</p><p>  借閱信息管理功能模塊流程圖如圖4-6所示:</p><p>  圖4-6 借閱信息管理模塊流程圖</p><p>  4.3.5 圖書檢索模塊</p><p>  使用該模塊的用戶有:讀者和管理員。</p><p&g

58、t;  本模塊的功能點包括:</p><p>  根據(jù)圖書ID進行檢索;</p><p>  根據(jù)圖書名稱進行檢索;</p><p>  根據(jù)圖書類型進行檢索。</p><p>  根據(jù)圖書作者或譯者進行檢索。</p><p>  圖書檢索功能模塊流程圖如圖4-7所示:</p><p>  圖4

59、-7 圖書檢索模塊流程圖</p><p>  4.4 系統(tǒng)數(shù)據(jù)庫設計</p><p>  4.4.1 概念結構設計</p><p><b> ?。?)實體圖</b></p><p>  學生:學生屬性有學號、姓名、密碼、性別、學院、班級、電話、email、宿舍、地址、已借書數(shù)量、創(chuàng)建日期。學生實體圖如圖4-8所示:<

60、;/p><p>  圖4-8 學生實體圖</p><p>  圖書:圖書屬性有圖書編號、書名、作者、類別、單價、出版社、出版日期、總數(shù)量、當前數(shù)量、購買日期、內容摘要。圖書實體圖如圖4-9所示:</p><p>  圖4-9 圖書實體圖</p><p><b>  (2)E—R圖</b></p><p&g

61、t;  根據(jù)以上實體圖,分析了各個實體的屬性,根據(jù)這些屬性,可以得到系統(tǒng)的E—R圖,如圖4-10所示</p><p><b>  1n</b></p><p><b>  nn</b></p><p><b>  1n</b></p><p>  圖4.8 系統(tǒng)E-

62、R圖</p><p>  4.4.2 邏輯結構設計</p><p>  根據(jù)上述功能模塊的需求,設計如下主要數(shù)據(jù)庫表:</p><p>  表4.1 圖書信息表(t_book)</p><p>  表4.2 學生信息表 (t_student)</p><p>  表4.3 借閱信息表(t_book_student

63、)</p><p>  表4.4 管理員表(t_admin)</p><p>  表4.5 學院表(t_admin)</p><p>  表4.6 班級表(t_class)</p><p>  表4.7 圖書類別表(t_admin)</p><p><b>  5 系統(tǒng)實現(xiàn)</b></

64、p><p>  5.1 系統(tǒng)的軟件結構</p><p>  處理靜態(tài)WEB是由Web瀏覽器向Web發(fā)送靜態(tài)頁面, Web服務器直接對發(fā)送的靜態(tài)網(wǎng)頁進行處理。</p><p>  處理動態(tài)WEB數(shù)據(jù)庫查詢的過程是:當Web瀏覽器向Web服務器發(fā)送請求時,動態(tài)網(wǎng)頁的處理流程是,屏蔽掉HTML語言,只輸入動態(tài)網(wǎng)頁文件,由Web服務器向數(shù)據(jù)庫中傳遞信息,經(jīng)過數(shù)據(jù)庫的處理返回數(shù)據(jù)

65、集,Web應用服務器再把含有程序代碼的動態(tài)網(wǎng)頁轉換為靜態(tài)網(wǎng)頁返還給Web瀏覽器。這就是用動態(tài)網(wǎng)頁對數(shù)據(jù)庫進行查詢并將數(shù)據(jù)返還給瀏覽器處理的全過程,具體見圖5-1所示。</p><p>  圖5-1數(shù)據(jù)庫查詢示意圖</p><p>  5.2 登錄系統(tǒng)模塊的實現(xiàn)</p><p>  本模塊主要是用戶通過圖書館管理系統(tǒng)的首頁進入該系統(tǒng)。用戶輸入正確的用戶名和密碼,如果登

66、錄信息有錯誤,則系統(tǒng)提示登錄錯誤信息,并且禁止系統(tǒng)用戶進行任何操作。若登錄信息正確,系統(tǒng)會根據(jù)用戶的身份進行相應權限的判斷,讀者進入前臺系統(tǒng),管理員進入后臺系統(tǒng)。圖書館系統(tǒng)登錄主頁面如圖5-2所示。</p><p>  圖5-2 圖書館管理系統(tǒng)登錄界面</p><p><b>  其實現(xiàn)的代碼如下:</b></p><p><b> 

67、 Action層:</b></p><p>  public String login() {</p><p>  boolean flag = iss.login(admin);</p><p>  if(flag) { return "success"; }</p><p>  message = &q

68、uot;用戶名或口令錯誤!";</p><p>  return "fail";</p><p><b>  }</b></p><p><b>  Service層:</b></p><p>  public boolean login(TAdmin admin) {

69、</p><p>  TAdmin a = isd.login(admin);</p><p>  if(a != null) { return true;}</p><p>  return false;</p><p><b>  }</b></p><p><b>  Da

70、o層:</b></p><p>  public TAdmin login(TAdmin admin) {</p><p>  Session session = this.getHibernateTemplate().getSessionFactory().openSession();</p><p>  Query q = session.creat

71、eQuery("from TAdmin a where a.adminName = ? and a.adminPassword = ?").setString(0, admin.getAdminName()).setString(1, admin.getAdminPassword());</p><p>  TAdmin a = (TAdmin)q.uniqueResult();</p&

72、gt;<p><b>  return a;</b></p><p><b>  }</b></p><p>  5.3 圖書管理模塊的實現(xiàn)</p><p>  圖書管理模塊主要分為圖書入庫、查看圖書、統(tǒng)計圖書,其中圖書入庫是往圖書管理數(shù)據(jù)庫中添加圖書信息??磮D書功能中可以查看圖書詳細信息,并對圖書信息進行修

73、改或刪除某些廢棄圖書信息。</p><p>  5.3.1 圖書入庫功能的實現(xiàn)</p><p>  點擊添加圖書功能,填寫圖書基本信息,為圖書選擇類型,類型是與數(shù)據(jù)庫交互動態(tài)生成的下拉列表,具體界面如圖5-3所示。</p><p>  圖5-3 圖書入庫界面</p><p><b>  其實現(xiàn)的代碼如下:</b><

74、/p><p>  public String addInfoBook() {</p><p>  this.sortList = ibs.listBookSort();</p><p>  return "add";</p><p><b>  }</b></p><p>  pu

75、blic List<TSort> listBookSort() {</p><p>  return this.getHibernateTemplate().find("from TSort tsort");</p><p><b>  }</b></p><p>  public String addSaveB

76、ook() {</p><p>  ibs.saveBook(book);</p><p>  book = null;</p><p>  bookList = this.listBook();</p><p>  return "Book";</p><p><b>  }</b

77、></p><p>  public void saveBook(TBook book) {</p><p>  Date now = new Date();</p><p>  book.setBuyDate(now);</p><p>  book.setCurrentNum(book.getTotalNum());</p&g

78、t;<p>  ibd.saveBook(book);</p><p><b>  }</b></p><p>  public void saveBook(TBook book) {this.getHibernateTemplate().save(book);</p><p><b>  }</b>&l

79、t;/p><p>  5.3.2 圖書維護功能的實現(xiàn)</p><p>  點擊圖書維護功能,展示所有圖書的信息列表,在每個圖書信息行后提供刪除和修改操作功能,并且可以單擊選定某一個圖書信息后的詳細信息進行詳細查看圖書信息。具體圖書列表界面如圖5-4所示</p><p>  圖5-4 圖書列表界面</p><p><b>  其實現(xiàn)的代碼

80、如下:</b></p><p>  public String listAllBook() {</p><p>  bookList = this.listBook();</p><p>  return "Book";</p><p><b>  }</b></p><

81、;p>  public List<TBook> listBook(TBook book, Page page) {</p><p>  String hql = "from TBook tb where 1=1";</p><p>  if(book!=null) {</p><p>  if(book.getBookNum()

82、 != null && !"".equals(book.getBookNum().trim())) {</p><p>  hql = hql + " and tb.bookNum = '" + book.getBookNum()+"'";</p><p><b>  }</b>

83、;</p><p>  if(book.getBookName() != null && !"".equals(book.getBookName().trim())) {</p><p>  hql = hql + " and tb.bookName = '" + book.getBookName()+"'&

84、quot;;</p><p><b>  }</b></p><p>  if(book.getWriter() != null && !"".equals(book.getWriter().trim())) { hql = hql + " and tb.writer = '" + book.getWr

85、iter()+"'"; }</p><p>  if(!book.getSortId().getSortId().trim().equals("-1")) {</p><p>  hql = hql + " and tb.sortId.sortId = '" + book.getSortId().getSortId

86、()+"'";</p><p><b>  }</b></p><p>  hql = hql + " order by tb.bookName";</p><p><b>  } else {</b></p><p>  hql = hql + &q

87、uot; order by tb.buyDate desc";</p><p><b>  }</b></p><p>  Session session = this.getHibernateTemplate().getSessionFactory().openSession();</p><p>  Query q = sessi

88、on.createQuery(hql);</p><p>  q.setFirstResult(page.getStartRow());</p><p>  q.setMaxResults(5);</p><p>  List<TBook> list = q.list();</p><p>  return list;</p

89、><p><b>  }</b></p><p> ?。?)刪除圖書功能的實現(xiàn)</p><p>  管理員刪除圖書,刪除時可刪除一個,也可同時多選刪除,</p><p><b>  其實現(xiàn)的代碼如下:</b></p><p>  public String deleteOneB

90、ook() {</p><p>  ibs.delBookById(bookNum);</p><p>  bookList = this.listBook();</p><p>  return "Book";</p><p><b>  }</b></p><p>  pu

91、blic String deleteMoreBook() {</p><p>  ibs.delMoreBook(bookNums);</p><p>  bookList = this.listBook();</p><p>  return "Book"; </p><p><b>  }</b>

92、</p><p>  public void delBookById(String bookNum) {</p><p>  this.getHibernateTemplate().delete(this.getHibernateTemplate().get(TBook.class, bookNum)); </p><p><b>  }</b>

93、;</p><p>  public void delMoreBook(String[] bookNums) {</p><p>  for(int i=0; i<bookNums.length;i++) {</p><p>  this.getHibernateTemplate().delete(this.getHibernateTemplate().get

94、(TBook.class, bookNums[i]));}</p><p><b>  }</b></p><p> ?。?)修改圖書信息功能的實現(xiàn)</p><p>  在管理員修改圖書信息時,跳轉到圖書信息詳細表單中,列出所要修改圖書的詳細信息,并可以進行修改,則修改界面如圖5-5所示。</p><p>  圖5-5

95、 修改圖書信息界面</p><p><b>  其實現(xiàn)的代碼如下:</b></p><p>  public String modifyInfoBook() {</p><p>  this.sortList = ibs.listBookSort();</p><p>  book = ibs.queryOneBookB

96、yId(bookNum);</p><p>  return "modifyInfo";</p><p><b>  }</b></p><p>  public String modifySaveBook() {</p><p>  ibs.modifyBook(book);</p>

97、<p>  book = null;</p><p>  bookList = this.listBook();</p><p>  return "Book";</p><p><b>  }</b></p><p>  public TBook queryOneBookById(Stri

98、ng bookNum) {</p><p>  TBook book = (TBook)this.getSession().createQuery("from TBook tb where tb.bookNum = ?").setString(0, bookNum).uniqueResult();</p><p>  this.getSession().close();

99、</p><p>  return book;</p><p><b>  }</b></p><p>  public void modifyBook(TBook book) {</p><p>  this.getHibernateTemplate().update(book);</p><p&g

100、t;<b>  }</b></p><p> ?。?)查看圖書詳細信息功能的實現(xiàn)</p><p>  在管理員點擊詳細信息時,跳轉到某圖書信息詳細表單中,列出所選圖書的詳細信息,則顯示界面如圖5-6所示。</p><p>  圖5-6圖書詳細信息界面</p><p><b>  其實現(xiàn)的代碼如下:</b&

101、gt;</p><p>  public String infoDetailBook() {</p><p>  book = ibs.queryOneBookById(bookNum);</p><p>  return "Detail";</p><p><b>  }</b></p>

102、<p>  public TBook queryOneBookById(String bookNum) {</p><p>  TBook book = (TBook)this.getSession().createQuery("from TBook tb where tb.bookNum = ?").setString(0, bookNum).uniqueResult();&l

103、t;/p><p>  this.getSession().close();</p><p>  return book;</p><p><b>  }</b></p><p>  5.4 學生管理模塊的實現(xiàn)</p><p>  學生管理模塊主要分為添加學生、查看學生、修改學生,查看學生的詳細信息。

104、</p><p>  5.4.1 學生添加功能的實現(xiàn)</p><p>  點擊添加學生,填寫學生基本信息,具體界面如圖5-7所示。</p><p>  圖5-7辦理借書證界面</p><p><b>  其實現(xiàn)的代碼如下:</b></p><p>  public String addInfoSt

105、udent() {</p><p>  this.academyList = iss.listAllAcademy();</p><p>  return "add";</p><p><b>  }</b></p><p>  public void addStudent(TStudent stud

106、ent) {</p><p>  Date now = new Date();</p><p>  student.setCreateDate(now);</p><p>  student.setLendedNum(0);</p><p>  isd.saveStudent(student);</p><p><

107、;b>  }</b></p><p>  public List<TAcademy> listAllAcademy() {</p><p>  return this.getHibernateTemplate().find("from TAcademy ta");</p><p><b>  }</b

108、></p><p>  public List<TClass> listAllClass() {</p><p>  return this.getHibernateTemplate().find("from TClass tc");</p><p><b>  }</b></p><p

109、>  public void saveStudent(TStudent student) {</p><p>  this.getHibernateTemplate().save(student);</p><p><b>  }</b></p><p>  5.4.2 學生維護功能的實現(xiàn)</p><p>  點擊

110、學生維護功能,展示所有讀者的信息列表,在每個讀者信息行后提供刪除和修改操作功能,并且可以單擊選定某一個讀者信息后的詳細信息進行詳細查看讀者信息。具體讀者列表界面如圖5-8所示</p><p>  圖5-8 讀者列表界面</p><p><b>  其實現(xiàn)的代碼如下:</b></p><p>  public String listAllStud

111、ent() {</p><p>  studentList = this.getStudentListByPage();</p><p>  return "Student";</p><p><b>  }</b></p><p>  public List<TStudent> list

112、AllStudent(Page page) {</p><p>  Session session = this.getHibernateTemplate().getSessionFactory().openSession();</p><p>  Query q = session.createQuery("from TStudent ts");</p>

113、<p>  q.setFirstResult(page.getStartRow());</p><p>  q.setMaxResults(5);</p><p>  List<TStudent> list = q.list();</p><p>  return list;</p><p><b>  }&

114、lt;/b></p><p>  (1)刪除學生功能的實現(xiàn)</p><p>  管理員刪除讀者,刪除時可刪除一個,也可同時多選刪除。</p><p><b>  其實現(xiàn)的代碼如下:</b></p><p>  public String deleteOneStudent() {</p><p&g

115、t;  iss.deleteOneStudent(studentNum);</p><p>  studentList = this.getStudentListByPage();</p><p>  return "Student";</p><p><b>  }</b></p><p>  pu

116、blic String deleteMoreStudent() {</p><p>  iss.deleteMoreStudent(studentNums);</p><p>  studentList = this.getStudentListByPage();</p><p>  return "Student";</p>&l

117、t;p><b>  }</b></p><p>  public void deleteOneStudent(String studentNum) {</p><p>  this.getHibernateTemplate().delete(this.getHibernateTemplate().get(TStudent.class, studentNum));

118、</p><p><b>  }</b></p><p>  public void deleteMoreStudent(String[] studentNums) {</p><p>  for(int i=0;i<studentNums.length;i++) {</p><p>  this.getHiber

119、nateTemplate().delete(this.getHibernateTemplate().get(TStudent.class, studentNums[i]));</p><p><b>  }</b></p><p><b>  }</b></p><p> ?。?)修改學生信息功能的實現(xiàn)</p>

120、<p>  在管理員修改學生信息時,跳轉到學生信息詳細表單中,列出所要修改學生的詳細信息,并可以進行修改,則修改界面如圖5-9所示。</p><p>  圖5-9 修改讀者信息界面</p><p><b>  其實現(xiàn)的代碼如下:</b></p><p>  public String modifyInfoStudent() {&l

121、t;/p><p>  this.student = iss.getStudentByid(studentNum);</p><p>  this.academyList = iss.listAllAcademy();</p><p>  this.classList = iss.listClassById(student.getAcademyId().getAcadem

122、yId());</p><p>  return "modifyInfo";</p><p><b>  }</b></p><p>  public String modifySaveStudent() {</p><p>  iss.modifyStudentByid(student);</

123、p><p>  student = null;</p><p>  studentList = this.getStudentListByPage();</p><p>  return "Student";</p><p><b>  }</b></p><p>  public

124、 TStudent getStudentByid(String studentNum) {</p><p>  return (TStudent)this.getHibernateTemplate().get(TStudent.class, studentNum);</p><p><b>  }</b></p><p>  public vo

125、id modifyStudentByid(TStudent student) {</p><p>  this.getHibernateTemplate().update(student);</p><p><b>  }</b></p><p>  (3)查看讀者詳細信息功能的實現(xiàn)</p><p>  在管理員點擊詳細

126、信息時,跳轉到某讀者信息詳細表單中,列出所選讀者的詳細信息,則顯示界面如圖5-10所示。</p><p>  圖5-10讀者詳細信息界面</p><p><b>  其實現(xiàn)的代碼如下:</b></p><p>  public String infoDetailStudent() {</p><p>  student

溫馨提示

  • 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

提交評論