計(jì)算機(jī)系-畢業(yè)論文信息管理
火車訂票系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)摘 要隨著科學(xué)技術(shù)的不斷提高,計(jì)算機(jī)科學(xué)日漸成熟,其強(qiáng)大的功能已為人們深刻認(rèn)識(shí),它已進(jìn)入人類社會(huì)的各個(gè)領(lǐng)域并發(fā)揮著越來(lái)越重要的作用。作為計(jì)算機(jī)應(yīng)用的一部分使用計(jì)算機(jī)對(duì)火車信息進(jìn)行管理,具有手工管理所無(wú)法比擬的優(yōu)點(diǎn)。例如:檢索迅速查找方便可靠性高存儲(chǔ)量大保密性好壽命長(zhǎng)成本低等這些優(yōu)點(diǎn)能夠極大地提高火車信息管理的效率,也是企業(yè)的科學(xué)化正規(guī)化管理,與世界接軌的重要條件。本文針對(duì)火車站的訂票實(shí)際情況,按照軟件工程的結(jié)構(gòu)化設(shè)計(jì)思想,經(jīng)過(guò)項(xiàng)目的可行性研究和需求分析,總體設(shè)計(jì),詳細(xì)設(shè)計(jì),以及編碼實(shí)現(xiàn)和調(diào)試等步驟設(shè)計(jì)開(kāi)發(fā)了火車站網(wǎng)上訂票系統(tǒng)。并運(yùn)用數(shù)據(jù)流圖和數(shù)據(jù)字典,E-R 圖和數(shù)據(jù)庫(kù)邏輯結(jié)構(gòu),層次圖,系統(tǒng)流程圖,以及程序流程圖,對(duì)該系統(tǒng)的數(shù)據(jù)需求,數(shù)據(jù)庫(kù),系統(tǒng)軟件結(jié)構(gòu),系統(tǒng)流程,以及處理過(guò)程等進(jìn)行了分析和設(shè)計(jì)。本系統(tǒng)前臺(tái)主要使用 JSP 作為開(kāi)發(fā)語(yǔ)言,后臺(tái)使用 MySQL 作為數(shù)據(jù)庫(kù)管理系統(tǒng),開(kāi)發(fā)環(huán)境是 MyEclipse,服務(wù)器采用 tomcat,開(kāi)發(fā)出的一個(gè)基于 Web 技術(shù)的 B/S 結(jié)構(gòu)的火車訂票系統(tǒng)。關(guān)鍵詞:信息管理 火車訂票 JSP B/S 結(jié)構(gòu)IThe Design and Implementation of Train ticketing systemAbstractWith the continuous improvement of science and technology, computer science increasingly mature, its powerful features for people to have a profound understanding, it has entered the human society in various fields and play an increasingly important role. As part of the computer application the use of computers to train information management, with a manual management of the incomparable advantages. For example: the rapid retrieval and search for convenient, high reliability, large storage capacity, confidentiality good, long life and low cost. These advantages can improve the efficiency of the train information management, the enterprise is also a scientific, standardized management, and an important condition for the world.Aiming at the train station booking the actual situation, in accordance with a structured software engineering design, after the project can do research and needs analysis, general design, detailed design, coding and debugging steps as well as the design and development of fire station online booking system. And use the data flow diagram and data dictionary, E-R diagram and database logical structure, hierarchy diagram, system flow chart, and program flow chart of the system, data requirements, database, system software structure, system flow process, and process is analyzed and design.The front of the system using JSP as a development language, the use of MySQL as a database management system, the development environment is MyEclipse, server using tomcat, developed a Web technology based on B/S structure of railway ticketing system.Key words: information management; train ticket; JSP; B / S structureII目 錄中文摘要.i英文摘要.ii目錄.iii第一章 緒論.11.1課題背景 .11.2目的和意義 .11.3開(kāi)發(fā)工具及技術(shù) .11.3.1開(kāi)發(fā)工具 .11.3.2 JSP .21.3.3 JavaScript .21.3.4 Struts2簡(jiǎn)介 .31.3.5 Hibernate簡(jiǎn)介 .31.4軟硬件需求 .3第二章 需求分析.42.1需求調(diào)研 .42.2可行性分析 .42.2.1技術(shù)的可行性 .42.2.2經(jīng)濟(jì)的可行性 .42.2.3操作可行性 .42.2.4法律的可行性 .52.3系統(tǒng)用戶用例圖 .52.3.1管理員用例圖 .52.3.2會(huì)員用例圖 .52.4功能模塊需求分析 .62.5設(shè)計(jì)的 基本思想 .72.6性能需求 .72.6.1系統(tǒng)的安全性 .7III2.6.2數(shù)據(jù)的完整性 .72.7界面需求 .7第三章 系統(tǒng)分析與設(shè)計(jì).83.1數(shù)據(jù)庫(kù)的分析與設(shè)計(jì) .83.1.1數(shù)據(jù)庫(kù)的概念結(jié)構(gòu)設(shè)計(jì) .83.1.2數(shù)據(jù)庫(kù)的邏輯結(jié)構(gòu)設(shè)計(jì) .103.1.3數(shù)據(jù)庫(kù)的連接原理 .123.2中文亂碼問(wèn)題處理 .12第四章 系統(tǒng)功能實(shí)現(xiàn).134.1前臺(tái)網(wǎng)站模塊 .134.1.1網(wǎng)站首面 .134.1.2用戶注冊(cè) .134.1.3車票預(yù)訂 .144.2會(huì)員功能模塊 .144.2.1會(huì)員中心 .144.2.2我的基本信息 .154.2.3我的訂單信息 .154.2.4修改密碼 .164.3管理員功能模塊 .164.3.1登錄系統(tǒng) .164.3.2管理員主頁(yè)面 .174.3.3會(huì)員信息管理 .184.3.4車次信息管理 .184.3.5訂單信息管理 .204.3.6修改密碼 .214.3.7退出系統(tǒng) .21第五章 系統(tǒng)測(cè)試.235.1系統(tǒng)測(cè)試目的與意義 .23IV5.2測(cè)試過(guò)程 .235.2.1主頁(yè)面的登錄模塊測(cè)試 .235.2.2其他錯(cuò)誤 .24第六章 結(jié) 論.25致 謝.26參考文獻(xiàn).270第一章 緒論1.1 課題背景火車站市場(chǎng)的管理和規(guī)范問(wèn)題,是困擾我們多年的一個(gè)老問(wèn)題,也是政府管理中的一個(gè)難點(diǎn),訂票是客運(yùn)業(yè)務(wù)中的一個(gè)最基本的業(yè)務(wù),表面上看,它只是火車站業(yè)務(wù)的一個(gè)簡(jiǎn)單的部分,但是它涉及到管理與客戶服務(wù)等多方面 1,因此,過(guò)去傳統(tǒng)的售票方式已經(jīng)不能滿足現(xiàn)代客運(yùn)業(yè)務(wù)流量劇增的客觀要求,這就要求一種全新的訂票方式網(wǎng)上訂票,來(lái)緩解訂票高峰時(shí)期的客運(yùn)壓力,并為用戶提供方便快捷的訂票服務(wù)。1.2 目的和意義中國(guó)現(xiàn)在擁有非常先進(jìn)、發(fā)達(dá)的鐵路系統(tǒng),但目前的售票系統(tǒng)還是上世紀(jì) 60 年代開(kāi)發(fā)的。2003 年以后,中國(guó)鐵路開(kāi)始加快現(xiàn)代化建設(shè),近幾年來(lái)中國(guó)的火車訂票系統(tǒng)已經(jīng)逐步走向現(xiàn)代化,訂票全路聯(lián)網(wǎng),實(shí)現(xiàn)了信息化管理 2。但是鐵路歷史由來(lái)的“老大難”問(wèn)題售票問(wèn)題,一直無(wú)法得到解決。每年的各大節(jié)假日,全國(guó)人民總會(huì)為買(mǎi)票問(wèn)題而苦惱,一部分人更是無(wú)緣車票。雖然目前的電話訂票,也極大地方便了旅客,然而最貼近現(xiàn)代化發(fā)展水平的還是網(wǎng)上訂票項(xiàng)目,國(guó)家也積極推進(jìn)。1.3 開(kāi)發(fā)工具及技術(shù)1.3.1 開(kāi)發(fā)工具此次設(shè)計(jì)主要采用 MyEclipse 加 Tomcat 后臺(tái)服務(wù)器進(jìn)行,設(shè)計(jì)過(guò)程中頁(yè)面主要使用 JSP 技術(shù)完成,下面對(duì) MyEclipse、Tomcat 和 MySQL 數(shù)據(jù)庫(kù)進(jìn)行簡(jiǎn)要介紹。1.3.1.1 MyEclipse MyEclipse,是一個(gè)十分優(yōu)秀的用于開(kāi)發(fā) Java,J2EE 的 Eclipse 插件集合,MyEclipse 的功能非常強(qiáng)大,支持也十分廣泛,尤其是對(duì)各種開(kāi)元產(chǎn)品的支持十分不錯(cuò)。MyEclipse 企業(yè)級(jí)工作平臺(tái)(MyEclipse Enterprise Workbench,簡(jiǎn)稱 MyEclipse)是對(duì) Eclipse IDE3的擴(kuò)展,利用它我們可以在數(shù)據(jù)庫(kù)和 JavaEE 的開(kāi)發(fā)、發(fā)布,以及應(yīng)用程序服務(wù)器的整合方面極大的提高工作效率。它是功能豐富的 JavaEE 集成開(kāi)發(fā)環(huán)境,包括了完備的編碼、調(diào)試、測(cè)試和發(fā)布功能,完整支持 HTML, Struts, JSP, CSS, Javascript, SQL, Hibernate。1.3.1.2 Tomcat Tomcat 是一個(gè)小型的輕量級(jí)應(yīng)用服務(wù)1器,在中小型系統(tǒng)和并發(fā)訪問(wèn)用戶不是很多的場(chǎng)合下被普遍使用,是開(kāi)發(fā)和調(diào)試 JSP 程序的首選??梢赃@樣認(rèn)為,當(dāng)在一臺(tái)機(jī)器上配置好 Apahce 服務(wù)器,可利用它響應(yīng)對(duì) HTML 頁(yè)面的訪問(wèn)請(qǐng)求。實(shí)際上 Tomcat 部分是 Apache 服務(wù)器 3的擴(kuò)展,但它是獨(dú)立運(yùn)行的,所以當(dāng)運(yùn)行 tomcat 時(shí),它實(shí)際上作為一個(gè)與 Apache 獨(dú)立的進(jìn)程單獨(dú)運(yùn)行的。1.3.1.3 MySQL MySQL 是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),由瑞典 MySQL AB 公司開(kāi)發(fā),目前屬于 Oracle 公司。MySQL 是最流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),在 WEB 應(yīng)用方面 MySQL 是最好的 RDBMS(Relational Database Management System,關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng))應(yīng)用軟件之一。MySQL 是一種關(guān)聯(lián)數(shù)據(jù)庫(kù)管理系統(tǒng),關(guān)聯(lián)數(shù)據(jù)庫(kù)將數(shù)據(jù)保存在不同的表中,而不是將所有數(shù)據(jù)放在一個(gè)大倉(cāng)庫(kù)內(nèi),這樣就增加了速度并提高了靈活性。MySQL 所使用的 SQL 語(yǔ)言是用于訪問(wèn)數(shù)據(jù)庫(kù)的最常用標(biāo)準(zhǔn)化語(yǔ)言 3。MySQL 軟件由于其體積小、速度快、總體擁有成本低,尤其是開(kāi)放源碼這一特點(diǎn),一般中小型網(wǎng)站的開(kāi)發(fā)都選擇 MySQL 作為網(wǎng)站數(shù)據(jù)庫(kù)。1.3.2 JSPJSP 技術(shù)使用 Java 編程語(yǔ)言編寫(xiě)類 XML 的 tags 和 scriptlets,來(lái)封裝產(chǎn)生動(dòng)態(tài)網(wǎng)頁(yè)的處理邏輯。網(wǎng)頁(yè)還能通過(guò) tags 和 scriptlets 訪問(wèn)存在于服務(wù)端的資源的應(yīng)用邏輯。JSP 將網(wǎng)頁(yè)邏輯與網(wǎng)頁(yè)設(shè)計(jì)和顯示分離,支持可重用的基于組件的設(shè)計(jì) 4,可以使基于 Web 的應(yīng)用程序的開(kāi)發(fā)變得迅速和容易。Web 服務(wù)器在遇到訪問(wèn) JSP 網(wǎng)頁(yè)的請(qǐng)求時(shí),首先執(zhí)行其中的程序段,然后將執(zhí)行結(jié)果連同JSP 文件中的 HTML 代碼一起返回給客戶。插入的 Java 程序段可以操作數(shù)據(jù)庫(kù)、重新定向網(wǎng)頁(yè)等,以實(shí)現(xiàn)建立動(dòng)態(tài)網(wǎng)頁(yè)所需要的功能。JSP 與 Servlet 一樣,是在服務(wù)器端執(zhí)行的,通常返回給客戶端就是一個(gè) HTML 文本,因此客戶端只要有瀏覽器能瀏覽。JSP 頁(yè)面由 HTML 代碼和嵌入其中的Java 代碼所組成。服務(wù)器在頁(yè)面被客戶端請(qǐng)求以后對(duì)這些 Java 代碼進(jìn)行處理,然后將生成的HTML 頁(yè)面返回給客戶端的瀏覽器 5。Servlet 是 JSP 的技術(shù)基礎(chǔ),而且大型的 Web 應(yīng)用程序的開(kāi)發(fā)需要 Java Servlet 和 JSP 配合才能完成。JSP 具備了 Java 技術(shù)的簡(jiǎn)單易用,完全的面向?qū)ο?,具有平臺(tái)無(wú)關(guān)性且安全可靠,主要面向因特網(wǎng)的所有特點(diǎn) 6。1.3.3 JavaScriptJavaScript 是一種基于對(duì)象和事件驅(qū)動(dòng)并具有相對(duì)安全性的客戶端腳本語(yǔ)言。同時(shí)也是一種廣泛用于客戶端 Web 開(kāi)發(fā)的腳本語(yǔ)言,常用來(lái)給 HTML 網(wǎng)頁(yè)添加動(dòng)態(tài)功能,比如響應(yīng)用戶的各種操作。JavaScript 的一個(gè)重要功能就是面向?qū)ο蟮墓δ?,通過(guò)基于對(duì)象的程序設(shè)計(jì),可以用更直觀、模塊化和可重復(fù)使用的方式進(jìn)行程序開(kāi)發(fā)。在 HTML 基礎(chǔ)上,使用 Javascript 可以開(kāi)發(fā)交互式 Web 網(wǎng)頁(yè)。Javascript 的出現(xiàn)使得網(wǎng)頁(yè)和用戶之間實(shí)現(xiàn)了一種實(shí)時(shí)性的、動(dòng)態(tài)的、交2互性的關(guān)系,使網(wǎng)頁(yè)包含更多活躍的元素和更加精彩的內(nèi)容 7。在本系統(tǒng)中很多地方使用了javascript 技術(shù),比如說(shuō),檢驗(yàn)用戶輸入數(shù)據(jù)的有效性,是否重復(fù),是否為空等等。1.3.4 Struts2 簡(jiǎn)介Struts 最早是作為 Apache Jakarta 項(xiàng)目的組成部分問(wèn)世運(yùn)作。項(xiàng)目的創(chuàng)立者希望通過(guò)對(duì)該項(xiàng)目的研究,改進(jìn)和提高 Java Server Pages、Servlet、標(biāo)簽庫(kù)以及面向?qū)ο蟮募夹g(shù)水準(zhǔn)。它的目的是為了減少在運(yùn)用 MVC 設(shè)計(jì)模型來(lái)開(kāi)發(fā) Web 應(yīng)用的時(shí)間。使用 Struts 的目的是為了幫助我們減少在運(yùn)用 MVC 設(shè)計(jì)模型來(lái)開(kāi)發(fā) Web 應(yīng)用的時(shí)間。Struts 是 Apache 軟件基金會(huì)(ASF)贊助的一個(gè)開(kāi)源項(xiàng)目。它最初是 Jakarta 項(xiàng)目中的一個(gè)子項(xiàng)目,并在 2002 年 3 月成為 ASF 的頂級(jí)項(xiàng)目。它通過(guò)采用 Java ServletJSP 技術(shù),實(shí)現(xiàn)了基于 Java EE Web 應(yīng)用的 Model-View-ControllerMVC設(shè)計(jì)模式的應(yīng)用框架Web Framework3,是 MVC 經(jīng)典設(shè)計(jì)模式中的一個(gè)經(jīng)典產(chǎn)品。而 Struts2 則是 Struts 的升級(jí)版本。1.3.5 Hibernate 簡(jiǎn)介Hibernate 是一個(gè)開(kāi)放源代碼的對(duì)象關(guān)系映射框架,它對(duì) JDBC 進(jìn)行了非常輕量級(jí)的對(duì)象封裝,使得 Java 程序員可以隨心所欲的使用對(duì)象編程思維來(lái)操縱數(shù)據(jù)庫(kù)。Hibernate 可以應(yīng)用在任何使用 JDBC 的場(chǎng)合,既可以在 Java 的客戶端程序使用,也可以在 Servlet/JSP 的 Web 應(yīng)用中使用,最具革命意義的是,Hibernate 可以在應(yīng)用 EJB 的 J2EE 架構(gòu)中取代 CMP3,完成數(shù)據(jù)持久化的重任。Hibernate 的核心接口一共有 2 個(gè),分別為:Session、SessionFactory、Transaction、Query 和 Configuration。這 2 個(gè)核心接口在任何開(kāi)發(fā)中都會(huì)用到。通過(guò)這些接口,不僅可以對(duì)持久化對(duì)象進(jìn)行存取,還能夠進(jìn)行事務(wù)控制 3。1.4 軟硬件需求硬 件 需 求 :CPU: Pentium 以 上 計(jì) 算 機(jī) 內(nèi) 存 : 512M 以 上 軟 件 需 求 :操 作 系 統(tǒng) 版 本 : Windows XP/vista/Win7 開(kāi) 發(fā) 工 具 : MyEclipse 10 后 臺(tái) 服 務(wù) 器 : Apache Tomcat 7 開(kāi) 發(fā) 語(yǔ) 言 : Java 瀏 覽 器 : IE 10 3第二章 需求分析2.1 需求調(diào)研在項(xiàng)目的開(kāi)始是需求調(diào)研,經(jīng)過(guò)一系列的調(diào)查發(fā)現(xiàn),火車站市場(chǎng)的管理和規(guī)范問(wèn)題,是困擾我們多年的一個(gè)老問(wèn)題,也是政府管理中的一個(gè)難點(diǎn)。訂票是客運(yùn)業(yè)務(wù)中的一個(gè)最基本的業(yè)務(wù),表面上看,它只是火車站業(yè)務(wù)的一個(gè)簡(jiǎn)單的部分,但是它涉及到管理與客戶服務(wù)等多方面 1,因此,過(guò)去傳統(tǒng)的售票方式已經(jīng)不能滿足現(xiàn)代客運(yùn)業(yè)務(wù)流量劇增的客觀要求,這就要求一種全新的訂票方式網(wǎng)上訂票,來(lái)緩解訂票高峰時(shí)期的客運(yùn)壓力,并為用戶提供方便快捷的訂票服務(wù)。2.2 可行性分析開(kāi)發(fā)任何一個(gè)系統(tǒng),都會(huì)受到時(shí)間和資源上的限制。因此,在每一個(gè)項(xiàng)目開(kāi)發(fā)之前,都要進(jìn)行可行性分析,可以減少項(xiàng)目的開(kāi)發(fā)風(fēng)險(xiǎn),避免人力、物力和財(cái)力的浪費(fèi)。下面就技術(shù)、經(jīng)濟(jì)、操作和法律四個(gè)方面來(lái)介紹。2.2.1 技術(shù)的可行性本系統(tǒng)開(kāi)發(fā)工具是 MyEclipse 和 MySQL 數(shù)據(jù)庫(kù),開(kāi)發(fā)語(yǔ)言是 Java,主要使用了 J2EE 的技術(shù),java 是一種面向?qū)ο缶幊陶Z(yǔ)言,簡(jiǎn)單易學(xué)而且靈活方便。大三時(shí)就學(xué)習(xí)了 java 課程,大四期間也系統(tǒng)的了解了 J2EE 的知識(shí),火車訂票系統(tǒng)總體上開(kāi)發(fā)難度不高,數(shù)據(jù)庫(kù)的設(shè)計(jì)和操作是本系統(tǒng)設(shè)計(jì)的核心。在大學(xué)期間學(xué)習(xí)過(guò) UML 統(tǒng)一建模語(yǔ)言等課程,每個(gè)學(xué)期也會(huì)完成對(duì)應(yīng)的課程設(shè)計(jì),具備一定的系統(tǒng)分析、設(shè)計(jì)和測(cè)試能力。因此,完成系統(tǒng)實(shí)現(xiàn)在技術(shù)上完全具有可行性。2.2.2 經(jīng)濟(jì)的可行性如今是信息化時(shí)代,信息化管理可以使車票管理、預(yù)訂工作更加系統(tǒng)化、快速化、全面化。這樣可以為企業(yè)帶來(lái)較高的工作效益和經(jīng)濟(jì)效益,本系統(tǒng)對(duì)計(jì)算機(jī)配置的要求不高,企業(yè)機(jī)房更換下來(lái)的低配置電腦都可以完全滿足需要,再者,企業(yè)在管理工作上的高效率和便捷性遠(yuǎn)遠(yuǎn)超過(guò)了開(kāi)發(fā)本系統(tǒng)的成本 8,所以在經(jīng)濟(jì)上具有完全的可行性。2.2.3 操作可行性本系統(tǒng)操作簡(jiǎn)單,輸入信息頁(yè)面大多數(shù)都是下拉框的選擇形式,在某些頁(yè)面,信息可以自動(dòng)生成,無(wú)需輸入,時(shí)間的輸入也是用的日歷控件,操作簡(jiǎn)便,對(duì)操作人員的要求很低,只需對(duì) WINDOWS 操作熟練,加之對(duì)本系統(tǒng)的操作稍加培訓(xùn)即可工作,而且本系統(tǒng)可視性非常好,所4以在技術(shù)上不會(huì)有很大難度。2.2.4 法律的可行性本系統(tǒng)是自行開(kāi)發(fā)的管理系統(tǒng),是很有實(shí)際意義的系統(tǒng),開(kāi)發(fā)環(huán)境軟件和使用的數(shù)據(jù)庫(kù)都是開(kāi)源代碼,開(kāi)發(fā)這個(gè)系統(tǒng)不同于開(kāi)發(fā)普通的系統(tǒng)軟件,不存在侵權(quán)等問(wèn)題,即法律上是可行的 8。綜上所述,開(kāi)發(fā)一個(gè)網(wǎng)絡(luò)火車訂票系統(tǒng)與傳統(tǒng)售票的方式相比具有速度更快,操作更準(zhǔn)確,節(jié)省開(kāi)支等有利之處,因此,建立一個(gè)網(wǎng)絡(luò)火車訂票系統(tǒng)是必要可行的。2.3 系統(tǒng)用戶用例圖2.3.1 管理員用例圖管理員是系統(tǒng)的核心用戶,涉及到四大功能模塊,管理員對(duì)系統(tǒng)的所有用戶有著操作的權(quán)限,能夠及時(shí)動(dòng)態(tài)的掌握車票及訂單的各項(xiàng)情況。管理員用例圖如圖 2-1 所示:管理員登錄系統(tǒng)會(huì)員信息管理修改密碼車次信息管理訂單信息管理圖 2-1 管理員用例圖2.3.2 會(huì)員用例圖會(huì)員是系統(tǒng)的主要用戶,登錄系統(tǒng)可進(jìn)入會(huì)員中心。會(huì)員用例圖如圖 2-2 所示:5會(huì)員登錄系統(tǒng) 修改個(gè)人信息修改密碼我的車票訂單管理圖 2-2 會(huì)員用例圖2.4 功能模塊需求分析本系統(tǒng)最大的特點(diǎn)是使用操作簡(jiǎn)單、友好的提示信息。本系統(tǒng)將實(shí)現(xiàn)以下基本功能:(1)系統(tǒng)具有簡(jiǎn)潔大方的頁(yè)面,使用簡(jiǎn)便,友好的錯(cuò)誤操作提示。(2)管理員用戶具有管理員信息管理、會(huì)員信息管理、車次信息管理、訂單信息管理等功能。(3)具有較強(qiáng)的安全性,避免用戶的惡意操作 9。管理員功能模塊圖說(shuō)明:管理員是功能最多的一種用戶角色。(1)管理員管理模塊:在該模塊中完成管理員的密碼修改功能。(2)會(huì)員信息管理模塊:在該模塊中定義了注冊(cè)會(huì)員信息的管理,其功能包括會(huì)員信息的查詢、刪除等操作。(3)車次信息管理模塊:在該模塊中定義了對(duì)車次信息的管理,其功能包括車次信息錄入、查詢、刪除等操作。(4)訂單信息管理模塊:在該模塊中定義了對(duì)訂單信息的管理,其功能包括訂單信息查詢、受理、刪除等操作。管理員用戶功能模塊圖如圖 2-3 所示:6管理員用戶模塊修改個(gè)人密碼會(huì)員信息管理碼車次信息管理訂單信息管理會(huì)員刪除會(huì)員管理車次管理車次添加訂單受理訂單管理圖 2-3 管理員用戶功能模塊圖2.5 設(shè)計(jì)的基本思想設(shè)計(jì)思想遵循以下幾點(diǎn):1. 采用 B/S 模式進(jìn)行開(kāi)發(fā),其優(yōu)點(diǎn)是后臺(tái)與前臺(tái)處理層次分明,而且符合眾多已經(jīng)習(xí)慣網(wǎng)頁(yè)方式的用戶。2. 采用面向?qū)ο蟮拈_(kāi)發(fā)與設(shè)計(jì)理念。運(yùn)用面向?qū)ο蠹夹g(shù)的前提是對(duì)整體系統(tǒng)的高度和準(zhǔn)確抽象,通過(guò)它可以保證系統(tǒng)良好的框架,進(jìn)而帶來(lái)產(chǎn)品較強(qiáng)的穩(wěn)定性和運(yùn)行效率。3. 采用模塊化設(shè)計(jì)。模塊化設(shè)計(jì)要求將整個(gè)系統(tǒng)劃分成基于小的模塊,有利于代碼的重載,簡(jiǎn)化設(shè)計(jì)和實(shí)現(xiàn)過(guò)程。4. 簡(jiǎn)單方便的系統(tǒng)界面。設(shè)計(jì)簡(jiǎn)單友好的系統(tǒng)界面,方便用戶較快的適應(yīng)系統(tǒng)的操作。5速度優(yōu)先原則。由于此工具最重要的評(píng)測(cè)標(biāo)準(zhǔn)就是速度,因此在設(shè)計(jì)過(guò)程中,具體過(guò)程盡量做到資源占用少,速度快。6設(shè)計(jì)既要突出重點(diǎn),又要細(xì)致周到。要符合設(shè)計(jì)需求,在有可能改進(jìn)的地方進(jìn)行擴(kuò)充,使系統(tǒng)更適應(yīng)用戶的需要 9。72.6 性能需求2.6.1 系統(tǒng)的安全性火車訂票系統(tǒng)在管理權(quán)限上要嚴(yán)格進(jìn)行控制,具體要求如下:想登錄火車訂票系統(tǒng)后臺(tái)進(jìn)行操作,必須有操作權(quán)限,沒(méi)有權(quán)限的用戶不能通過(guò)任何方式登錄系統(tǒng)查看系統(tǒng)的任何信息和數(shù)據(jù),以確保系統(tǒng)的嚴(yán)密性和安全性;要在前臺(tái)提交訂單等信息,必須先進(jìn)行注冊(cè),未注冊(cè)的用戶不能進(jìn)行任何操作。2.6.2 數(shù)據(jù)的完整性1.各種記錄信息的完整性,信息記錄內(nèi)容不能為空。2.各種數(shù)據(jù)間相互聯(lián)系的正確性。3.相同數(shù)據(jù)在不同記錄中的一致性。2.7 界面需求界面設(shè)計(jì)目前已經(jīng)成為評(píng)價(jià)軟件質(zhì)量的一條重要指標(biāo),一個(gè)好的用戶界面可以增加用戶使用系統(tǒng)的信心和興趣,提高工作效率,JSP 技術(shù)是用 JAVA 語(yǔ)言作為腳本語(yǔ)言的,JSP 網(wǎng)頁(yè)為整個(gè)服務(wù)器端的 JAVA 庫(kù)單元提供了一個(gè)接口來(lái)服務(wù)于 HTTP 的應(yīng)用程序。創(chuàng)建動(dòng)態(tài)頁(yè)面非常方便。用戶界面是指軟件系統(tǒng)與用戶交互的接口,通常包括輸出、輸入、人-機(jī)對(duì)話的界面格式等 10。第三章 系統(tǒng)分析與設(shè)計(jì)3.1 數(shù)據(jù)庫(kù)的分析與設(shè)計(jì)計(jì)算機(jī)信息系統(tǒng)以數(shù)據(jù)庫(kù)為核心,在數(shù)據(jù)庫(kù)管理系統(tǒng)的支持下,進(jìn)行信息的收集、整理、存儲(chǔ)、檢索、更新、加工、統(tǒng)計(jì)和傳播等操作。數(shù)據(jù)庫(kù)已經(jīng)成為現(xiàn)在信息系統(tǒng)等計(jì)算機(jī)系統(tǒng)的基礎(chǔ)與核心部分 10。數(shù)據(jù)庫(kù)設(shè)計(jì)的好壞直接影響到整個(gè)系統(tǒng)的質(zhì)量和效率。數(shù)據(jù)庫(kù)的設(shè)計(jì)一般經(jīng)過(guò)規(guī)劃。需求分析、概念設(shè)計(jì)、邏輯設(shè)計(jì)、物理設(shè)計(jì) 5 個(gè)步驟。3.1.1 數(shù)據(jù)庫(kù)的概念結(jié)構(gòu)設(shè)計(jì)概念設(shè)計(jì)是指在數(shù)據(jù)分析的基礎(chǔ)上自底向上的建立整個(gè)系統(tǒng)的數(shù)據(jù)庫(kù)概念結(jié)構(gòu),從用戶的角度進(jìn)行視圖設(shè)計(jì),然后將視圖集成,最后對(duì)集成的結(jié)構(gòu)分析優(yōu)化得到最后結(jié)果 9。數(shù)據(jù)庫(kù)的概念結(jié)構(gòu)設(shè)計(jì)采用實(shí)體聯(lián)系(E-R)模型設(shè)計(jì)方法。E-R 模型法的組成元素有:實(shí)體、屬性、聯(lián)系,E-R 模型用 E-R 圖表示,是提示用戶工作環(huán)境中所涉及的事物,屬性則是對(duì)8實(shí)體特性的描述 9。根據(jù)以上對(duì)數(shù)據(jù)庫(kù)的需求分析,并結(jié)合系統(tǒng)概念模型的特點(diǎn)及建立方法,建立 E-R 模型圖。(1)會(huì)員信息實(shí)體 E-R 圖如圖 3-1 所示:用戶名密碼會(huì)員信息真實(shí)姓名身份證號(hào) 性別聯(lián)系電話電子郵箱地址圖 3-1 會(huì)員信息實(shí)體 E-R 圖(2)車次信息實(shí)體 E-R 圖如圖 3-2 所示車次號(hào)出發(fā)站車次信息到達(dá)站出發(fā)時(shí)間 發(fā)車時(shí)間到達(dá)時(shí)間剩余票數(shù)票價(jià)圖 3-2 車次信息實(shí)體 E-R 圖屬性 實(shí)體間關(guān)系實(shí)體9(3)訂單信息 E-R 圖如圖 3-3 所示會(huì)員信息車次信息訂單信息預(yù)定金額支付方式 預(yù)訂時(shí)間預(yù)定狀態(tài)圖 3-3 訂單信息實(shí)體 E-R 圖(4)管理員信息 E-R 圖如圖 3-4 所示管理員信息登錄名密碼圖 3-4 管理員信息實(shí)體 E-R 圖3.1.2 數(shù)據(jù)庫(kù)的邏輯結(jié)構(gòu)設(shè)計(jì)我們知道,數(shù)據(jù)庫(kù)概念模型獨(dú)立于任何特定的數(shù)據(jù)庫(kù)管理系統(tǒng),因此,需要根據(jù)具體使用10的數(shù)據(jù)庫(kù)管理系統(tǒng)的特點(diǎn)進(jìn)行轉(zhuǎn)換。即轉(zhuǎn)化為按計(jì)算機(jī)觀點(diǎn)處理的邏輯關(guān)系模型,E-R 模型向關(guān)系數(shù)據(jù)庫(kù)模型轉(zhuǎn)換應(yīng)遵循下列原則:*每一個(gè)實(shí)體要轉(zhuǎn)換成一個(gè)關(guān)系*所有的主鍵必須定義非空(NOT NULL)*對(duì)于二元聯(lián)系應(yīng)按照一對(duì)多、弱對(duì)實(shí)、一對(duì)一、多對(duì)多等聯(lián)系來(lái)定義外鍵 9。根據(jù) E-R 模型,火車訂票系統(tǒng)建立了以下邏輯數(shù)據(jù)結(jié)構(gòu),下面是各數(shù)據(jù)表的詳細(xì)說(shuō)明。(1)會(huì)員信息表主要是記錄了會(huì)員基本信息。表結(jié)構(gòu)如表 3-5 所示。表 3-5 會(huì)員信息表(t_user)列名 數(shù)據(jù)類型 長(zhǎng)度 允許空 是否主鍵 說(shuō)明user_id int 4 否 是 編號(hào)user_name varchar 50 否 否 登錄名user_pw varchar 50 否 否 密碼user_realname varchar 50 否 否 真實(shí)姓名user_idcard varchar 50 否 否 身份證號(hào)user_sex varchar 50 否 否 性別user_tel varchar 50 否 否 聯(lián)系電話user_email varchar 50 否 否 電子郵箱user_address varchar 200 否 否 住址yxbz varchar 1 否 否 有效標(biāo)志(2)車次信息表主要是記錄了車次的基本信息,表結(jié)構(gòu)如表 3-6 所示。表 3-6 車次信息表(t_checi)列名 數(shù)據(jù)類型 長(zhǎng)度 允許空 是否主鍵 說(shuō)明id int 4 否 是 編號(hào)checihao varchar 50 否 否 車次號(hào)shifazhan varchar 50 否 否 出發(fā)站daodazhan varchar 50 否 否 到達(dá)站piaoshijian varchar 50 否 否 出發(fā)時(shí)間startshijian varchar 50 否 否 發(fā)車時(shí)間endshijian varchar 50 否 否 到達(dá)時(shí)間piaojia double 10 否 否 票價(jià)11piaoshu int 8 否 否 剩余票數(shù)yxbz varchar 1 否 否 有效標(biāo)志(3)訂單信息表主要是記錄訂單的基本信息,表結(jié)構(gòu)如表 3-7 所示。表 3-7 訂單信息表(t_yuding)列名 數(shù)據(jù)類型 長(zhǎng)度 允許空 是否主鍵 說(shuō)明id int 4 否 是 編號(hào)user_id int 4 否 否 會(huì)員 IDcheci_id int 4 否 否 車次 IDyuding_jine varchar 50 否 否 預(yù)訂金額zhifufangshi varchar 50 否 否 支付方式y(tǒng)uding_shijian varchar 50 否 否 預(yù)訂時(shí)間yuding_zhuantai varchar 50 否 否 預(yù)訂狀態(tài)(6)管理員信息表主要記錄管理員的賬號(hào)信息,包括用戶名和密碼,表結(jié)構(gòu)如表 3-8 所示。表 3-8 管理員信息表(t_admin)列名 數(shù)據(jù)類型 長(zhǎng)度 允許空 是否主鍵 說(shuō)明userId int 4 否 是 編號(hào)userName varchar 50 否 否 用戶名userPw varchar 50 否 否 密碼3.1.3 數(shù)據(jù)庫(kù)的連接原理本系統(tǒng)采用 Hibernate 對(duì)數(shù)據(jù)庫(kù)進(jìn)行管理。Hibernate 是一個(gè)開(kāi)放源代碼的對(duì)象關(guān)系映射框架,它對(duì) JDBC 進(jìn)行了輕量級(jí)的對(duì)象封裝,使 Java 程序員可以隨心所欲的使用對(duì)象編程思維來(lái)操縱數(shù)據(jù)庫(kù)。它不僅提供了從 Java 類到數(shù)據(jù)表之間的映射,也提供了數(shù)據(jù)查詢和恢復(fù)機(jī)制 3。相對(duì)于使用 JDBC 和 SQL 來(lái)手工操作數(shù)據(jù)庫(kù), Hibernate 可以大大減少操作數(shù)據(jù)庫(kù)的工作量。另外 Hibernate 可以利用代理模式來(lái)簡(jiǎn)化載入類的過(guò)程,這將大大減少利用 Hibernate QL 從數(shù)據(jù)庫(kù)提取數(shù)據(jù)的代碼的編寫(xiě)量,從而節(jié)約開(kāi)發(fā)時(shí)間和開(kāi)發(fā)成本 Hibernate 可以和多種Web 服務(wù)器或者應(yīng)用服務(wù)器良好集成,如今已經(jīng)支持幾乎所有的流行的數(shù)據(jù)庫(kù)服務(wù)器。Hibernate 技術(shù)本質(zhì)上是一個(gè)提供數(shù)據(jù)庫(kù)服務(wù)的中間件。它的架構(gòu)如圖 3-9 所示:12圖 3-9 Hibernatre 架構(gòu)圖圖 3.5 顯示了 Hibernate 的工作原理,它是利用數(shù)據(jù)庫(kù)以及其他一些配置文件如 Hibernate.properties,XML Mapping 等來(lái)為應(yīng)用程序提供數(shù)據(jù)持久化服務(wù)的。Hibernate 具有很大的靈活性,但同時(shí)它的體系結(jié)構(gòu)比較復(fù)雜,提供了好幾種不同的運(yùn)行方式。在輕型體系中,應(yīng)用程序提供 JDBC 連接,并且自行管理事務(wù),這種方式使用了 Hibernate 的一個(gè)最小子集 3;在全面解決體系中,對(duì)于應(yīng)用程序來(lái)說(shuō),所有底層的 JDBC/JTA API 都被抽象了,Hibernate 會(huì)替你照管所有的細(xì)節(jié)。3.2 中文亂碼問(wèn)題處理在程序中經(jīng)常會(huì)遇到中文亂碼的情況,解決辦法是將頁(yè)面的編碼方式和 struts.xml 的設(shè)置的編碼方式都用成 utf-8。1. 在 jsp 頁(yè)面設(shè)定字符編碼,;2. 在 struts.properties 中加入?yún)?shù) struts.i18n.encoding = UTF-8。第四章 系統(tǒng)功能實(shí)現(xiàn)在管理信息系統(tǒng)的生命周期中,經(jīng)過(guò)了需求分析、系統(tǒng)設(shè)計(jì)等階段之后,便開(kāi)始了系統(tǒng)實(shí)施階段。在系統(tǒng)分析和設(shè)計(jì)階段,系統(tǒng)開(kāi)發(fā)工作主要是集中在邏輯、功能和技術(shù)設(shè)計(jì)上,系統(tǒng)實(shí)施階段要繼承此前面各個(gè)階段的工作成果,將技術(shù)設(shè)計(jì)轉(zhuǎn)化為物理實(shí)現(xiàn),因此系統(tǒng)實(shí)施的成果是系統(tǒng)分析和設(shè)計(jì)階段的結(jié)晶 10-13。134.1 前臺(tái)網(wǎng)站模塊4.1.1 網(wǎng)站首面 1.描述:火車訂票系統(tǒng)網(wǎng)首頁(yè)分為頂部菜單、右側(cè)的登錄模塊及日歷表、中間主要的車次信息三部分組成。2.程序效果圖如下圖 4-1 所示:圖 4-1 網(wǎng)站首頁(yè)4.1.2 用戶注冊(cè)1.描述:新用戶通過(guò)該模塊實(shí)現(xiàn)網(wǎng)站注冊(cè)會(huì)員功能的實(shí)現(xiàn)。2.程序效果圖如下圖 4-2 所示:14圖 4-2 用戶注冊(cè)界面4.1.3 車票預(yù)訂1.描述:注冊(cè)用戶瀏覽主頁(yè)中的所有可預(yù)訂的車票信息,點(diǎn)擊預(yù)訂,填寫(xiě)預(yù)訂信息,完成車票預(yù)訂操作。預(yù)訂車票時(shí)要先判斷用戶是否登錄,否則不能預(yù)訂。2.程序效果圖如下圖 4-3 所示:圖 4-3 車票預(yù)訂界面4.2 會(huì)員功能模塊4.2.1 會(huì)員中心1.描述:會(huì)員中心主頁(yè)面:左方頁(yè)面展示了會(huì)員可操作的兩大功能,進(jìn)入相關(guān)的管理頁(yè)面可以鏈接到子菜單,每個(gè)管理模塊下面都有相應(yīng)的子菜單。152.程序運(yùn)行效果圖如圖 4-4 所示:圖 4-4 會(huì)員中心主頁(yè)面4.2.2 我的基本信息1.描述:會(huì)員點(diǎn)擊左側(cè)的菜單“我的基本信息” ,頁(yè)面跳轉(zhuǎn)到我的基本信息界面,調(diào)用后臺(tái)的 action 類查詢出我的基本信息,并顯示到頁(yè)面上。2.程序效果圖如下圖 4-5 所示:圖 4-5 我的基本信息4.2.3 我的訂單信息1.描述:會(huì)員點(diǎn)擊左側(cè)的菜單“我的訂單信息” ,頁(yè)面跳轉(zhuǎn)到會(huì)員訂單信息管理界面,調(diào)用后臺(tái)的 action 類查詢出所有的會(huì)員訂單信息,并把這些信息封轉(zhuǎn)到數(shù)據(jù)集合 List 中,綁定到request 對(duì)象,然后頁(yè)面跳轉(zhuǎn)到相應(yīng)的 jsp,顯示出會(huì)員訂單信息。2.程序效果圖如下圖 4-6 所示:16圖 4-6 會(huì)員訂單信息4.2.4 修改密碼1.描述:輸入用戶的原有密碼,輸入新密碼以后點(diǎn)擊修改按鈕即可修改密碼成功。2.程序效果圖如圖 4-7 所示:圖 4-7 修改密碼4.3 管理員功能模塊4.3.1 登錄系統(tǒng)1.描述:為了保證后臺(tái)管理系統(tǒng)的安全性,要使用本系統(tǒng),必須先登陸到系統(tǒng)中,管理員需要正確的賬號(hào)和密碼登錄本系統(tǒng)后臺(tái)管理。2.程序運(yùn)行效果圖如圖 4-8 所示:17圖 4-8 后臺(tái)系統(tǒng)登陸頁(yè)面設(shè)計(jì)4.3.2 管理員主頁(yè)面1.描述:管理員主頁(yè)面:左方頁(yè)面展示了管理員可操作的四大功能,進(jìn)入相關(guān)的管理頁(yè)面可以鏈接到子菜單,每個(gè)管理模塊下面都有相應(yīng)的子菜單。2.程序運(yùn)行效果圖如圖 4-9 所示:圖 4-9 管理員主頁(yè)面184.3.3 會(huì)員信息管理4.3.3.1 會(huì)員信息管理1.描述:管理員點(diǎn)擊左側(cè)的菜單“會(huì)員信息管理” ,頁(yè)面跳轉(zhuǎn)到會(huì)員信息管理界面,調(diào)用后臺(tái)的 action 類查詢出所有的會(huì)員信息,并把這些信息封轉(zhuǎn)到數(shù)據(jù)集合 List 中,綁定到 request對(duì)象,然后頁(yè)面跳轉(zhuǎn)到相應(yīng)的 jsp,顯示出會(huì)員信息。2.程序效果圖如下圖 4-10 所示圖 4-10 會(huì)員信息管理4.3.3.2 會(huì)員信息刪除1.描述:點(diǎn)擊會(huì)員信息管理,頁(yè)面跳轉(zhuǎn)到會(huì)員信息管理界面,瀏覽所有的會(huì)員信息,點(diǎn)擊要?jiǎng)h除的會(huì)員信息,彈出的確定對(duì)話框,即可刪除該會(huì)員信息。2.程序效果圖如圖 4-11 所示:圖 4-11 會(huì)員信息刪除4.3.4 車次信息管理4.3.4.1 查詢車次信息1.描述:管理員點(diǎn)擊左側(cè)的菜單“車19次信息管理” ,頁(yè)面跳轉(zhuǎn)到車次信息管理界面,調(diào)用后臺(tái)的 action 類查詢出所有的車次信息,并把這些信息封轉(zhuǎn)到數(shù)據(jù)集合 List 中,綁定到 request 對(duì)象,然后頁(yè)面跳轉(zhuǎn)到相應(yīng)的 jsp,顯示出車次信息。還可以通過(guò)輸入條件查找到對(duì)應(yīng)的車次,然后進(jìn)行編輯或刪除。2.程序效果圖如圖 4-12 所示:圖 4-12 查詢車次信息4.3.4.2 添加車次信息1.描述:管理員輸入車次相關(guān)正確信息后點(diǎn)擊提交按鈕,如果是沒(méi)有輸入完整的車次信息,都會(huì)給出相應(yīng)的錯(cuò)誤提示,不能錄入成功。輸入數(shù)據(jù)都通過(guò) form 表單中定義的方法onsubmit="return checkForm()"來(lái)檢查,checkForm()函數(shù)中是各種的校驗(yàn)輸入數(shù)據(jù)的方式。2.程序效果圖如圖 4-13 所示:圖 4-13 添加車次信息204.3.4.3 修改車次信息1.描述:點(diǎn)擊車次信息管理,頁(yè)面跳轉(zhuǎn)到車次信息管理界面,瀏覽所有的車次信息,點(diǎn)擊要修改的車次信息,跳轉(zhuǎn)到車次信息修改頁(yè)面修改該條車次信息。2.程序效果圖如下圖 4-14 所示圖 4-14 修改車次信息4.3.5 訂單信息管理4.3.5.1 訂單信息管理1.描述:管理員點(diǎn)擊左側(cè)的菜單“訂單信息管理” ,頁(yè)面跳轉(zhuǎn)到訂單信息管理界面,調(diào)用后臺(tái)的 action 類查詢出所有的訂單信息,并把這些信息封轉(zhuǎn)到數(shù)據(jù)集合 List 中,綁定到 request對(duì)象,然后頁(yè)面跳轉(zhuǎn)到相應(yīng)的 jsp,顯示出訂單信息。管理員可以對(duì)訂單進(jìn)行受理或刪除。2.程序效果圖如下圖 4-15 所示圖 4-15 訂單信息管理214.3.5.2 訂單信息刪除1.描述:點(diǎn)擊訂單信息管理,頁(yè)面跳轉(zhuǎn)到訂單信息界面,瀏覽所有的訂單信息,點(diǎn)擊要?jiǎng)h除的訂單信息,彈出的確定對(duì)話框,即可刪除該訂單信息。2.程序效果圖如圖 4-16 所示:圖 4-16 訂單信息刪除4.3.6 修改密碼1.描述:輸入管理員的原有密碼,輸入新密碼以后點(diǎn)擊修改按鈕即可修改密碼成功。2.程序效果圖如圖 4-17 所示:圖 4-17 修改密碼4.3.7 退出系統(tǒng)1.描述:點(diǎn)此按鈕回到系統(tǒng)的主頁(yè)面。2.程序效果圖如圖 4-18 所示:22圖 4-18 退出系統(tǒng)3.關(guān)鍵代碼:主要是通過(guò) javascript 語(yǔ)句來(lái)實(shí)現(xiàn),item_word84="退出" item_link84="javascript:window.open('./index.jsp','_self')" 23第五章 系統(tǒng)測(cè)試5.1 系統(tǒng)測(cè)試目的與意義系統(tǒng)測(cè)試是管理信息系統(tǒng)開(kāi)發(fā)周期中一個(gè)十分重要而漫長(zhǎng)的的階段。其重要性體現(xiàn)在他是保證系統(tǒng)質(zhì)量與可靠性的最后關(guān)口,是對(duì)整個(gè)系統(tǒng)開(kāi)發(fā)過(guò)程包括系統(tǒng)分析、系統(tǒng)設(shè)計(jì)和系統(tǒng)實(shí)現(xiàn)的最終審查。系統(tǒng)測(cè)試的任務(wù)是盡可能徹底的檢查出程序中的錯(cuò)誤,提高軟件系統(tǒng)的可靠性,其目的是檢驗(yàn)系統(tǒng)“做得怎樣” 。這這階段又可以分為三個(gè)步驟:模塊測(cè)試,測(cè)試每個(gè)模塊的程序是否正確;組裝測(cè)試,測(cè)試模塊之間的接口是否正確;確認(rèn)測(cè)試,測(cè)試整個(gè)軟件系統(tǒng)是否滿足用戶功能和性能的要求。測(cè)試發(fā)現(xiàn)問(wèn)題之后要經(jīng)過(guò)調(diào)試找出錯(cuò)誤原因和位置,然后進(jìn)行改正。是基于系統(tǒng)整體需求說(shuō)明書(shū)的黑盒測(cè)試,應(yīng)覆蓋系統(tǒng)隨偶聯(lián)合的部件 10-13。系統(tǒng)測(cè)試是正對(duì)整個(gè)產(chǎn)品系統(tǒng)進(jìn)行的測(cè)試,目的是驗(yàn)證系統(tǒng)是否滿足了需求規(guī)格的定義,找出需求規(guī)格不符合或與之矛盾的地方。5.2 測(cè)試過(guò)程在測(cè)試之初,由于將數(shù)據(jù)庫(kù)中的數(shù)據(jù)是隨便輸入,沒(méi)有實(shí)用性,為了使系統(tǒng)更加完善,在系統(tǒng)測(cè)試的過(guò)程中,本系統(tǒng)將一開(kāi)始編程隨便輸入的數(shù)據(jù)全部清理后,輸入了一些有效的測(cè)試數(shù)據(jù),這樣可以更真實(shí)的反映系統(tǒng)的功能實(shí)現(xiàn)情況。這樣不斷發(fā)現(xiàn)問(wèn)題,經(jīng)過(guò)反復(fù)的測(cè)試、調(diào)試,把問(wèn)題一個(gè)個(gè)的解決,最終系統(tǒng)可以正常運(yùn)行。5.2.1 主頁(yè)面的登錄模塊測(cè)試測(cè)試流程: 1.打開(kāi)系統(tǒng)首頁(yè),輸入錯(cuò)誤的登錄信息2.登錄3.輸入正確的登錄信息4.登錄5.測(cè)試結(jié)果模塊名稱 測(cè)試用例 預(yù)期結(jié)果 實(shí)際結(jié)果 是否通過(guò)登錄模塊 用戶名:null 密碼:null 彈出錯(cuò)誤提示,請(qǐng)輸入用戶名登陸失敗,提示請(qǐng)輸入用戶名通過(guò)登錄模塊 用戶名:m1 密碼:null 彈出錯(cuò)誤提示,請(qǐng)輸入密碼失敗,提示輸入密碼 通過(guò)24登錄模塊 用戶名:m1密碼:1 彈出錯(cuò)誤提示,用戶名或者密碼錯(cuò)誤登陸失敗,提示用戶名或者密碼錯(cuò)誤通過(guò)5.2.2 其他錯(cuò)誤在程序設(shè)計(jì)實(shí)現(xiàn)的過(guò)程中不可避免的會(huì)產(chǎn)生各種難以預(yù)料的錯(cuò)誤,如書(shū)寫(xiě)錯(cuò)誤、傳值類型不一致、參數(shù)傳遞問(wèn)題等等。這些都需要通過(guò)細(xì)心的檢測(cè)與不斷的調(diào)試才能夠排除。比如在action 配置時(shí)因粗心錯(cuò)誤導(dǎo)致運(yùn)行導(dǎo)致所報(bào)錯(cuò)誤,如圖 5-1 所示:圖 5-1 由于 action 配置錯(cuò)誤,運(yùn)行時(shí)的提示很多時(shí)候往往是一些小錯(cuò)誤,debug 難找到錯(cuò)誤所在,讓我調(diào)試半天。因此做系統(tǒng)一定要思維嚴(yán)謹(jǐn),編寫(xiě)代碼要認(rèn)真仔細(xì),做事要細(xì)致。25第六章 結(jié) 論本次畢業(yè)設(shè)計(jì)將我大學(xué)四年所學(xué)的軟件理論知識(shí)用到了具體的實(shí)踐中去,深化了理論知識(shí),同時(shí)也鍛煉了動(dòng)手實(shí)踐能力。在這段日子里,我查閱了許多有關(guān)火車票網(wǎng)上訂票系統(tǒng)的資料,翻閱了許多 JSP 的書(shū)籍,結(jié)合自己的經(jīng)驗(yàn),詳細(xì)調(diào)查了網(wǎng)上訂票=管理的工作內(nèi)容與細(xì)節(jié),開(kāi)發(fā)設(shè)計(jì)了這個(gè)火車訂票系統(tǒng),雖然每個(gè)學(xué)期都會(huì)有相應(yīng)課程的課程設(shè)計(jì)和實(shí)訓(xùn)來(lái)作為動(dòng)手練習(xí)訓(xùn)練,不過(guò)在本次畢業(yè)設(shè)計(jì)具體的實(shí)踐的時(shí)候還是遇到了很多小問(wèn)題,比如說(shuō)在 jsp 頁(yè)面將輸入框設(shè)為不可用是添加屬性 readonly=“true”,而我在實(shí)際編程中卻錯(cuò)寫(xiě)成 disable=“true”,這樣直接導(dǎo)致了 request 對(duì)象取不到數(shù)據(jù),調(diào)試了程序很久才發(fā)現(xiàn) request 對(duì)象獲得的返回值一直是空,之前一直以為是代碼哪里出了問(wèn)題,總是在查源程序的邏輯。這些雖然都是小問(wèn)題,但是由于不細(xì)心在具體實(shí)踐中卻浪費(fèi)了不少時(shí)間,看來(lái)平時(shí)還是要多多實(shí)踐才是。在系統(tǒng)的開(kāi)發(fā)過(guò)程中,我運(yùn)用到了 B/S 三層結(jié)構(gòu)技術(shù)和自己在平時(shí)學(xué)習(xí)中掌握的一些技術(shù),通過(guò)這些技術(shù)的實(shí)現(xiàn),整個(gè)系統(tǒng)的性能得到了大大的提高。這些技術(shù)都在論文中做了比較詳細(xì)的介紹。本系統(tǒng)還存在許多的缺陷和不足之處,比如很多細(xì)節(jié)上做的還不行,有些功能模塊還應(yīng)再加強(qiáng)。希望在以后的時(shí)間里,我可以把這些缺陷都彌補(bǔ)過(guò)來(lái),進(jìn)一步完善系統(tǒng)。通過(guò)本次畢業(yè)設(shè)計(jì)我鍛煉了自己的自學(xué)、研究能力,也從中學(xué)到不少在課堂上學(xué)不到的東西。通過(guò)實(shí)踐我也深刻的體會(huì)到軟件開(kāi)發(fā)的艱辛及問(wèn)題解決后的喜悅心情,培養(yǎng)我的獨(dú)立思考問(wèn)題的能力,同時(shí)也增強(qiáng)了我的理論聯(lián)系實(shí)際的能力,這為自己以后的工作奠定了良好的基礎(chǔ)。本系統(tǒng)可以在很大程度上增加人們售票的途徑,減少購(gòu)票的排隊(duì)時(shí)間,但由于時(shí)間按和技術(shù)條件的限制,還存在一些不足之處,有些功能還需要改進(jìn),還應(yīng)該做進(jìn)一步的系統(tǒng)調(diào)查需求分析工作,更深入的完善系統(tǒng)??傊?,一個(gè)緊跟時(shí)代步伐的真正使用的軟件必需有一個(gè)不斷完善改進(jìn)的過(guò)程。26致 謝本次設(shè)計(jì)歷時(shí)三個(gè)月。在本次畢業(yè)設(shè)計(jì)中,能夠基本順利的完成任務(wù),是與錢(qián)亞冠老師的耐心指導(dǎo)分不開(kāi)的。錢(qián)老師無(wú)論是在畢業(yè)設(shè)計(jì)過(guò)程中,還是在論文完成中都給予了我極大的幫助。同時(shí),錢(qián)老師認(rèn)真負(fù)責(zé)的工作態(tài)度,嚴(yán)謹(jǐn)?shù)闹螌W(xué)精神和深厚的理論水平都使我受益匪淺。他勤奮嚴(yán)謹(jǐn)?shù)慕虒W(xué)態(tài)度也給我留下了極為深刻的印象。我從老師身上學(xué)到了很多東西。在理論上還是在實(shí)踐中,我能力都得到不少的提高,這對(duì)于我以后的工作和學(xué)習(xí)都有一種巨大的幫助,在此,特向錢(qián)老師表示由衷的感謝。通過(guò)這次畢業(yè)設(shè)計(jì)的整個(gè)開(kāi)發(fā)過(guò)程,我系統(tǒng)開(kāi)發(fā)過(guò)程從需求分析到具體功能實(shí)現(xiàn),再到最終測(cè)試和維護(hù)的理解有了很大的進(jìn)步,讓我對(duì)系統(tǒng)開(kāi)發(fā)有了更深層次的認(rèn)識(shí)。現(xiàn)在我的動(dòng)手能力和獨(dú)立解決問(wèn)題的能力也得到了很大的鍛煉和提高,這是這次畢業(yè)設(shè)計(jì)最好的收獲。最后,在整個(gè)系統(tǒng)