jsp31超市管理系統(tǒng)(ssh)-qrp_第1頁
jsp31超市管理系統(tǒng)(ssh)-qrp_第2頁
jsp31超市管理系統(tǒng)(ssh)-qrp_第3頁
jsp31超市管理系統(tǒng)(ssh)-qrp_第4頁
jsp31超市管理系統(tǒng)(ssh)-qrp_第5頁
已閱讀5頁,還剩33頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

PAGEIV摘要隨著信息技術(shù)的發(fā)展及ERP系統(tǒng)的日益普及,計算機(jī)在超市管理中的作用越來越不容忽視。超市之間通過網(wǎng)絡(luò)交易的趨勢越來越明顯。在這種環(huán)境中,采購作為超市生產(chǎn)經(jīng)營的一個重要環(huán)節(jié)應(yīng)加強(qiáng)管理,充分利用外部環(huán)境條件,逐步實現(xiàn)超市物資采購的網(wǎng)絡(luò)化管理。超市管理系統(tǒng)是針對超市內(nèi)部而設(shè)計的,應(yīng)用于超市的局域網(wǎng),這樣可以使得超市內(nèi)部管理更有效的聯(lián)系起來。系統(tǒng)的主要功能包括:供貨商信息管理、商品信息管理、采購申請管理與物品采購管理。本系統(tǒng)前臺主要使用JSP作為開發(fā)語言,后臺使用Oracle作為數(shù)據(jù)庫管理系統(tǒng),開發(fā)環(huán)境是MyEclipse,服務(wù)器采用tomcat,開發(fā)出的一個基于Web技術(shù)的B/S結(jié)構(gòu)的鋁窗設(shè)計管理系統(tǒng)。關(guān)鍵詞:采購,JSP,B/S結(jié)構(gòu)

ABSTRACTWiththedevelopmentofinformationtechnologyandtheprevalenceoftheERPsystem,thecomputerinthebusinessmanagementintherolecannotbeignored.Betweenenterprisetransactionthroughthenetworkisbecomingmoreandmoreobvious.Inthisenvironment,procurementasanenterprisetomanufacturemanagementisanimportantlinkinmanagementshouldbestrengthened,makefulluseofexternalenvironmentcondition,theprogressiverealizationofenterprisematerialpurchasingnetworkmanagement.Equipmentprocurementmanagementsystemisfortheenterpriseinternalanddesign,applicationinenterpriseLAN,andthiscanmaketheenterpriseinternalmanagementmoreeffectiveconnection.Themainfunctionsofthissystemincludes:supplierinformationmanagement,officesuppliesinformationmanagement,thepurchasingapplicationmanagementandgoodspurchasemanagementThefrontofthesystemusingJSPasadevelopmentlanguage,theuseofOracleasadatabasemanagementsystem,thedevelopmentenvironmentisMyEclipse,serverusingtomcat,developedaWebtechnologybasedonB/Sstructurewindowsdesignmanagementsystem.Keywords:purchasing,JSP,B/Sstructure

目錄TOC\o"1-2"\h\z\t"標(biāo)題3,3,標(biāo)題4,4"摘要 IABSTRACT II第一章緒論 11.1課題背景 11.2目的和意義 11.3開發(fā)工具及技術(shù) 21.3.1開發(fā)工具 21.3.2JSP 31.3.3JavaScript 41.4軟硬件需求 4第二章需求分析 52.1需求調(diào)研 52.2可行性分析 52.2.1技術(shù)的可行性 52.2.2經(jīng)濟(jì)的可行性 52.2.3操作可行性 52.2.4法律的可行性 62.3系統(tǒng)用戶用例圖 62.3.1管理員用例圖 62.3.2操作員用例圖 62.4功能模塊需求分析 72.5設(shè)計的基本思想 82.6性能需求 92.6.1系統(tǒng)的安全性 92.6.2數(shù)據(jù)的完整性 92.7界面需求 9第三章系統(tǒng)分析與設(shè)計 113.1數(shù)據(jù)庫的分析與設(shè)計 113.1.1數(shù)據(jù)庫的概念結(jié)構(gòu)設(shè)計 113.1.2數(shù)據(jù)庫的邏輯結(jié)構(gòu)設(shè)計 143.1.3數(shù)據(jù)庫的連接原理 163.2中文亂碼問題處理 16第四章系統(tǒng)功能實現(xiàn) 194.1系統(tǒng)登陸頁面實現(xiàn) 194.2管理員模塊 214.2.1供貨商管理 224.2.2商品信息管理 274.2.3物品采購審批 324.2.4修改密碼 344.2.5退出系統(tǒng) 344.3操作員模塊 344.3.1采購審請管理 344.3.2物品采購管理 37第五章系統(tǒng)測試 415.1系統(tǒng)測試目的與意義 415.2測試過程 415.2.1主頁面的登錄模塊測試 415.3其他錯誤 42結(jié)論 43參考文獻(xiàn) 44致謝 45第一章緒論1.1課題背景采購是公司生產(chǎn)產(chǎn)品及維護(hù)正常運作而必須消耗的物品及必須配置的設(shè)施之購入活動的總稱,是公司成本控制的重點。目前絕大多數(shù)超市行使采購管理的職能部門為供應(yīng)部(科),也有超市將銷售職能與采購職能并在一起,稱為供銷科。在實際操作中有些流程如詢價/報價在很多超市中不是每次都進(jìn)行的,缺點是:物料管理、采購管理、供應(yīng)商管理由一個職能部門來完成,缺乏必要的監(jiān)督和控制機(jī)制。超市管理系統(tǒng),就是專門服務(wù)于超市物資采購的管理系統(tǒng)。。1.2目的和意義傳統(tǒng)采購的重點放在如何和供應(yīng)商進(jìn)行商業(yè)交易的活動上,特點是比較重視交易過程的供應(yīng)商的價格比較,通過供應(yīng)商的多頭競爭,從中選擇價格最低的作為合作者。傳統(tǒng)的采購模式的主要缺點表現(xiàn)在如下幾個方面。1.傳統(tǒng)采購過程是典型的非信息對稱博奕過程,選擇供應(yīng)商在傳統(tǒng)的采購活動中是一個首要的任務(wù)。在采購過程中,采購一方為了能夠從多個競爭性的供應(yīng)商中選擇一個最佳的供應(yīng)商,往往會保留私有信息,而供應(yīng)商也在和其他的供應(yīng)商競爭中隱瞞自己的信息。這樣,采購、供應(yīng)雙方都不進(jìn)行有效的信息溝通,這就是非信息對稱的博奕過程。2.驗收檢查是采購部門的一個重要的事后把關(guān)工作,質(zhì)量控制難度大采購一方很難參與供應(yīng)商的生產(chǎn)組織過程和有關(guān)質(zhì)量控制活動,相互的工作是不透明的。因此需要通過各種有關(guān)標(biāo)準(zhǔn)如國際標(biāo)準(zhǔn)、國家標(biāo)準(zhǔn)等,進(jìn)行檢查驗收。缺乏合作的質(zhì)量控制會導(dǎo)致采購部門對采購物品質(zhì)量控制的難度增加。3.供需關(guān)系是臨時的或短期的合作關(guān)系,而且競爭多于合作由于缺乏合作與協(xié)調(diào),采購過程中各種抱怨和扯皮的事情比較多,很多時間消耗在解決日常問題上,沒有更多的時間用來做長期預(yù)測與計劃工作,供應(yīng)與需求之間這種缺乏合作的氣氛增加了許多運作中的不確定性。4.響應(yīng)用戶需求能力遲鈍由于供應(yīng)與采購雙方在信息的溝通方面缺乏及時的信息反饋,在市場需求發(fā)生變化的情況下,采購一方也不能改變供應(yīng)一方已有的訂貨合同,因此采購一方在需求減少時庫存增加,需求增加時,出現(xiàn)供不應(yīng)求。重新訂貨需要增加談判過程,因此供需之間對用戶需求的響應(yīng)沒有同步進(jìn)行,缺乏應(yīng)付需求變化的能力。正確的采購能夠使供應(yīng)鏈系統(tǒng)能夠?qū)崿F(xiàn)無縫連接,并提高同一供應(yīng)鏈上超市的同步化運作效率。1.3開發(fā)工具及技術(shù)1.3.1開發(fā)工具此次設(shè)計主要采用MyEclipse加Tomcat后臺服務(wù)器進(jìn)行,設(shè)計過程中頁面主要使用JSP技術(shù)完成,下面對MyEclipse、Tomcat和Oracle數(shù)據(jù)庫進(jìn)行簡要介紹。MyEclipseMyEclipse,是一個十分優(yōu)秀的用于開發(fā)Java,J2EE的Eclipse插件集合,MyEclipse的功能非常強(qiáng)大,支持也十分廣泛,尤其是對各種開元產(chǎn)品的支持十分不錯。MyEclipse超市級工作平臺(MyEclipseEnterpriseWorkbench,簡稱MyEclipse)是對EclipseIDE的擴(kuò)展,利用它我們可以在數(shù)據(jù)庫和JavaEE的開發(fā)、發(fā)布,以及應(yīng)用程序服務(wù)器的整合方面極大的提高工作效率。它是功能豐富的JavaEE集成開發(fā)環(huán)境,包括了完備的編碼、調(diào)試、測試和發(fā)布功能,完整支持HTML,Struts,JSP,CSS,Javascript,SQL,Hibernate。TomcatTomcat是一個小型的輕量級應(yīng)用服務(wù)器,在中小型系統(tǒng)和并發(fā)訪問用戶不是很多的場合下被普遍使用,是開發(fā)和調(diào)試JSP程序的首選??梢赃@樣認(rèn)為,當(dāng)在一臺機(jī)器上配置好Apahce服務(wù)器,可利用它響應(yīng)對HTML頁面的訪問請求。實際上Tomcat部分是Apache服務(wù)器的擴(kuò)展,但它是獨立運行的,所以當(dāng)運行tomcat時,它實際上作為一個與Apache獨立的進(jìn)程單獨運行的。OracleOracle是以高級結(jié)構(gòu)化查詢語言(SQL)為基礎(chǔ)的大型關(guān)系數(shù)據(jù)庫,通俗地講它是用方便邏輯管理的語言操縱大量有規(guī)律數(shù)據(jù)的集合。是目前最流行的客戶/服務(wù)器(CLIENT/SERVER)體系結(jié)構(gòu)的數(shù)據(jù)庫之一。ORACLE7.X以來引入了共享SQL和多線索服務(wù)器體系結(jié)構(gòu)。這減少了ORACLE的資源占用,并增強(qiáng)了ORACLE的能力,使之在低檔軟硬件平臺上用較少的資源就可以支持更多的用戶,而在高檔平臺上可以支持成百上千個用戶。提供了基于角色(ROLE)分工的安全保密管理。在數(shù)據(jù)庫管理功能、完整性檢查、安全性、一致性方面都有良好的表現(xiàn).支持大量多媒體數(shù)據(jù),如二進(jìn)制圖形、聲音、動畫以及多維數(shù)據(jù)結(jié)構(gòu)等。提供了與第三代高級語言的接口軟件PRO*系列,能在C,C++等主語言中嵌入SQL語句及過程化(PL/SQL)語句,對數(shù)據(jù)庫中的數(shù)據(jù)進(jìn)行操縱。加上它有許多優(yōu)秀的前臺開發(fā)工具如POWERBUILD、SQL*FORMS、VISIABASIC等,可以快速開發(fā)生成基于客戶端PC平臺的應(yīng)用程序,并具有良好的移植性。提供了新的分布式數(shù)據(jù)庫能力??赏ㄟ^網(wǎng)絡(luò)較方便地讀寫遠(yuǎn)端數(shù)據(jù)庫里的數(shù)據(jù),并有對稱復(fù)制的技術(shù)。1.3.2JSPJSP技術(shù)使用Java編程語言編寫類XML的tags和scriptlets,來封裝產(chǎn)生動態(tài)網(wǎng)頁的處理邏輯。網(wǎng)頁還能通過tags和scriptlets訪問存在于服務(wù)端的資源的應(yīng)用邏輯。JSP將網(wǎng)頁邏輯與網(wǎng)頁設(shè)計和顯示分離,支持可重用的基于組件的設(shè)計,使基于Web的應(yīng)用程序的開發(fā)變得迅速和容易。Web服務(wù)器在遇到訪問JSP網(wǎng)頁的請求時,首先執(zhí)行其中的程序段,然后將執(zhí)行結(jié)果連同JSP文件中的HTML代碼一起返回給客戶。插入的Java程序段可以操作數(shù)據(jù)庫、重新定向網(wǎng)頁等,以實現(xiàn)建立動態(tài)網(wǎng)頁所需要的功能。JSP與Servlet一樣,是在服務(wù)器端執(zhí)行的,通常返回給客戶端就是一個HTML文本,因此客戶端只要有瀏覽器能瀏覽。JSP頁面由HTML代碼和嵌入其中的Java代碼所組成。服務(wù)器在頁面被客戶端請求以后對這些Java代碼進(jìn)行處理,然后將生成的HTML頁面返回給客戶端的瀏覽器。Servlet是JSP的技術(shù)基礎(chǔ),而且大型的Web應(yīng)用程序的開發(fā)需要JavaServlet和JSP配合才能完成。JSP具備了Java技術(shù)的簡單易用,完全的面向?qū)ο?,具有平臺無關(guān)性且安全可靠,主要面向因特網(wǎng)的所有特點。JSP技術(shù)的優(yōu)點:(1)一次編寫,到處運行。除了系統(tǒng)之外,代碼不用做任何更改。(2)系統(tǒng)的多平臺支持?;旧峡梢栽谒衅脚_上的任意環(huán)境中開發(fā),在任意環(huán)境中進(jìn)行系統(tǒng)部署,在任意環(huán)境中擴(kuò)展。相比ASP/.net的局限性是顯而易見的。(3)強(qiáng)大的可伸縮性。從只有一個小的Jar文件就可以運行Servlet/JSP,到由多臺服務(wù)器進(jìn)行集群和負(fù)載均衡,到多臺Application進(jìn)行事務(wù)處理,消息處理,一臺服務(wù)器到無數(shù)臺服務(wù)器,Java顯示了一個巨大的生命力。(4)多樣化和功能強(qiáng)大的開發(fā)工具支持。Java已經(jīng)有了許多非常優(yōu)秀的開發(fā)工具,而且許多可以免費得到,并且其中許多已經(jīng)可以順利的運行于多種平臺之下(5)支持服務(wù)器端組件。web應(yīng)用需要強(qiáng)大的服務(wù)器端組件來支持,開發(fā)人員需要利用其他工具設(shè)計實現(xiàn)復(fù)雜功能的組件供web頁面調(diào)用,以增強(qiáng)系統(tǒng)性能。JSP可以使用成熟的JAVABEANS組件來實現(xiàn)復(fù)雜商務(wù)功能。內(nèi)部對象說明:request客戶端請求,此請求會包含來自GET/POST請求的參數(shù);response網(wǎng)頁傳回客戶端的響應(yīng);pageContext網(wǎng)頁的屬性是在這里管理;session與請求有關(guān)的會話;applicationservlet正在執(zhí)行的內(nèi)容;out用來傳送響應(yīng)的輸出流;config代碼片段配置對象;pageJSP網(wǎng)頁本身;exception針對錯誤網(wǎng)頁,未捕捉的例外1.3.3JavaScriptJavaScript是一種基于對象和事件驅(qū)動并具有相對安全性的客戶端腳本語言。同時也是一種廣泛用于客戶端Web開發(fā)的腳本語言,常用來給HTML網(wǎng)頁添加動態(tài)功能,比如響應(yīng)用戶的各種操作。JavaScript的一個重要功能就是面向?qū)ο蟮墓δ?,通過基于對象的程序設(shè)計,可以用更直觀、模塊化和可重復(fù)使用的方式進(jìn)行程序開發(fā)。在HTML基礎(chǔ)上,使用Javascript可以開發(fā)交互式Web網(wǎng)頁。Javascript的出現(xiàn)使得網(wǎng)頁和用戶之間實現(xiàn)了一種實時性的、動態(tài)的、交互性的關(guān)系,使網(wǎng)頁包含更多活躍的元素和更加精彩的內(nèi)容。在本系統(tǒng)中很多地方使用了javascript技術(shù),比如說,檢驗用戶輸入數(shù)據(jù)的有效性,是否重復(fù),是否為空等等。1.4軟硬件需求硬件需求:CPU:Pentium以上計算機(jī)內(nèi)存:512M以上軟件需求:操作系統(tǒng)版本:WindowsXP/vista/Win7開發(fā)工具:MyEclipse6.0.1后臺服務(wù)器:ApacheTomcat6.0開發(fā)語言:Java瀏覽器:IE6.0第二章需求分析2.1需求調(diào)研在項目的開始是需求調(diào)研,并且走訪了一些中心型私營超市,經(jīng)過一系列的調(diào)查與談話中發(fā)現(xiàn),現(xiàn)行的公司商品采購工作還是存在著很多不足之處,采購申請與供貨商信息采用分散方式管理,不易保存,容易丟失,同樣也不利于數(shù)據(jù)的查詢和統(tǒng)計分析。根據(jù)實際情況及調(diào)查結(jié)果,發(fā)現(xiàn)實現(xiàn)設(shè)備采購管理的網(wǎng)絡(luò)化、信息化是十分有必要的,因此設(shè)計了超市管理系統(tǒng)。2.2可行性分析開發(fā)任何一個系統(tǒng),都會受到時間和資源上的限制。因此,在每一個項目開發(fā)之前,都要進(jìn)行可行性分析,可以減少項目的開發(fā)風(fēng)險,避免人力、物力和財力的浪費。下面就技術(shù)、經(jīng)濟(jì)、操作和法律四個方面來介紹。2.2.1技術(shù)的可行性本系統(tǒng)開發(fā)工具是MyEclipse和Oracle數(shù)據(jù)庫,開發(fā)語言是Java,主要使用了J2EE的技術(shù),java是一種面向?qū)ο缶幊陶Z言,簡單易學(xué)而且靈活方便。大三時就學(xué)習(xí)了java課程,大四期間也系統(tǒng)的了解了J2EE的知識,協(xié)議供貨管理系統(tǒng)總體上開發(fā)難度不高,數(shù)據(jù)庫的設(shè)計和操作是本系統(tǒng)設(shè)計的核心。在大學(xué)期間學(xué)習(xí)過軟件工程,軟件測試,UML統(tǒng)一建模語言等課程,每個學(xué)期也會完成對應(yīng)的課程設(shè)計,具備一定的系統(tǒng)分析、設(shè)計和測試能力。因此,完成系統(tǒng)實現(xiàn)在技術(shù)上完全具有可行性。2.2.2經(jīng)濟(jì)的可行性如今是信息化時代,信息化管理可以使商品采購工作更加系統(tǒng)化、快速化、全面化。這樣可以為超市帶來較高的工作效益和經(jīng)濟(jì)效益,本系統(tǒng)對計算機(jī)配置的要求不高,超市機(jī)房更換下來的低配置電腦都可以完全滿足需要,再者,超市在管理工作上的高效率和便捷性遠(yuǎn)遠(yuǎn)超過了開發(fā)本系統(tǒng)的成本,所以在經(jīng)濟(jì)上具有完全的可行性。2.2.3操作可行性本系統(tǒng)操作簡單,輸入信息頁面大多數(shù)都是下拉框的選擇形式,在某些頁面,信息可以自動生成,無需輸入,時間的輸入也是用的日歷控件,操作簡便,對操作人員的要求很低,只需對WINDOWS操作熟練,加之對本系統(tǒng)的操作稍加培訓(xùn)即可工作,而且本系統(tǒng)可視性非常好,所以在技術(shù)上不會有很大難度。2.2.4法律的可行性超市管理系統(tǒng)是自行開發(fā)的管理系統(tǒng),是很有實際意義的系統(tǒng),開發(fā)環(huán)境軟件和使用的數(shù)據(jù)庫都是開源代碼,開發(fā)這個系統(tǒng)不同于開發(fā)普通的系統(tǒng)軟件,不存在侵權(quán)等問題,即法律上是可行的。綜上所述,開發(fā)超市管理系統(tǒng)與人工記錄的方式相比具有速度更快,操作更準(zhǔn)確,節(jié)省開支等有利之處,因此,建立一個超市管理系統(tǒng)是必要可行的。2.3系統(tǒng)用戶用例圖2.3.1管理員用例圖管理員是系統(tǒng)的核心用戶,涉及到三大功能模塊,管理員對系統(tǒng)的供貨商與商品有著操作的權(quán)限,能夠?qū)Σ少徤暾堖M(jìn)行審批操作。圖2.1管理員用例圖2.3.2操作員用例圖操作員負(fù)責(zé)平日商品采購申請及具體采購工作。圖2.2操作員用例圖2.4功能模塊需求分析本系統(tǒng)最大的特點是使用操作簡單、友好的提示信息。本系統(tǒng)將實現(xiàn)以下基本功能:(1)系統(tǒng)具有簡潔大方的頁面,使用簡便,友好的錯誤操作提示(2)管理員用戶具有采購商管理、辦公物品管理、采購申請審批管理管理功能(3)操作員用戶具體采購申請管理、物品采購管理功能(3)具有較強(qiáng)的安全性,避免用戶的惡意操作系統(tǒng)的功能結(jié)構(gòu)圖,分做操作員平臺,管理員平臺。操作員用戶功能模塊圖說明:操作員通過自己的賬號和密碼進(jìn)入本系統(tǒng),可以瀏覽物品信息、發(fā)起采購申請、添加采購物品、打印采購信息,如功能圖2.3所示圖2.3操作員用戶功能模塊圖管理員功能模塊圖說明:管理員是功能最多的一種用戶角色。(1)供貨商管理模塊:在該模塊中定義了供貨商的管理,其功能包括供貨商錄入、查詢、修、刪除等操作。(2)商品信息管理模塊:在該模塊中定義了對商品信息的管理,其功能包括商品信息錄入、查詢、修改、刪除等操作。(3)物品采購審核模塊:在該模塊中定義了對采購信息的管理,其功能包括采購信息瀏覽、審批等操作。管理員用戶功能模塊圖如下。圖2.4管理員用戶功能模塊圖2.5設(shè)計的基本思想設(shè)計思想遵循以下幾點:1.采用B/S模式進(jìn)行開發(fā),其優(yōu)點是后臺與前臺處理層次分明,而且符合眾多已經(jīng)習(xí)慣網(wǎng)頁方式的用戶。2.采用面向?qū)ο蟮拈_發(fā)與設(shè)計理念。運用面向?qū)ο蠹夹g(shù)的前提是對整體系統(tǒng)的高度和準(zhǔn)確抽象,通過它可以保證系統(tǒng)良好的框架,進(jìn)而帶來產(chǎn)品較強(qiáng)的穩(wěn)定性和運行效率。3.采用模塊化設(shè)計。模塊化設(shè)計要求將整個系統(tǒng)劃分成基于小的模塊,有利于代碼的重載,簡化設(shè)計和實現(xiàn)過程。4.簡單方便的系統(tǒng)界面。設(shè)計簡單友好的系統(tǒng)界面,方便用戶較快的適應(yīng)系統(tǒng)的操作。5.速度優(yōu)先原則。由于此工具最重要的評測標(biāo)準(zhǔn)就是速度,因此在設(shè)計過程中,具體過程盡量做到資源占用少,速度快。6.設(shè)計既要突出重點,又要細(xì)致周到。要符合設(shè)計需求,在有可能改進(jìn)的地方進(jìn)行擴(kuò)充,使系統(tǒng)更適應(yīng)用戶的需要。2.6性能需求2.6.1系統(tǒng)的安全性協(xié)議供貨管理系統(tǒng)在管理權(quán)限上要嚴(yán)格進(jìn)行控制,具體要求如下:1.想登協(xié)議供貨管理系統(tǒng)進(jìn)行操作,必須有某些操作權(quán)限,沒有權(quán)限的用戶不能通過任何方式登錄系統(tǒng)查看系統(tǒng)的任何信息和數(shù)據(jù),以確保系統(tǒng)的嚴(yán)密性和安全性。2.在具體實現(xiàn)中設(shè)定不同權(quán)限,不同權(quán)限用戶登錄到系統(tǒng)后,不能越級操作,管理員可以對數(shù)據(jù)進(jìn)行增刪改操作;操作員用戶只具有瀏覽和增加操作。2.6.2數(shù)據(jù)的完整性1.各種記錄信息的完整性,信息記錄內(nèi)容不能為空2.各種數(shù)據(jù)間相互聯(lián)系的正確性3.相同數(shù)據(jù)在不同記錄中的一致性2.7界面需求界面設(shè)計目前已經(jīng)成為評價軟件質(zhì)量的一條重要指標(biāo),一個好的用戶界面可以增加用戶使用系統(tǒng)的信心和興趣,提高工作效率,JSP技術(shù)是用JAVA語言作為腳本語言的,JSP網(wǎng)頁為整個服務(wù)器端的JAVA庫單元提供了一個接口來服務(wù)于HTTP的應(yīng)用程序。創(chuàng)建動態(tài)頁面非常方便。用戶界面是指軟件系統(tǒng)與用戶交互的接口,通常包括輸出、輸入、人-機(jī)對話的界面格式等。1.輸出設(shè)計輸出是由計算機(jī)對輸入的原始信息進(jìn)行加工處理,形成高質(zhì)量的有效信息,并使之具有一定的格式,提供管理者使用,這是輸出設(shè)計的主要職責(zé)和目標(biāo)。系統(tǒng)設(shè)計的過程正好和實施過程相反,并不是從輸入設(shè)計到輸出設(shè)計,而是從輸出設(shè)計到輸入設(shè)計,這是因為輸出表格直接與使用者相聯(lián)系,設(shè)計的出發(fā)點應(yīng)當(dāng)是保證輸出表格方便地為使用者服務(wù),正確及時反映和組成用于各部門的有用信息。輸出設(shè)計的原則是考慮既要全面反映不同管理層的各項需要,又要言簡意賅,不要將用戶需要和不需要的都提供給用戶。2.輸入設(shè)計輸入數(shù)據(jù)的收集和錄入是比較費事的,需要大量的人力和一定設(shè)備,并且容易出錯。如果輸入系統(tǒng)的數(shù)據(jù)有錯誤,則處理后的輸出將擴(kuò)大這些錯誤,因此輸入數(shù)據(jù)的正確性對于整個系統(tǒng)質(zhì)量的好壞是具有決定性意義的。輸入設(shè)計的原則有如下幾點:1)輸入量應(yīng)保持在能滿足處理要求的最低限度。設(shè)計中可采用設(shè)置字段初值,下拉式數(shù)據(jù)窗口等方式盡量減少用戶鍵盤輸入量。輸入量越少,錯誤率就越少,數(shù)據(jù)準(zhǔn)備時間也減少。2)輸入的準(zhǔn)備及輸入過程應(yīng)盡量容易進(jìn)行,從而減少錯誤的發(fā)生。3)應(yīng)盡量早對輸入數(shù)據(jù)進(jìn)行檢查(盡量接近原數(shù)據(jù)發(fā)生點),以便使錯誤及時得到更正。4)輸入數(shù)據(jù)盡早地用其處理所需的形式被記錄,以避免數(shù)據(jù)由一種介質(zhì)轉(zhuǎn)移到另一種介質(zhì)時需要轉(zhuǎn)錄而可能發(fā)生的錯誤第三章系統(tǒng)分析與設(shè)計3.1數(shù)據(jù)庫的分析與設(shè)計計算機(jī)信息系統(tǒng)以數(shù)據(jù)庫為核心,在數(shù)據(jù)庫管理系統(tǒng)的支持下,進(jìn)行信息的收集、整理、存儲、檢索、更新、加工、統(tǒng)計和傳播等操作。數(shù)據(jù)庫已經(jīng)成為現(xiàn)在信息系統(tǒng)等計算機(jī)系統(tǒng)的基礎(chǔ)與核心部分。數(shù)據(jù)庫設(shè)計的好壞直接影響到整個系統(tǒng)的質(zhì)量和效率。數(shù)據(jù)庫的設(shè)計一般經(jīng)過規(guī)劃。需求分析、概念設(shè)計、邏輯設(shè)計、物理設(shè)計5個步驟。3.1.1數(shù)據(jù)庫的概念結(jié)構(gòu)設(shè)計概念設(shè)計是指在數(shù)據(jù)分析的基礎(chǔ)上自底向上的建立整個系統(tǒng)的數(shù)據(jù)庫概念結(jié)構(gòu),從用戶的角度進(jìn)行視圖設(shè)計,然后將視圖集成,最后對集成的結(jié)構(gòu)分析優(yōu)化得到最后結(jié)果。數(shù)據(jù)庫的概念結(jié)構(gòu)設(shè)計采用實體—聯(lián)系(E-R)模型設(shè)計方法。E-R模型法的組成元素有:實體、屬性、聯(lián)系,E-R模型用E-R圖表示,是提示用戶工作環(huán)境中所涉及的事物,屬性則是對實體特性的描述。概念設(shè)計的目標(biāo)是產(chǎn)生反映超市組織信息要求的數(shù)據(jù)庫概念結(jié)構(gòu),即概念模式。概念模式是獨立于數(shù)據(jù)庫邏輯結(jié)構(gòu),獨立于支持?jǐn)?shù)據(jù)庫的DBMS,不依賴于計算機(jī)系統(tǒng)的,根據(jù)以上對數(shù)據(jù)庫的需求分析,并結(jié)合系統(tǒng)概念模型的特點及建立方法,建立E-R模型圖。實體間關(guān)系屬性實體實體間關(guān)系屬性實體(1)供貨商信息實體E-R圖如圖3.1所示:圖3.1供貨商信息實體E-R圖(2)商品信息實體E-R圖如圖3.2所示圖3.2商品信息實體E-R圖(3)采購申請信息E-R圖如圖3.3所示圖3.3采購申請信息實體E-R圖(4)采購名細(xì)信息E-R圖如圖3.4所示圖3.4采購名細(xì)信息實體E-R圖(5)管理員信息E-R圖如圖3.5所示圖3.5管理員實體E-R圖(6)操作員信息E-R圖如圖3.6所示圖3.6管理員信息實體E-R圖3.1.2數(shù)據(jù)庫的邏輯結(jié)構(gòu)設(shè)計我們知道,數(shù)據(jù)庫概念模型獨立于任何特定的數(shù)據(jù)庫管理系統(tǒng),因此,需要根據(jù)具體使用的數(shù)據(jù)庫管理系統(tǒng)的特點進(jìn)行轉(zhuǎn)換。即轉(zhuǎn)化為按計算機(jī)觀點處理的邏輯關(guān)系模型,E-R模型向關(guān)系數(shù)據(jù)庫模型轉(zhuǎn)換應(yīng)遵循下列原則:*每一個實體要轉(zhuǎn)換成一個關(guān)系*所有的主鍵必須定義非空(NOTNULL)*對于二元聯(lián)系應(yīng)按照一對多、弱對實、一對一、多對多等聯(lián)系來定義外鍵。根據(jù)E-R模型,鋁窗設(shè)計管理系統(tǒng)建立了以下邏輯數(shù)據(jù)結(jié)構(gòu),下面是各數(shù)據(jù)表的詳細(xì)說明。(1)供貨商信息表主要是記錄了供貨商基本信息。表結(jié)構(gòu)如表3.1所示。表3.1供貨商信息表(t_gong)列名數(shù)據(jù)類型長度允許空是否主鍵說明idint4否是主鍵bianhaovarchar50否否供貨商編號mingchengvarchar50否否供貨商名稱dizhivarchar50否否供貨商地址dianhuavarchar50否否供貨商聯(lián)系電話emailvarchar50否否供貨商emailbeizhuvarchar20否否備注(2)商品信息表主要是記錄了商品的基本信息,表結(jié)構(gòu)如表3.2所示。表3.2商品信息表(t_goods)列名數(shù)據(jù)類型長度允許空是否主鍵說明idInt4否是主鍵bianhaovarchar 50否否商品編號mingchengvarchar50否否商品名稱liebievarchar50否否類別pinpaivarchar50否否品牌xinghaovarchar50否否型號guigevarchar50否否規(guī)格beizhuvarchar50否否備注(3)采購申請信息表主要是采購申請的基本信息,表結(jié)構(gòu)如表3.3所示。表3.3采購申請信息表(t_shenqing)列名數(shù)據(jù)類型長度允許空是否主鍵說明idInt4否是主鍵goods_idInt4否否設(shè)備IDshuliangvarchar50否否申請數(shù)量shenqinshijianvarchar50否否申請時間beizhuvarchar50否否備注zhuangtaiInt4否否當(dāng)前狀態(tài)huifuvarchar50否否審批意見(4)設(shè)備采購申請信息表主要是采購內(nèi)容的基本信息,表結(jié)構(gòu)如表3.4所示。表3.4采購申請信息表(t_caigou)列名數(shù)據(jù)類型長度允許空是否主鍵說明idInt4否是主鍵goods_idInt4否否設(shè)備IDgong_idInt4否否供貨商IDcaigoushijianvarchar50否否采購時間shuliangvarchar50否否采購數(shù)量caigoujiavarchar50否否采購價beizhuInt4否否備注(5)管理員信息表主要記錄管理員的賬號信息,包括用戶名和密碼,表結(jié)構(gòu)如表3.5所示。表3.5管理員信息表(t_admin)列名數(shù)據(jù)類型長度允許空是否主鍵說明userIdint4否是編號userNamevarchar50否否用戶名userPwvarchar50否否密碼(6)操作員信息表主要記錄操作員的賬號信息,包括用戶名、密碼和姓名,表結(jié)構(gòu)如表3.6所示。表3.6操作員信息表(t_caozuoyuan)列名數(shù)據(jù)類型長度允許空是否主鍵說明userIdint4否是編號userNamevarchar50否否用戶名userPwvarchar50否否密碼xingmingvarchar50否否操作員姓名3.1.3數(shù)據(jù)庫的連接原理采用JDBC連接數(shù)據(jù)庫的方式,只需在工程中導(dǎo)入對應(yīng)數(shù)據(jù)庫的jar包,就可以方便的對數(shù)據(jù)庫進(jìn)行連接,在程序中,用Class.forName()方法來加載驅(qū)動程序,在用DriverManager的getConnection()方法就可以創(chuàng)建一個數(shù)據(jù)庫連接。程序采用的是DAO模式來操作數(shù)據(jù)庫,DAO(DataAccessObject,數(shù)據(jù)訪問對象),是Java編程中的一種經(jīng)典模式,已被廣泛應(yīng)用,也是J2EE架構(gòu)中持久層框架的基礎(chǔ)知識,基于分層次式的軟件架構(gòu)來實現(xiàn)對數(shù)據(jù)庫的訪問操作。DAO模式的主要思想就是從抽象數(shù)據(jù)源獲取與操縱數(shù)據(jù)的方法。抽象數(shù)據(jù)的含義就是編寫應(yīng)用程序的程序員不必關(guān)心數(shù)據(jù)庫的物理位置,已經(jīng)是何種數(shù)據(jù)庫,只需使用封裝數(shù)據(jù)庫中表示記錄的數(shù)據(jù)對象即可。其思想如圖3.10所示:封裝使用封裝使用DataSourceDataAccessObjectBusinessObjectDataSourceDataAccessObjectBusinessObject創(chuàng)建/使用獲取/修改創(chuàng)建/使用獲取/修改DataTransferObjectDataTransferObject圖3.7DAO模式類圖3.2中文亂碼問題處理在程序中經(jīng)常會遇到中文亂碼的情況,如果手動的在servlet和jsp頁面進(jìn)行設(shè)置,相當(dāng)麻煩。因此,在程序的開始就寫了一個過濾器SetCharacterEncodingFilter。在web.xml中配置:<filter><filter-name>SetCharacterEncodingFilter</filter-name><filter-class>myweb.util.filter.SetCharacterEncodingFilter</filter-class><init-param><param-name>encoding</param-name><param-value>gb2312</param-value></init-param></filter><filter-mapping><filter-name>SetCharacterEncodingFilter</filter-name><url-pattern>/*</url-pattern>//*表示工程下所有的頁面都會有此過濾器的處理</filter-mapping>對應(yīng)的SetCharacterEncodingFilter.java文件中的重要代碼,在初始化init()方法中定義:publicvoidinit(FilterConfigfilterConfig)throwsServletException{ this.filterConfig=filterConfig;this.encoding=filterConfig.getInitParameter("encoding");Stringvalue=filterConfig.getInitParameter("ignore");}在工具包util包中同樣定義了DataFormate類來處理字符轉(zhuǎn)換:publicstaticStringtoUni(StringgbStr){StringuniStr="";/*把字符串轉(zhuǎn)換成uincode編碼*/if(gbStr==null){gbStr="";}try{byte[]tempByte=gbStr.getBytes("GB2312");uniStr=newString(tempByte,"ISO8859_1");}catch(Exceptionex){}returnuniStr;}/*把字符串轉(zhuǎn)換成Utf8編碼*/publicstaticStringtoUtf8String(Strings){StringBuffersb=newStringBuffer();for(inti=0;i<s.length();i++){charc=s.charAt(i);if(c>=0&&c<=255){sb.append(c);}else{byte[]b;try{b=Character.toString(c).getBytes("utf-8");}catch(Exceptionex){System.out.println(ex);b=newbyte[0];}for(intj=0;j<b.length;j++){intk=b[j];if(k<0){k+=256;}sb.append("%"+Integer.toHexString(k).toUpperCase());}} returnsb.toString();}第四章系統(tǒng)功能實現(xiàn)在管理信息系統(tǒng)的生命周期中,經(jīng)過了需求分析、系統(tǒng)設(shè)計等階段之后,便開始了系統(tǒng)實施階段。在系統(tǒng)分析和設(shè)計階段,系統(tǒng)開發(fā)工作主要是集中在邏輯、功能和技術(shù)設(shè)計上,系統(tǒng)實施階段要繼承此前面各個階段的工作成果,將技術(shù)設(shè)計轉(zhuǎn)化為物理實現(xiàn),因此系統(tǒng)實施的成果是系統(tǒng)分析和設(shè)計階段的結(jié)晶。4.1系統(tǒng)登陸頁面實現(xiàn)1.描述:為了保證系統(tǒng)的安全性,要先使用本系統(tǒng)必須先登陸到系統(tǒng)中,并且不同角色的用戶進(jìn)入不同的界面,功能也隨之不同。2.程序運行效果圖如圖4.1所示:圖4.1系統(tǒng)登陸頁面設(shè)計3.在登陸頁面輸入用戶名和密碼以,點擊提交按鈕,跳轉(zhuǎn)到登陸的service中,在該service中會對用戶名,密碼,驗證碼進(jìn)行判斷,驗證通過進(jìn)入對應(yīng)的頁面,loginservice關(guān)鍵代碼: publicStringlogin(StringuserName,StringuserPw,intuserType) { Stringresult="no"; if(userType==0)//系統(tǒng)管理員登陸 { Stringsql="select*fromt_adminwhereuserName=?anduserPw=?"; Object[]params={userName,userPw}; DBmydb=newDB(); mydb.doPstm(sql,params); try { ResultSetrs=mydb.getRs(); booleanmark=(rs==null||!rs.next()?false:true); if(mark==false) { result="no"; } else { result="yes"; TAdminadmin=newTAdmin(); admin.setUserId(rs.getInt("userId")); admin.setUserName(rs.getString("userName")); admin.setUserPw(rs.getString("userPw")); WebContextctx=WebContextFactory.get(); HttpSessionsession=ctx.getSession(); session.setAttribute("userType",0); session.setAttribute("admin",admin); } rs.close(); } catch(SQLExceptione) { System.out.println("登錄失敗!"); e.printStackTrace(); } finally { mydb.closed(); } } if(userType==1) { Stringsql="select*fromt_caozuoyuanwhereuserName=?anduserPw=?"; Object[]params={userName,userPw}; DBmydb=newDB(); mydb.doPstm(sql,params); try { ResultSetrs=mydb.getRs(); booleanmark=(rs==null||!rs.next()?false:true); if(mark==false) { result="no"; } else { result="yes"; TCaozuoyuancaozuoyuan=newTCaozuoyuan(); caozuoyuan.setUserId(rs.getInt("userId")); caozuoyuan.setUserName(rs.getString("userName")); caozuoyuan.setUserPw(rs.getString("userPw")); caozuoyuan.setXingming(rs.getString("xingming")); WebContextctx=WebContextFactory.get(); HttpSessionsession=ctx.getSession(); session.setAttribute("userType",1); session.setAttribute("caozuoyuan",caozuoyuan); } rs.close(); } catch(SQLExceptione) { System.out.println("登錄失?。?); e.printStackTrace(); } finally { mydb.closed(); } } returnresult; }4.2管理員模塊1.描述:系統(tǒng)主頁面:左方頁面展示了管理員可操作的五大功能,進(jìn)入相關(guān)的管理頁面可以鏈接到子菜單,并且高亮顯示,每個管理模塊下面都有相應(yīng)的子菜單。2.程序運行效果圖如圖4.2所示:圖4.2管理員主頁面在每個jsp頁面將會對相關(guān)用戶進(jìn)行攔截操作,這樣可以提高安全性,防止用戶不經(jīng)過登陸頁面而進(jìn)入任何子菜單頁面:if(session.getAttribute("user")==null){out.print("<script>alert('請先登錄!');window.open('../index.jsp','_self')</script>"); }4.2.2商品信息管理商品信息錄入描述:管理員輸入商品相關(guān)正確信息后點擊錄入按鈕,如果是沒有輸入完整的商品信息,都會給出相應(yīng)的錯誤提示,不能錄入成功。輸入數(shù)據(jù)都通過form表單中定義的方法onsubmit="returncheckForm()"來檢查,checkForm()函數(shù)中是各種的校驗輸入數(shù)據(jù)的方式。程序效果圖如下圖4.8所示:圖4.8商品信息錄入商品信息管理1.描述:管理員點擊左側(cè)的菜單“商品信息管理”,頁面跳轉(zhuǎn)到商品信息管理界面,調(diào)用后臺的action類查詢出所有的商品信息,并把這些信息封轉(zhuǎn)到數(shù)據(jù)集合List中,綁定到request對象,然后頁面跳轉(zhuǎn)到相應(yīng)的jsp,顯示出商品信息。2.程序效果圖如下圖4.9所示圖4.9商品信息管理頁面商品信息管理關(guān)鍵代碼: publicvoidgoodsMana(HttpServletRequestreq,HttpServletResponseres)throwsServletException,IOException { ListgoodsList=newArrayList(); Stringsql="select*fromt_goodswheredel='no'"; Object[]params={}; DBmydb=newDB(); try { mydb.doPstm(sql,params); ResultSetrs=mydb.getRs(); while(rs.next()) { TGoodsgoods=newTGoods(); goods.setId(rs.getLong("id")); goods.setBianhao(rs.getString("bianhao")); goods.setMingcheng(rs.getString("mingcheng")); goods.setLeibie(rs.getString("leibie")); goods.setPinpai(rs.getString("pinpai")); goods.setXinghao(rs.getString("xinghao")); goods.setGuige(rs.getString("guige")); goods.setBeizhu(rs.getString("beizhu")); goodsList.add(goods); } rs.close(); } catch(Exceptione) { e.printStackTrace(); } mydb.closed(); req.setAttribute("goodsList",goodsList); req.getRequestDispatcher("admin/goods/goodsMana.jsp").forward(req,res); } publicvoidgoodsDel(HttpServletRequestreq,HttpServletResponseres) { longid=Long.parseLong(req.getParameter("id")); Stringdel="yes"; Stringsql="updatet_goodssetdel=?whereid=?"; Object[]params={del,id}; DBmydb=newDB(); mydb.doPstm(sql,params); mydb.closed(); req.setAttribute("message","商品信息刪除成功!"); req.setAttribute("path","goods?type=goodsMana");StringtargetURL="/common/success.jsp"; dispatch(targetURL,req,res); } publicvoidgoodsUpd(HttpServletRequestreq,HttpServletResponseres) { longid=Long.parseLong(req.getParameter("id")); Stringbianhao=req.getParameter("bianhao"); Stringmingcheng=req.getParameter("mingcheng"); Stringleibie=req.getParameter("leibie"); Stringpinpai=req.getParameter("pinpai"); Stringxinghao=req.getParameter("xinghao"); Stringguige=req.getParameter("guige"); Stringbeizhu=req.getParameter("beizhu"); Stringsql="updatet_goodssetbianhao=?,mingcheng=?,leibie=?,pinpai=?,xinghao=?,guige=?,beizhu=?whereid=?"; Object[]params={bianhao,mingcheng,leibie,pinpai,xinghao,guige,beizhu,id}; DBmydb=newDB(); mydb.doPstm(sql,params); mydb.closed(); req.setAttribute("message","商品信息修改成功!"); req.setAttribute("path","goods?type=goodsMana");StringtargetURL="/common/success.jsp"; dispatch(targetURL,req,res); } publicvoidgoodsAdd(HttpServletRequestreq,HttpServletResponseres) { longid=CmUtil.getPkId(); Stringbianhao=req.getParameter("bianhao"); Stringmingcheng=req.getParameter("mingcheng"); Stringleibie=req.getParameter("leibie"); Stringpinpai=req.getParameter("pinpai"); Stringxinghao=req.getParameter("xinghao"); Stringguige=req.getParameter("guige"); Stringbeizhu=req.getParameter("beizhu"); Stringdel="no"; Stringsql="insertintot_goodsvalues(?,?,?,?,?,?,?,?,?)"; Object[]params={id,bianhao,mingcheng,leibie,pinpai,xinghao,guige,beizhu,del}; DBmydb=newDB(); mydb.doPstm(sql,params); mydb.closed(); req.setAttribute("message","商品信息添加成功!"); req.setAttribute("path","goods?type=goodsMana");StringtargetURL="/common/success.jsp"; dispatch(targetURL,req,res); }4.2.3商品采購審批1.描述:先是點擊商品信息管理,頁面跳轉(zhuǎn)到物品采購審批管理界面,瀏覽所有的申請信息,點擊要修改的申核的信息,跳轉(zhuǎn)到申請審核頁面,對申請信息進(jìn)行審核。2.程序效果圖如圖4.12、圖4.13所示:圖4.12申請信息瀏覽頁面采購審批關(guān)鍵代碼: publicvoidspMana(HttpServletRequestreq,HttpServletResponseres)throwsServletException,IOException { ListsqList=newArrayList(); Stringsql="selectta.*,tb.mingcheng,tb.leibiefromt_shenqingta,t_goodstbwhereta.goods_id=tb.idandta.zhuangtai=0"; Object[]params={}; DBmydb=newDB(); try { mydb.doPstm(sql,params); ResultSetrs=mydb.getRs(); while(rs.next()) { TShenqingshenqing=newTShenqing(); shenqing.setId(rs.getLong("id")); shenqing.setSpmc(rs.getString("mingcheng")); shenqing.setSplb(rs.getString("leibie")); shenqing.setShuliang(rs.getString("shuliang")); shenqing.setShenqingshijian(rs.getString("shenqingshijian")); shenqing.setBeizhu(rs.getString("beizhu")); shenqing.setStrZt(getStrZt(rs.getInt("zhuangtai"))); sqList.add(shenqing); } rs.close(); } catch(Exceptione) { e.printStackTrace(); } mydb.closed(); req.setAttribute("sqList",sqList); req.getRequestDispatcher("admin/shenqing/shenpiList.jsp").forward(req,res); } publicvoidsqAdd(HttpServletRequestreq,HttpServletResponseres) { longid=CmUtil.getPkId(); longgoodsId=Long.parseLong(req.getParameter("goodsId")); Stringshuliang=req.getParameter("shuliang"); Stringshenqingshijian=req.getParameter("shenqingshijian"); Stringbeizhu=req.getParameter("beizhu"); intzhuangtai=0; Stringhuifu=""; Stringsql="insertintot_shenqingvalues(?,?,?,?,?,?,?)"; Object[]params={id,goodsId,shuliang,shenqingshijian,beizhu,zhuangtai,huifu}; DBmydb=newDB(); mydb.doPstm(sql,params); mydb.closed(); req.setAttribute("message","采購申請?zhí)砑映晒?"); req.setAttribute("path","shenqing?type=sqMana");StringtargetURL="/common/success.jsp"; dispatch(targetURL,req,res); }4.2.4修改密碼1.描述:輸入用戶名和用戶的原有密碼,輸入新密碼以后點擊修改按鈕即可修改密碼成功。2.程序效果圖如圖4.14所示:圖4.14修改密碼4.2.5退出系統(tǒng)1.描述:點此按鈕回到系統(tǒng)的主頁面。2.關(guān)鍵代碼:主要是通過javascript語句來實現(xiàn),item_word[8][4]="退出系統(tǒng)";item_link[8][4]="javascript:window.open('../index.jsp','_self')";4.3操作員模塊4.3.1采購審請管理添加采購申請描述:先是點擊添加采購申請管理,頁面跳轉(zhuǎn)到采購申請管理界面,瀏覽所有的商品信息,點擊要采購的商品的信息,跳轉(zhuǎn)到采購申請?zhí)砑用妫顚懖少徤暾埿畔?。程序效果圖如下圖4.15、圖4.16所示:圖4.15采購申請商品瀏覽頁面采購結(jié)果查看1.描述:操作員點擊左側(cè)的菜單“我的采購申請”,頁面跳轉(zhuǎn)到物品申請結(jié)果查看界面,調(diào)用后臺的action類查詢出所有的申請信息,并把這些信息封轉(zhuǎn)到數(shù)據(jù)集合List中,綁定到request對象,然后頁面跳轉(zhuǎn)到相應(yīng)的jsp,顯示出申請信息。2.程序效果圖如下圖4.17所示圖4.17申請結(jié)果查看頁面采購申請管理關(guān)鍵代碼: publicvoidgoodsList(HttpServletRequestreq,HttpServletResponseres)throwsServletException,IOException { ListgoodsList=newArrayList(); Stringsql="select*fromt_goodswheredel='no'"; Object[]params={}; DBmydb=newDB(); try { mydb.doPstm(sql,params); ResultSetrs=mydb.getRs(); while(rs.next()) { TGoodsgoods=newTGoods(); goods.setId(rs.getLong("id")); goods.setBianhao(rs.getString("bianhao")); goods.setMingcheng(rs.getString("mingcheng")); goods.setLeibie(rs.getString("leibie")); goods.setPinpai(rs.getString("pinpai")); goods.setXinghao(rs.getString("xinghao")); goods.setGuige(rs.getString("guige")); goods.setBeizhu(rs.getString("beizhu")); goodsList.add(goods); } rs.close(); } catch(Exceptione) { e.printStackTrace(); } mydb.closed(); req.setAttribute("goodsList",goodsList); req.getRequestDispatcher("admin/shenqing/goodsList.jsp").forward(req,res); } publicvoidsqAdd(HttpServletRequestreq,HttpServletResponseres) { longid=CmUtil.getPkId(); longgoodsId=Long.parseLong(req.getParameter("goodsId")); Stringshuliang=req.getParameter("shuliang"); Stringshenqingshijian=req.getParameter("shenqingshijian"); Stringbeizhu=req.getParameter("beizhu"); intzhuangtai=0; Stringhuifu=""; Stringsql="insertintot_shenqingvalues(?,?,?,?,?,?,?)"; Object[]params={id,goodsId,shuliang,shenqingshijian,beizhu,zhuangtai,huifu}; DBmydb=newDB(); mydb.doPstm(sql,params); mydb.closed(); req.setAttribute("message","采購申請?zhí)砑映晒?"); req.setAttribute("path","shenqing?type=sqMana");StringtargetURL="/common/success.jsp"; dispatch(targetURL,req,res); }4.3.2物品采購管理物品采購添加描述:先是點擊物品采購添加管理,頁面跳轉(zhuǎn)到物品采購管理界面,瀏覽所有的已同意采購的申請信息,點擊要采購的信息,跳轉(zhuǎn)到采購物品添加面,填寫采購內(nèi)容信息。程序效果圖如下圖4.18、圖4.19所示:圖4.19采購信息錄入第五章系統(tǒng)測試5.1系統(tǒng)測試目的與意義系統(tǒng)測試是管理信息系統(tǒng)開發(fā)周期中一個十分重要而漫長的的階段。其重要性體現(xiàn)在他是保證系統(tǒng)質(zhì)量與可靠性的最后關(guān)口,是對整個系統(tǒng)開發(fā)過程包括系統(tǒng)分析、系統(tǒng)設(shè)計和系統(tǒng)實現(xiàn)的最終審查。系統(tǒng)測試的任務(wù)是盡可能徹

溫馨提示

  • 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. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論