




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、軟件工程課程設(shè)計(jì)個(gè)人博客 信 息 工 程 學(xué) 院軟件工程課程設(shè)計(jì)報(bào)告本題 目: 個(gè)人博客專業(yè)班級(jí): 軟件091學(xué) 生: 廖揚(yáng)華指導(dǎo)老師: 李淑芝 2012年 7月 5 日49目 錄第一章 問(wèn)題定義11.問(wèn)題背景12.主要解決的問(wèn)題13.運(yùn)行環(huán)境要求14.技術(shù)要求1第二章 可行性研究報(bào)告21引言21.1編寫(xiě)目的21.2項(xiàng)目背景21.3符號(hào)和定義21.4參考資料22.可行性研究前提32.1性能需求32.2技術(shù)可行性分析32.3經(jīng)濟(jì)可行性分析42.4 社會(huì)因素方面的可行性分析43. 所建議系統(tǒng)概述4第三章 項(xiàng)目開(kāi)發(fā)計(jì)劃61引言61.1編寫(xiě)目的61.2 背景61.3定義61.4參考資料62項(xiàng)目概述62
2、.1工作內(nèi)容62.2主要參加人員72.3程序72.4文件72.5服務(wù)72.6非移交的產(chǎn)品72.7驗(yàn)收標(biāo)準(zhǔn)72.8完成項(xiàng)目的最遲期限72.9本計(jì)劃的批準(zhǔn)者和批準(zhǔn)日期83實(shí)施計(jì)劃83.1工作任務(wù)的分解與人員分工83.2預(yù)算84項(xiàng)目進(jìn)度85.支持條件95.1計(jì)算機(jī)系統(tǒng)支持9第四章 需求分析101.引言102.需求分析102.1系統(tǒng)的需求分析102.2系統(tǒng)的功能分析10第五章 系統(tǒng)概要設(shè)計(jì)121引言121.功能模塊劃分142功能模塊設(shè)計(jì)142.1博客登錄管理模塊15第六章 數(shù)據(jù)庫(kù)設(shè)計(jì)171數(shù)據(jù)庫(kù)分析171.1數(shù)據(jù)庫(kù)設(shè)計(jì)e-r圖172 系統(tǒng)數(shù)據(jù)表設(shè)計(jì)193數(shù)據(jù)連接21第七章 詳細(xì)設(shè)計(jì)231.系統(tǒng)主要功能
3、模塊詳述231.1登錄模塊231.2日志管理模塊231.3撰寫(xiě)日志模塊241.4刪除日志模塊242配置源程序273附加數(shù)據(jù)庫(kù)mysql273.1需要導(dǎo)入的包274將程序發(fā)布到tomcat下275公共核心類的設(shè)計(jì)285.1數(shù)據(jù)庫(kù)相關(guān)285.2管理類設(shè)計(jì)30第八章 測(cè)試報(bào)告331引言331.1編寫(xiě)目的331.2測(cè)試范圍331.3參考資料342測(cè)試計(jì)劃執(zhí)行情況342.1 測(cè)試類型342.2 進(jìn)度偏差352.3測(cè)試環(huán)境與配置352.4 測(cè)試問(wèn)題總結(jié)363.測(cè)試總結(jié)363.1測(cè)試用例執(zhí)行結(jié)果363.2測(cè)試問(wèn)題解決373.3覆蓋分析383.4測(cè)試覆蓋分析383.5需求覆蓋分析383.6缺陷分析384.綜合
4、評(píng)價(jià)394.1 軟件能力394.2 缺陷和限制394.3 建議39第九章 用戶使用手冊(cè)40引言40系統(tǒng)介紹40操作注意事項(xiàng)40操作流程40十 附錄431數(shù)據(jù)連接文件432獲取前臺(tái)主頁(yè)面453實(shí)現(xiàn)文章發(fā)表464實(shí)現(xiàn)照片上傳關(guān)鍵代碼485實(shí)現(xiàn)留言49第一章 問(wèn)題定義1.問(wèn)題背景博客,譯自英文blog。blog(個(gè)人博客系統(tǒng)): 個(gè)人博客是使廣大博客用戶能夠在互聯(lián)網(wǎng)上發(fā)表及評(píng)論相關(guān)文章的軟件系統(tǒng)。c/s(client/server):客戶機(jī)/服務(wù)器它是互聯(lián)網(wǎng)平臺(tái)上的個(gè)人信息交流中心。通常博客就是用來(lái)發(fā)表文章,所有的文章都是按照年份和日期排列,有些類似斑竹的日記??瓷先テ降瓱o(wú)奇,毫無(wú)可炫耀之處,但它可
5、以讓每個(gè)人零成本、零維護(hù)地創(chuàng)建自己的網(wǎng)絡(luò)媒體,每個(gè)人都可以隨時(shí)把自己的思想火花和靈感更新到博客站點(diǎn)上。2.主要解決的問(wèn)題個(gè)人博客系統(tǒng)用來(lái)展示個(gè)人風(fēng)采,其中模塊主要包括:(1)個(gè)人首頁(yè):交流、提高,通過(guò)交流產(chǎn)生更多的思維火花,相互提高。(2)心情日志: 記錄生活,在自己的每一天上留下思考的劃痕(3)個(gè)人相冊(cè): 分享,將自己的相片、自己所見(jiàn)美麗景色。 (4)個(gè)人資料:告知訪客一些可以公開(kāi)的個(gè)人信息3.運(yùn)行環(huán)境要求(1)客戶端:windows操作系統(tǒng)ie瀏覽器(2)服務(wù)器:windows server 版操作系統(tǒng)4.技術(shù)要求(1)了解有關(guān)web網(wǎng)站建設(shè)的基本概念與方法。(2)掌握網(wǎng)頁(yè)設(shè)計(jì)制作的基本概
6、念,有關(guān)美學(xué)基本知識(shí)與設(shè)計(jì)制作流程。(3)掌握網(wǎng)絡(luò)信息發(fā)布與維護(hù)的方法。 第二章 可行性研究報(bào)告1引言近年來(lái)隨著信息技術(shù)的進(jìn)步,blog也快速擴(kuò)張,它已經(jīng)滿足不了用戶的需求。目前用戶在網(wǎng)絡(luò)上發(fā)表文章、張貼內(nèi)容的目的有很大的差異,但是,由于溝通方式比電子郵件、討論群組以及bbs和論壇更簡(jiǎn)單和容易,博客系統(tǒng)已經(jīng)成為廣大各界用戶進(jìn)行溝通的主流工具1.1編寫(xiě)目的本系統(tǒng)是針對(duì)博客用戶的需求設(shè)計(jì)的,可以完成博客用戶登入、發(fā)表、瀏覽、修改博文、上傳、瀏覽照片、留言等主要功能。 此可行性研究報(bào)告,實(shí)現(xiàn)了在最短的時(shí)間內(nèi)以最小的代價(jià)確定問(wèn)題是否可以解決,從而確定進(jìn)一步對(duì)系統(tǒng)進(jìn)行開(kāi)發(fā)。1.2項(xiàng)目背景 開(kāi)發(fā)軟件名稱:
7、個(gè)人博客系統(tǒng) 項(xiàng)目任務(wù)提出者:軟件工程課程設(shè)計(jì)指導(dǎo)老師 項(xiàng)目開(kāi)發(fā)者:本人 用戶:admin 實(shí)現(xiàn)軟件的單位:江西理工大學(xué)信息工程學(xué)院1.3符號(hào)和定義(1)blog(個(gè)人博客系統(tǒng)): 個(gè)人博客是使廣大博客用戶能夠在互聯(lián)網(wǎng)上發(fā)表及評(píng)論相關(guān)文章的軟件系統(tǒng)。(2)c/s(client/server):客戶機(jī)/服務(wù)器1.4參考資料1史濟(jì)明,顧春華,鄭紅.軟件工程原理、方法及應(yīng)用(第三版)m.高等教育出版社,2009.6.2.可行性研究前提個(gè)人博客系統(tǒng)的主要功能:個(gè)人博客管理以及系統(tǒng)管理等功能。(1)前臺(tái)廣大博客用戶的登錄主要包括的功能:閱讀博客、發(fā)表評(píng)論、注冊(cè)博客、博客登錄、發(fā)表留言。 1)閱讀博客:給
8、廣大用戶提供便捷的在線閱讀自己感興趣的文章。 2)發(fā)表評(píng)論:提供給閱讀者對(duì)自己所閱讀的博客發(fā)表自己得觀點(diǎn)、作相關(guān)的評(píng)論。 3)注冊(cè)博客:以滿足用戶成為本系統(tǒng)真正的博客用戶,登陸本系統(tǒng)從而滿足自己更多的需求,包括發(fā)表留言等。(2)個(gè)人博客管理的功能:發(fā)表文章、文章管理、相冊(cè)管理、消息管理、個(gè)人詳細(xì)資料管理。1) 博客登陸系統(tǒng)以后可以發(fā)表自己得文章,并且對(duì)自己發(fā)表的文章作最基本的管理,包括增刪改查等。2)相冊(cè)管理功能是廣大博客用戶對(duì)自己的相冊(cè)進(jìn)行的最基本的操作,包括相片的上傳、下載、刪除等。3)消息管理功能是用戶對(duì)自己收到的信息進(jìn)行查閱、評(píng)論與刪除。4)個(gè)人詳細(xì)資料是博客用戶對(duì)自己得個(gè)人資料做出完
9、善,包括增刪改查等。(3)系統(tǒng)管理的功能:用戶管理、博客分類、公告管理、評(píng)論管理、友情鏈接、系統(tǒng)維護(hù)。用戶管理功能實(shí)現(xiàn)管理員對(duì)博客用戶的審核等操縱。博客分類功能實(shí)現(xiàn)了系統(tǒng)對(duì)博客用戶發(fā)表的博客做出類型的歸并。公告管理功能是將最近系統(tǒng)的一些最新消息公布到系統(tǒng)的界面,從而實(shí)現(xiàn)用戶對(duì)系統(tǒng)情況的真實(shí)了解。 評(píng)論管理:對(duì)進(jìn)入本系統(tǒng)的游客所發(fā)表的評(píng)論進(jìn)行查看管理,而對(duì)于已經(jīng)過(guò)期或不良評(píng)論進(jìn)行刪除操作,使博客可以做到及時(shí)的更新,以利于網(wǎng)站的維護(hù)。 系統(tǒng)維護(hù)功能實(shí)現(xiàn)了系統(tǒng)的安全性等。2.1性能需求 方便、快捷、有效的實(shí)現(xiàn)博客用戶以及系統(tǒng)管理員的需求,進(jìn)行數(shù)據(jù)的操作的速度快。2.2技術(shù)可行性分析 此個(gè)人博客系統(tǒng)是
10、一個(gè)涉及到數(shù)據(jù)庫(kù)的應(yīng)用程序。利用現(xiàn)有的數(shù)據(jù)庫(kù)開(kāi)發(fā)技術(shù)可以達(dá)到各方面的要求。2.3經(jīng)濟(jì)可行性分析(1)支出1)完全可以利用現(xiàn)有的設(shè)備,不需要增加新的硬件設(shè)備。2)需要經(jīng)常性的軟件維護(hù)費(fèi)用。 2、效益 目前的情況還不可以確定具體的效益,只能根據(jù)后期的點(diǎn)擊率和使用效率來(lái)確定。 3、投資回收周期 估計(jì)是系統(tǒng)運(yùn)行后的一年2.4 社會(huì)因素方面的可行性分析(1)法律方面的可行性 本系統(tǒng)的研制和開(kāi)發(fā)所涉及到的軟件都選用正版,不會(huì)侵犯他人、集體和國(guó)家的利益,遵循相關(guān)的法律法規(guī)。(2)使用方面的可行性 使用本系統(tǒng)的用戶需要擁有一定的計(jì)算機(jī)基礎(chǔ)3. 所建議系統(tǒng)概述此系統(tǒng)的設(shè)計(jì)包括以下方面,一為博客用戶空間,二為系統(tǒng)
11、管理員空間,三為普通游客空間。博客用戶在首頁(yè)進(jìn)行登錄后,在個(gè)人界面可以進(jìn)行對(duì)相冊(cè)、文章、評(píng)論以及個(gè)人信息進(jìn)行修改等管理。系統(tǒng)管理員可以對(duì)系統(tǒng)近期的動(dòng)態(tài)做出維護(hù)、對(duì)博客用戶的審核等。普通游客可以在博客里瀏覽博文或?qū)Σ┪倪M(jìn)行感言評(píng)論。所建議的數(shù)據(jù)流程:第一層:訪客博主個(gè)人博客系統(tǒng)第二層:第三層:第三章 項(xiàng)目開(kāi)發(fā)計(jì)劃 1引言對(duì)個(gè)人而言,博客可以調(diào)動(dòng)個(gè)人的積極性,充分發(fā)揮個(gè)人的創(chuàng)造性。從2002年開(kāi)始,國(guó)內(nèi)博客開(kāi)始迅猛發(fā)展起來(lái),從最初的只有幾千個(gè)嘗鮮者到現(xiàn)在的各式各樣的博客,圈子。在這三年的發(fā)展過(guò)程中,主要呈現(xiàn)出如下幾個(gè)特點(diǎn):(1)博客是可以將個(gè)人信息完整呈現(xiàn)在互聯(lián)網(wǎng)上的載體。(2)博客具有“準(zhǔn)實(shí)名制
12、”趨勢(shì),有助于信任機(jī)制的建立。1.1編寫(xiě)目的開(kāi)發(fā)小組成員需要閱讀本說(shuō)明,已明確項(xiàng)目初步的開(kāi)發(fā)計(jì)劃,此計(jì)劃適合小組內(nèi)部系統(tǒng)的開(kāi)發(fā),讀者為設(shè)計(jì)人員、開(kāi)發(fā)人員和測(cè)試人員。1.2 背景開(kāi)發(fā)的軟件系統(tǒng)的名稱:個(gè)人博客系統(tǒng);本項(xiàng)目的任務(wù)提出者、開(kāi)發(fā)者、用戶:邱自陽(yáng);1.3定義a.jsp:即java server pages,是由sun公司倡導(dǎo),與多個(gè)公司共同建立的一種技術(shù)標(biāo)準(zhǔn),它是建立在servlet之上的。b.servlet:servlet是在jsp之前就存在的運(yùn)行在服務(wù)器端的一種java技術(shù),它是用java語(yǔ)言編寫(xiě)的服務(wù)器端程序,java語(yǔ)言能夠?qū)崿F(xiàn)的功能,servlet基本上可以實(shí)現(xiàn)。c.javab
13、ean:可稱它們?yōu)椤蔼?dú)立的組件”,每一個(gè)javabean實(shí)現(xiàn)一個(gè)特定的功能,通過(guò)合理地組織具有不同功能的javabean,可以快速地生成一個(gè)全新的應(yīng)用程序。1.4參考資料1 jsp程序設(shè)計(jì)教程人民郵局出版社,2008年4月2 竇萬(wàn)峰.軟件工程方法與實(shí)踐.機(jī)械工業(yè)出版社,2009 年5 月.3 竇萬(wàn)峰.軟件工程實(shí)驗(yàn)教程.機(jī)械工業(yè)出版社,2009 年5 月.4 個(gè)人博客系統(tǒng)可行性分析報(bào)告.2項(xiàng)目概述2.1工作內(nèi)容在本項(xiàng)目開(kāi)發(fā)過(guò)程中需要進(jìn)行可行性分析、制定項(xiàng)目開(kāi)發(fā)計(jì)劃、軟件需求、軟件分析設(shè)計(jì)、軟件實(shí)現(xiàn)、軟件測(cè)試以及相應(yīng)的文檔編寫(xiě)工作。2.2主要參加人員廖揚(yáng)華為大學(xué)生,選該項(xiàng)目作為軟件工程課程設(shè)計(jì)的題
14、目,掌握程序設(shè)計(jì)和軟件工程的基本原理和思想,通過(guò)查閱資料和討論的形式,能夠解決問(wèn)題。2.3程序 所用的編程語(yǔ)言是jsp,采用了javabean+servlet結(jié)合技術(shù)實(shí)現(xiàn)的。2.4文件移交用戶的每種文件的名稱及內(nèi)容要點(diǎn):(1)問(wèn)題定義:明確要解決的問(wèn)題是什么?(2)可行性研究報(bào)告:要解決的關(guān)鍵問(wèn)題是“對(duì)于上一個(gè)階段所確定的問(wèn)題有有行得通的解決辦法嗎?”(3)需求分析報(bào)告:準(zhǔn)確地確定“為了解決這個(gè)問(wèn)題,目標(biāo)系統(tǒng)應(yīng)該做什么?”,主要是確定目標(biāo)系統(tǒng)必須具備哪些功能;(4)概要設(shè)計(jì)報(bào)告:概括的說(shuō)就是“應(yīng)該怎么實(shí)現(xiàn)目標(biāo)系統(tǒng)”,主要任務(wù)是設(shè)計(jì)程序的體系結(jié)構(gòu);(5)詳細(xì)設(shè)計(jì)報(bào)告:設(shè)計(jì)出程序的詳細(xì)規(guī)格說(shuō)明;(
15、6)編碼及單元測(cè)試文檔:寫(xiě)出正確的容易理解、容易維護(hù)的程序模塊;(7)綜合測(cè)試文檔:利用測(cè)試工具按照測(cè)試方案和流程對(duì)產(chǎn)品進(jìn)行功能和性能測(cè)試,甚至根據(jù)需要編寫(xiě)不同的測(cè)試工具,設(shè)計(jì)和維護(hù)測(cè)試系統(tǒng),對(duì)測(cè)試方案可能出現(xiàn)的問(wèn)題進(jìn)行分析和評(píng)估。執(zhí)行測(cè)試用例后,需要跟蹤故障,以確保開(kāi)發(fā)的產(chǎn)品適合需求;(8)軟件維護(hù)文檔:通過(guò)各種必要的維護(hù)活動(dòng)使系統(tǒng)持久地滿足用戶的需要。2.5服務(wù)向用戶提供的服務(wù)為需求分析文檔及用戶手冊(cè),用戶可從中得到關(guān)于軟件使用的信息。2.6非移交的產(chǎn)品所有文件都應(yīng)上交項(xiàng)目委托單位,即江西理工大學(xué)。2.7驗(yàn)收標(biāo)準(zhǔn)用戶可根據(jù)需求分析中的“需求規(guī)定”一欄對(duì)系統(tǒng)進(jìn)行詳細(xì)的評(píng)定與驗(yàn)證,或參考系統(tǒng)提
16、供的其他功能/性能指標(biāo)。2.8完成項(xiàng)目的最遲期限本學(xué)期結(jié)束即2012年7月4號(hào)。2.9本計(jì)劃的批準(zhǔn)者和批準(zhǔn)日期本計(jì)劃的批準(zhǔn)者為江西理工大學(xué),批準(zhǔn)日期為2012年6月26日。3實(shí)施計(jì)劃3.1工作任務(wù)的分解與人員分工可行性分析:廖揚(yáng)華項(xiàng)目開(kāi)發(fā)計(jì)劃:廖揚(yáng)華軟件需求:廖揚(yáng)華軟件需求分析設(shè)計(jì):廖揚(yáng)華編碼:廖揚(yáng)華測(cè)試與維護(hù):廖揚(yáng)華等用戶手冊(cè)的編寫(xiě):廖揚(yáng)華3.2預(yù)算人員成本:60元/人天,共計(jì)6011=660元其他費(fèi)用如下:辦公費(fèi)用:700元 差旅費(fèi):無(wú)機(jī)時(shí)費(fèi):無(wú) 資料費(fèi):1000元設(shè)備費(fèi):4000元 專用設(shè)備租金:無(wú)總計(jì)費(fèi)用支出:6360元4項(xiàng)目進(jìn)度時(shí)間完成功能第一周文章管理第二周注冊(cè)、登錄、發(fā)表文章,上
17、傳照片和評(píng)論管理項(xiàng)目進(jìn)度圖如下:5.支持條件5.1計(jì)算機(jī)系統(tǒng)支持計(jì)算機(jī)系統(tǒng)支持包括以下內(nèi)容:(1)運(yùn)行該軟件系統(tǒng)所需要的硬設(shè)備包括服務(wù)器和客戶機(jī),要求滿足(最低配置):1) 1g hz 以上處理器,內(nèi)存不少于256m。2) 3g 以上空余硬盤空間。3) 客戶機(jī)為普通電腦。(2)運(yùn)行該軟件系統(tǒng)所需要的軟設(shè)備包括:1) tomcat 5.5以上版本(服務(wù)器)2) 安裝了jdk1.5版本以上3) 安裝了sql server 2000版本以上4) 以及相關(guān)的jar包(3)開(kāi)發(fā)這個(gè)系統(tǒng)運(yùn)用到的軟件1) myeclipse 8.6版本2) dreamweaver 8.0以上3) jdk1.5版本4) to
18、mcat 5.5以上版本5) sql server 2000版本第四章 需求分析1.引言本環(huán)節(jié)是為后面的詳細(xì)設(shè)計(jì),實(shí)現(xiàn),測(cè)試,以及最后的驗(yàn)收提供參考,也為評(píng)價(jià)系統(tǒng)的功能和性能提供標(biāo)準(zhǔn),本過(guò)程適合用戶,開(kāi)發(fā)人員,系統(tǒng)分析人員,程序設(shè)計(jì)人員以及系統(tǒng)測(cè)試人員閱讀和提供參考2.需求分析2.1系統(tǒng)的需求分析 此博客系統(tǒng)為簡(jiǎn)單的博客系統(tǒng),主要的功能包括五大部分:管理文章、管理評(píng)論、友情鏈接、管理公告、瀏覽者的評(píng)論管理和修改個(gè)人密碼。文章管理包括添加文章、刪除文章、修改文章等功能。評(píng)論管理可以實(shí)現(xiàn)查看評(píng)論、添加評(píng)論等功能。項(xiàng)目按照企業(yè)級(jí)三層架構(gòu)開(kāi)發(fā),包括model層,數(shù)據(jù)訪問(wèn)操作層和頁(yè)面展示層。2.2系統(tǒng)的
19、功能分析博客系統(tǒng)的使用角色一般有瀏覽者和博主兩種:博主是博客信息的發(fā)布者,瀏覽者是對(duì)博客內(nèi)容進(jìn)行瀏覽,也可以通過(guò)發(fā)表評(píng)論來(lái)與博主交流。詳細(xì)功能如下表:功能類別子功能用戶管理(瀏覽者)注冊(cè)瀏覽文章發(fā)表評(píng)論博主管理管理文章管理評(píng)論管理公告友情鏈接博客統(tǒng)計(jì)圖4-1 功能類別圖(1).瀏覽者瀏覽者一般使用的功能如圖所示:圖4-2瀏覽者功能圖1)注冊(cè)瀏覽者可以通過(guò)博客網(wǎng)站注冊(cè)功能開(kāi)通自己的博客,成為一名博主。注冊(cè)信息包括注冊(cè)人的id、密碼和有效郵箱等。2)瀏覽文章博客最吸引人的當(dāng)屬博客充滿創(chuàng)意的文章,包括技術(shù)類、生活類、情感類等。3)發(fā)表評(píng)論瀏覽者可以對(duì)某篇文章發(fā)表評(píng)論,來(lái)作為與博主溝通的途徑。同時(shí),瀏
20、覽者與瀏覽者也可以在此展開(kāi)討論。(2).博主博主除了擁有瀏覽者的功能外,還可以維護(hù)自己的博客,包括外表修飾,發(fā)表文章,管理類別等,用例圖如下圖所示: 圖4-31)管理文章博主可以通過(guò)博客發(fā)表文章、編輯文章、刪除文章等。2)管理評(píng)論博主通過(guò)評(píng)論管理對(duì)瀏覽者的評(píng)論進(jìn)行回復(fù)或刪除。3)管理類別為了便于組織文章,一般博客都會(huì)給文章分類,如技術(shù),情感,生活等。4)管理公告每一個(gè)博客都有自己的公告區(qū),博主可以對(duì)博客公告內(nèi)容進(jìn)行修改。5)友情鏈接提供進(jìn)入朋友博客的鏈接,以達(dá)到信息共享的目的。3.管理員管理員是博客網(wǎng)站的管理者,通常對(duì)網(wǎng)站進(jìn)行綜合管理,具體來(lái)說(shuō)可以有下面有:數(shù)據(jù)備份恢復(fù)、博客統(tǒng)計(jì)。用例圖如下圖
21、:圖4-4 管理員第五章 系統(tǒng)概要設(shè)計(jì)1引言根據(jù)博客信息管理系統(tǒng)的特點(diǎn),將其分為兩大模塊:前臺(tái)用戶瀏覽模塊和后臺(tái)用戶管理模塊。前臺(tái)用戶瀏覽模塊主要用于用戶瀏覽日志信息;后臺(tái)用戶管理模塊主要用于博客管理員對(duì)個(gè)人博客網(wǎng)站的管理,如日志管理、留言管理及評(píng)論管理等。博客系統(tǒng)平臺(tái)的前臺(tái)用戶瀏覽模塊流程圖如圖5-1所示。博客系統(tǒng)平臺(tái)的后臺(tái)用戶管理模塊流程圖如圖5-2所示。前臺(tái)用戶瀏覽模塊主要用于用戶瀏覽日志信息,用戶瀏覽日志有三種瀏覽方式可以選擇:一是直接點(diǎn)擊日志標(biāo)題鏈接進(jìn)入日志顯示頁(yè)面瀏覽日志;二是點(diǎn)擊博客主題鏈接進(jìn)入該個(gè)人博客的首頁(yè),然后在該首頁(yè)中選擇所需的日志標(biāo)題鏈接進(jìn)入日志顯示頁(yè)面瀏覽日志;三是通
22、過(guò)首頁(yè)提供的搜索功能,搜索所需要的日志,然后在結(jié)果列表中選擇所需的日志標(biāo)題鏈接進(jìn)入日志顯示頁(yè)面瀏覽日志。瀏覽日志的同時(shí)用戶可以查看別人對(duì)該日志的評(píng)論,然后用戶也可以對(duì)該日志發(fā)表自已的評(píng)論。用戶進(jìn)入后臺(tái)管理平臺(tái),首先必需進(jìn)行權(quán)限驗(yàn)證,防止未授權(quán)的用戶非法登錄。若未通過(guò)驗(yàn)證,則顯示出錯(cuò)提示,并跳轉(zhuǎn)到登錄界面。若通過(guò)驗(yàn)證,則進(jìn)入個(gè)人博客后臺(tái)管理平臺(tái)。用戶可以瀏覽已發(fā)表的日志,并對(duì)其進(jìn)行相應(yīng)的操作如修改日志和刪除日志;可以查看日志的評(píng)論信息并對(duì)其進(jìn)行回復(fù)或者刪除操作;可以發(fā)表新的日志;可以新建日志分類;可以瀏覽個(gè)人博客的留言信息并對(duì)其進(jìn)行相應(yīng)的操作如回復(fù)留言圖5-1 前臺(tái)用戶瀏覽模塊流程圖圖5.2 后
23、臺(tái)用戶管理模塊流程圖1.功能模塊劃分前臺(tái)模塊功能結(jié)構(gòu)如圖3.5所示。圖3.5 博客信息系統(tǒng)前臺(tái)功能結(jié)構(gòu)圖后臺(tái)模塊功能結(jié)構(gòu)如圖3.6所示。圖3.6 博客信息系統(tǒng)后臺(tái)功能結(jié)構(gòu)圖2功能模塊設(shè)計(jì)博客信息管理系統(tǒng)分為面向網(wǎng)絡(luò)用戶的前臺(tái)及面向個(gè)人博客維護(hù)管理的后臺(tái),依據(jù)博客網(wǎng)站中所要實(shí)現(xiàn)的基本功能的設(shè)定,將所有功能分解為如下四個(gè)主要的功能模塊來(lái)加以實(shí)現(xiàn)。用戶以合法的用戶名及密碼登錄,系統(tǒng)即可按該登錄用戶的權(quán)限分配操作模塊。2.1博客登錄管理模塊博客注冊(cè)登錄管理模塊用于建立博客網(wǎng)站固定的客戶群體,通過(guò)記錄對(duì)應(yīng)的博客檔案,實(shí)現(xiàn)對(duì)博客信息的后臺(tái)維護(hù)及管理,同時(shí)也便于通過(guò)博客檔案庫(kù)將網(wǎng)站最新動(dòng)態(tài)及相關(guān)企業(yè)的信息方
24、便地傳達(dá)給每一位潛在的客戶。該功能模塊實(shí)現(xiàn)了以下幾個(gè)子功能。a)新博客在線注冊(cè)。b)博客登錄管理。c)跳轉(zhuǎn)到博客主頁(yè)。只有進(jìn)行登錄并通過(guò)身份驗(yàn)證的用戶,才可以在個(gè)人博客頁(yè)面發(fā)表日志,并借助個(gè)人設(shè)置實(shí)現(xiàn)對(duì)個(gè)人博客相關(guān)信息的管理維護(hù)。對(duì)于沒(méi)有經(jīng)過(guò)身份驗(yàn)證的網(wǎng)絡(luò)用戶不允許在博客頁(yè)面中發(fā)表日志,更不允許對(duì)博客頁(yè)面信息進(jìn)行管理維護(hù)。該模塊實(shí)現(xiàn)新博客的注冊(cè)及登錄驗(yàn)證功能。其中,注冊(cè)新博客時(shí)會(huì)對(duì)用戶輸入的注冊(cè)信息進(jìn)行有效性驗(yàn)證,包括基本數(shù)據(jù)格式的有效性以及邏輯有效性,例如,用戶名被占用時(shí)將及時(shí)給出提示。注冊(cè)成功的博客登錄時(shí),會(huì)隨時(shí)根據(jù)博客輸入的登錄信息進(jìn)行提示,如用戶名錯(cuò)誤或者密碼錯(cuò)誤。2.2博客及文章檢索
25、查詢模塊博客及文章檢索查詢模塊為網(wǎng)絡(luò)用戶提供便捷的搜索,以及日志閱讀瀏覽等功能,同時(shí)對(duì)日志的評(píng)論信息、博客推薦也能夠及時(shí)反饋給網(wǎng)絡(luò)用戶。該功能模塊實(shí)現(xiàn)了以下幾個(gè)子功能。a)熱門博客頁(yè)面推薦。b)最新博客日志推薦。c)日志信息關(guān)鍵字搜索。該模塊能夠在網(wǎng)頁(yè)中隨時(shí)提供在線的最新日志信息。該信息需要定期更新,網(wǎng)絡(luò)用戶可以隨時(shí)獲得最新日志以及最熱門的博客推薦。在客戶選擇了某個(gè)博客或者某個(gè)感興趣的日志后,可以方便地跳轉(zhuǎn)到對(duì)應(yīng)博客頁(yè)面進(jìn)行日志的閱讀,并和博客進(jìn)行交流互動(dòng)。為了使網(wǎng)絡(luò)用戶盡快定位到所需的博客資料及日志信息,本模塊提供了搜索功能,用戶可以對(duì)所關(guān)注的日志信息按照標(biāo)題進(jìn)行關(guān)鍵字搜索,以避免用戶瀏覽多
26、個(gè)頁(yè)面來(lái)尋找所需的日志信息。3博客頁(yè)面顯示模塊當(dāng)網(wǎng)絡(luò)用戶進(jìn)入某個(gè)人博客主頁(yè)后,在該頁(yè)面中將提供博客日志列表的顯示,同時(shí)為了方便用戶瀏覽,在該模塊中提供根據(jù)分類名進(jìn)行日志列表的顯示,也提供日志評(píng)論的瀏覽,此外還允許用戶在博客頁(yè)面中發(fā)表評(píng)論及留言。該功能模塊實(shí)現(xiàn)了如下幾個(gè)子功能。a)用戶可以分頁(yè)查看對(duì)應(yīng)的日志內(nèi)容及評(píng)論信息。b)用戶可以針對(duì)日志內(nèi)容發(fā)表評(píng)論。c)用戶可以針對(duì)博客進(jìn)行留言。d)用戶可以分類查看日志內(nèi)容。在該模塊中還提供了博客頁(yè)面統(tǒng)計(jì)信息,日志、評(píng)論及留言信息分頁(yè)顯示等方便用戶的顯示效果。4博客個(gè)人管理維護(hù)模塊博客個(gè)人維護(hù)管理模塊用于實(shí)現(xiàn)用戶對(duì)博客個(gè)人主頁(yè)及相關(guān)信息的動(dòng)態(tài)管理。該功能模
27、塊實(shí)現(xiàn)了如下幾個(gè)子功能:a)日志及日志分類管理。b)評(píng)論及留言管理。c)個(gè)人基本信息維護(hù)管理。借助該模塊,用戶可以隨時(shí)對(duì)個(gè)人博客主頁(yè)中的內(nèi)容進(jìn)行增加或修改,包括日志分類信息的更新、評(píng)論及留言管理等功能,也允許用戶對(duì)博客的個(gè)人信息進(jìn)行維護(hù)及其管理。第六章 數(shù)據(jù)庫(kù)設(shè)計(jì)1數(shù)據(jù)庫(kù)分析數(shù)據(jù)庫(kù)是當(dāng)前應(yīng)用軟件系統(tǒng)的重要組成部分,如何使基于數(shù)據(jù)庫(kù)的應(yīng)用系統(tǒng)安全、可靠、高效的運(yùn)行一直是軟件開(kāi)發(fā)技術(shù)研究的難題。所以本系統(tǒng)的數(shù)據(jù)庫(kù)設(shè)計(jì)基于以下幾點(diǎn)來(lái)考慮:a)數(shù)據(jù)庫(kù)規(guī)范化與非規(guī)范化的考慮。b)數(shù)據(jù)查詢優(yōu)化與索引的建立。c)存儲(chǔ)過(guò)程與視圖。1.1數(shù)據(jù)庫(kù)設(shè)計(jì)e-r圖為了把用戶的數(shù)據(jù)要求清晰明確地表達(dá)出來(lái),通常要建立一個(gè)概
28、念性的數(shù)據(jù)模型。概念性數(shù)據(jù)模型是一種面向問(wèn)題的數(shù)據(jù)模型,是按照用戶的觀點(diǎn)來(lái)對(duì)數(shù)據(jù)和信息建模。描述了從用戶角度看到的數(shù)據(jù),反映了用戶的現(xiàn)實(shí)環(huán)境。最常用的表示概念性數(shù)據(jù)模型的方法,是實(shí)體聯(lián)系方法(entityrelationship approach)。這種方法用er圖描述現(xiàn)實(shí)世界中的實(shí)體,而不涉及這些實(shí)體在系統(tǒng)中的實(shí)現(xiàn)方法。用這種方法表示的概念性數(shù)據(jù)模型又稱為er模型。er模型中包含“實(shí)體”,“聯(lián)系”和“屬性”。博客信息管理系統(tǒng)涉及的實(shí)體包括:a)用戶:用戶id、用戶名稱、用戶密碼、博客主題、說(shuō)明、e-mail、注冊(cè)日期、發(fā)表日志數(shù)。 b)類別:類別編號(hào)、類別名、類別描述、用戶id。c)日志:日
29、志編號(hào)、日志標(biāo)題、日志內(nèi)容、類別編號(hào)、發(fā)表日期、最后修改日期、用戶id、瀏覽次數(shù)、評(píng)論數(shù)。d)評(píng)論:評(píng)論編號(hào)、評(píng)論標(biāo)題、評(píng)論內(nèi)容、發(fā)表日期、最后回復(fù)日期、評(píng)論人、日志編號(hào)。e)留言:留言編號(hào)、留言標(biāo)題、留言內(nèi)容、發(fā)表日期、最后回復(fù)日期、留言人、用戶id。綜合本系統(tǒng)各子模塊要實(shí)現(xiàn)的功能,通過(guò)前面對(duì)博客信息系統(tǒng)數(shù)據(jù)的分析可以得到:用戶表、類別表、日志表、日志評(píng)論表、留言表的數(shù)據(jù)庫(kù)概念模型(e-r圖)。用戶e-r圖如圖4.1所示。圖6-1 用戶e-r圖日志類別e-r圖如圖6-2所示。圖6-2 日志類別e-r圖日志e-r圖如圖6-3所示。圖6-3 日志e-r圖日志評(píng)論e-r圖如圖6-4所示。圖6-4
30、日志評(píng)論e-r圖留言e-r圖如圖6-5所示。圖6-5 留言e-r圖2 系統(tǒng)數(shù)據(jù)表設(shè)計(jì)a)用戶表,此表主要用于保存用戶的基本信息。其結(jié)構(gòu)如表4.1所示。列名含義類型長(zhǎng)度缺省值允許空blogid用戶編號(hào)int4無(wú)否username用戶名varchar20無(wú)否password用戶密碼varchar20無(wú)否nickname博客主題varchar50無(wú)否description博客描述varchar100無(wú)是email電子郵件email50無(wú)否articlenum發(fā)表的日志數(shù)int40否表6-6 用戶表b)日志表,此表主要用于保存日志的基本信息。其結(jié)構(gòu)如表4.2所示。 列名含義類型長(zhǎng)度缺省值允許空arti
31、cleid日志編號(hào)int4無(wú)否title日志標(biāo)題varchar50無(wú)否content日志內(nèi)容text8無(wú)否categoryid類別idint4無(wú)否publishtime日志發(fā)表時(shí)間datetime8無(wú)否lastmodifytime日志最后修改時(shí)間datetime8無(wú)否blogid用戶idint4無(wú)否readtimes日志瀏覽次數(shù)int40否feedbacknum日志評(píng)論數(shù)int40否表6-7 日志表c)日志評(píng)論表,此表主要用于保存日志評(píng)論的基本信息。其結(jié)構(gòu)如表4.3所示。列名含義類型長(zhǎng)度缺省值允許空f(shuō)eedbackid評(píng)論編號(hào)int4無(wú)否title評(píng)論標(biāo)題varchar20無(wú)否content評(píng)
32、論內(nèi)容text8無(wú)否publishtime發(fā)表時(shí)間datetime8無(wú)否username用戶名varchar20無(wú)否articleid日志idint4無(wú)否表6-8 日志評(píng)論表d)留言表,此表主要用于保存留言的基本信息。其結(jié)構(gòu)如表4.4所示。 列名含義類型長(zhǎng)度缺省值允許空messageid留言編號(hào)int4無(wú)否title留言標(biāo)題varchar20無(wú)否content留言內(nèi)容text8無(wú)否publishtime發(fā)表時(shí)間datetime8無(wú)否lastmodifytime最后回復(fù)時(shí)間datetime8無(wú)否username用戶名varchar20無(wú)否blogid用戶idint4無(wú)否表6-9 留言表e)類別表
33、,此表用于保存日志類別的基本信息。其結(jié)構(gòu)如表4.5所示。列名含義類型長(zhǎng)度缺省值允許空categoryid類別編號(hào)int4無(wú)否name類別名varchar20無(wú)否description類別描述varchar100無(wú)是blogid用戶編號(hào)int4無(wú)否 表6-10 類別表s3數(shù)據(jù)連接目前流行的數(shù)據(jù)庫(kù)連接技術(shù)主要有:jdbc-odbc橋、jdbc和數(shù)據(jù)連接池技術(shù)。該系統(tǒng)采用數(shù)據(jù)連接池技術(shù),使用連接池的優(yōu)點(diǎn)主要體現(xiàn)在兩個(gè)方面:對(duì)數(shù)據(jù)庫(kù)的連接統(tǒng)一進(jìn)行配置、管理、監(jiān)控,以及對(duì)數(shù)據(jù)庫(kù)連接池的參數(shù)進(jìn)行優(yōu)化調(diào)整,同時(shí)對(duì)應(yīng)用程序中沒(méi)有關(guān)閉或其他原因造成沒(méi)有關(guān)閉的數(shù)據(jù)庫(kù)連接由連接池統(tǒng)一進(jìn)行管理。便于程序的移植和后端數(shù)
34、據(jù)庫(kù)的切換,因?yàn)樵趹?yīng)用中通過(guò)統(tǒng)一的jndi獲得數(shù)據(jù)庫(kù)的連接,而具體連接的是哪一臺(tái)機(jī)器上的數(shù)據(jù)庫(kù)與程序無(wú)關(guān)。數(shù)據(jù)庫(kù)連接池技術(shù)的思想非常簡(jiǎn)單,將數(shù)據(jù)庫(kù)連接作為對(duì)象存儲(chǔ)在一個(gè)vector對(duì)象中,一旦數(shù)據(jù)庫(kù)連接建立后,不同的數(shù)據(jù)庫(kù)訪問(wèn)請(qǐng)求就可以共享這些連接。這樣,通過(guò)復(fù)用這些已經(jīng)建立的數(shù)據(jù)庫(kù)連接,可以克服上述缺點(diǎn),極大地節(jié)省系統(tǒng)資源和時(shí)間。數(shù)據(jù)庫(kù)連接池的主要操作如下:a)建立數(shù)據(jù)庫(kù)連接池對(duì)象(服務(wù)器啟動(dòng))。b)按照事先指定的參數(shù)創(chuàng)建初始數(shù)量的數(shù)據(jù)庫(kù)連接(即:空閑連接數(shù))。c)對(duì)于一個(gè)數(shù)據(jù)庫(kù)訪問(wèn)請(qǐng)求,直接從連接池中得到一個(gè)連接。如果數(shù)據(jù)庫(kù)連接池對(duì)象中沒(méi)有空閑的連接,且連接數(shù)沒(méi)有達(dá)到最大(即:最大活躍連接
35、數(shù)),創(chuàng)建一個(gè)新的數(shù)據(jù)庫(kù)連接。d)存取數(shù)據(jù)庫(kù)。e)關(guān)閉數(shù)據(jù)庫(kù),釋放所有數(shù)據(jù)庫(kù)連接(此時(shí)的關(guān)閉數(shù)據(jù)庫(kù)連接,并非真正關(guān)閉,而是將其放入空閑隊(duì)列中。如實(shí)際空閑連接數(shù)大于初始空閑連接數(shù)則釋放連接)。f)釋放數(shù)據(jù)庫(kù)連接池對(duì)象(服務(wù)器停止、維護(hù)期間,釋放數(shù)據(jù)庫(kù)連接池對(duì)象,并釋放所有連接)。第七章 詳細(xì)設(shè)計(jì)1.系統(tǒng)主要功能模塊詳述1.1登錄模塊當(dāng)用戶需發(fā)表新日志或者是對(duì)博客進(jìn)行管理時(shí),就必須先進(jìn)行登錄驗(yàn)證操作,然后進(jìn)入博客系統(tǒng)后臺(tái)。用戶登錄界面如圖7-1所示。1.2日志管理模塊日志管理顯示模塊列出了日志編號(hào)、日志標(biāo)題以及相應(yīng)的操作:編輯日志和刪除日志。根據(jù)選擇的分類顯示當(dāng)前分類下的日志列表。當(dāng)然,對(duì)日志進(jìn)行
36、操作的前提條件是當(dāng)前登錄用戶具備相應(yīng)的管理權(quán)限。日志顯示界面圖如圖7-2所示。 圖7-1 用戶登錄界面圖圖7-2 日志顯示界面圖當(dāng)用戶需要添加新的日志時(shí),可單擊日志管理顯示界面中的添加日志鏈接,進(jìn)入添加新日志的界面。在日志標(biāo)題、內(nèi)容輸入域內(nèi)輸入相應(yīng)的文字,以及選擇分類后,單擊“確定”按鈕進(jìn)行表單提交,完成添加新日志的操作14。1.3撰寫(xiě)日志模塊撰寫(xiě)日志界面圖如圖7-3所示。1.4刪除日志模塊如果需要?jiǎng)h除已發(fā)表的日志,可單擊日志管理顯示界面中的刪除日志鏈接,將彈出刪除日志確認(rèn)對(duì)話框圖如圖7-4所示。 圖7-3 撰寫(xiě)日志界面圖圖7-4 刪除日志確認(rèn)對(duì)話框圖再次確認(rèn)用戶是否真的要進(jìn)行該日志的刪除操作
37、,而不是誤操作。點(diǎn)擊確定按鈕完成日志刪除操作,點(diǎn)擊取消按鈕取消該刪除操作。完成日志刪除操作的核心代碼如下:tryconn=db.getconnetion();/禁止自動(dòng)提交,設(shè)置回滾點(diǎn)conn.setautocommit(false);stmt=conn.createstatement();/刪除該日志的所有評(píng)論stmt.preparestatement(“delete from feedback where articleid=?”);stmt.setint(1,articleid);stmt.executeupdate();/刪除該日志stmt.preparestatement(“dele
38、te from article where articleid=?”);stmt.setint(1,articleid);stmt.executeupdate();mit(); /事務(wù)提交catch(exception ex)ex.printstacktrace();try conn.rollback(); /操作不成功則回滾catrch(exception e) e.printstacktrace();finallytry stmt.close(); conn.close();catch(exception e) e.printstacktrace();由于每一篇日志允許用戶進(jìn)行評(píng)論,日志可
39、能有相應(yīng)的日志評(píng)論,在進(jìn)行日志刪除操作時(shí),得先刪除該日志的所有評(píng)論,然后刪除該日志。為了保持?jǐn)?shù)據(jù)庫(kù)中的數(shù)據(jù)一致性,本系統(tǒng)采用事務(wù)來(lái)完成該刪除操作。在數(shù)據(jù)庫(kù)操作中,一項(xiàng)事務(wù)是指由一條或多條數(shù)據(jù)庫(kù)更新的sql語(yǔ)句所組成的一個(gè)不可分割的工作單元。只有當(dāng)事務(wù)中所有操作都正常完成,整個(gè)事務(wù)才能被提交到數(shù)據(jù)庫(kù);如果有一項(xiàng)操作沒(méi)有完成,就必須撤銷整個(gè)事務(wù)。1.5相冊(cè)上傳界面,這里可以從本地上傳自己喜歡并且想要長(zhǎng)時(shí)間保存的照片圖7-5上傳照片的界面2配置源程序3附加數(shù)據(jù)庫(kù)mysql(1)將myblogdatebase文件夾中的擴(kuò)展名為db_blog_data.mdf和db_blog_log.ldf的兩個(gè)文件拷
40、貝到sql server安裝路徑下的data文件夾中。(2)將彈出“附加數(shù)據(jù)庫(kù)”對(duì)話框,在該對(duì)話框中單擊【】按鈕,選擇所要附加數(shù)據(jù)庫(kù)的db_blog_data.mdf文件,單擊【確定】按鈕,即可完成數(shù)據(jù)庫(kù)的附加操作。3.1需要導(dǎo)入的包在連接數(shù)據(jù)庫(kù)時(shí)需要用到以下三個(gè)包:msbase.jar、mssqlserver.jar和msutil.jar,將這三個(gè)包拷貝到web應(yīng)用下的 web-inflib目錄下即可。4將程序發(fā)布到tomcat下(1)將“myblog”文件夾拷貝到tomcat安裝路徑下的webapps文件夾中。(2)選擇開(kāi)始菜單中的“所有程序apache tomcat 6.0monitor
41、 tomcat”命令,這時(shí)在windows的系統(tǒng)托盤中會(huì)顯示標(biāo)識(shí)tomcat服務(wù)器啟動(dòng)狀態(tài)的圖標(biāo),如果顯示為,則說(shuō)明tomcat服務(wù)器沒(méi)有啟動(dòng),這時(shí)可以在該圖標(biāo)上單擊鼠標(biāo)右鍵在彈出的快捷菜單中選擇“start service”菜單項(xiàng)啟動(dòng)tomcat服務(wù)器,啟動(dòng)后將顯示為。(3)打開(kāi)ie瀏覽器,在地址欄中輸入http:/localhost:8080/,進(jìn)入“tomcat軟件管理”頁(yè)面。注意:8080為安裝tomcat時(shí)設(shè)置的端口號(hào)。(4)單擊tomcat manager超鏈接,彈出“連接到 localhost”對(duì)話框。(5)在用戶名及密碼處輸入登錄tomcat的用戶名和密碼,單擊【確定】按鈕。(
42、6)進(jìn)入“tomcat應(yīng)用程序管理”頁(yè)面,在此頁(yè)面中單擊“myblog”,進(jìn)入本程序主頁(yè)面,完成tomcat配置。5公共核心類的設(shè)計(jì)5.1數(shù)據(jù)庫(kù)相關(guān)訪問(wèn)數(shù)據(jù)庫(kù)相關(guān)類如下:a)獲取數(shù)據(jù)源,其代碼如下:public static connection getconnection()try context ctx=(context)new initialcontext().lookup(contants.env);datasource ds=(datasource)ctx.lookup(constants.jdbc);getconnection()方法:該方法通過(guò)context類提供的lookup(
43、)方法查找數(shù)據(jù)源,從而獲得jdbc/blog數(shù)據(jù)源的引用,得到datasource對(duì)象的引用后,就可以通過(guò)datasource的getconnection()方法獲得數(shù)據(jù)庫(kù)連接對(duì)象。b)連接數(shù)據(jù)庫(kù)和操作數(shù)據(jù)庫(kù);代碼如下: / 構(gòu)造數(shù)據(jù)庫(kù)的連接和訪問(wèn)類public dbconnect() throws exception / 獲得數(shù)據(jù)庫(kù)連接對(duì)象conn=db.getconnection();/ 創(chuàng)建一個(gè)jdbc聲明stmt = conn.createstatement();/ 預(yù)設(shè)sql語(yǔ)句public void preparestatement(string sql) throws sqlex
44、ception prepstmt = conn.preparestatement(sql);/ 設(shè)置索引值位置的對(duì)應(yīng)值public void setstring(int index, string value) throws sqlexception prepstmt.setstring(index, value);public void setint(int index, int value) throws sqlexception prepstmt.setint(index, value);/ 執(zhí)行sql語(yǔ)句并返回字段集public resultset executequery() thr
45、ows sqlexception if (prepstmt != null) return prepstmt.executequery(); elsereturn null;dbconnect()方法:該方法主要負(fù)責(zé)獲得數(shù)據(jù)庫(kù)連接對(duì)象。preparestatement(string sql)方法:該方法主要完成預(yù)設(shè)sql語(yǔ)句,只有一個(gè)用來(lái)接收sql語(yǔ)句的參數(shù),如果sql語(yǔ)句有誤將拋出異常。setstring(int index, string value)方法:該方法用于設(shè)置預(yù)設(shè)sql語(yǔ)句中的相應(yīng)字段值,index表示索引位置,value表示需設(shè)置字符串類型的值。setint(int inde
46、x, int value)方法:該方法用于預(yù)設(shè)sql語(yǔ)句中的相應(yīng)字段值,index表示索引位置,value表示需設(shè)置整型類型的值。executequery()方法:該方法用于執(zhí)行預(yù)設(shè)的sql語(yǔ)句。5.2.2編寫(xiě)javabean類為每一個(gè)數(shù)據(jù)庫(kù)表建一個(gè)javabean類,完成對(duì)該表字段的獲取和設(shè)置。博客信息管理系統(tǒng)所用的javabean類列表如表5.1所示。表5-1 javabean類列表javabean類說(shuō)明admin類博客管理員表對(duì)應(yīng)的javabean類article類日志表對(duì)應(yīng)的javabean類word類留言表對(duì)應(yīng)的javabean類photo類相冊(cè)表對(duì)應(yīng)的javabean類review
47、類評(píng)論表對(duì)應(yīng)的javabean類feedback類的代碼如下:public class feedback / 屬性,對(duì)應(yīng)數(shù)據(jù)表中的字段名private int feedbackid;private string title; / 字段的訪問(wèn)和設(shè)置方法public int getfeedbackid() return feedbackid;public void setfeedbackid (int feedbackid) this. feedbackid = feedbackid;feedback類:通過(guò)getfeedbackid()方法獲取feedbackid屬性的值,通過(guò)setfeedba
48、ckid (int feedbackid)方法設(shè)置feedbackid屬性的值。5.2管理類設(shè)計(jì)上面每一個(gè)javabean類都有一個(gè)相對(duì)應(yīng)的管理類,是在javabean類及數(shù)據(jù)庫(kù)相關(guān)類的基礎(chǔ)上完成對(duì)數(shù)據(jù)庫(kù)表的訪問(wèn)、更新、統(tǒng)計(jì)操作。博客信息管理系統(tǒng)所用的管理類列表如表5.2所示。表5-2 管理類列表管理類說(shuō)明word類完成對(duì)博客管理員表的查詢、更新及統(tǒng)計(jì)article類完成對(duì)日志表的查詢、更新及統(tǒng)計(jì)artiletype類完成對(duì)評(píng)論表的查詢、更新及統(tǒng)計(jì)review類完成對(duì)隨筆表的查詢、更新及統(tǒng)計(jì)feedbackmgr類的部分代碼如下:public class feedbackmgr /*添加評(píng)論
49、*/public void add(feedback feedback)dbconnect dbc = null;resultset rs = null;try / 新建數(shù)據(jù)庫(kù)連接和訪問(wèn)對(duì)象dbc = new dbconnect();/ 預(yù)設(shè)sql語(yǔ)句dbc.preparestatement(insert into feedback (title,content,publishtime,lastmodifytime,username,articleid) values ( ?,?,?,?,?,?);/ 設(shè)置對(duì)應(yīng)值dbc.setstring(1, feedback.gettitle();dbc.
50、setstring(2, feedback.getcontent();dbc.setdate(3, new java.sql.date(new java.util.date().gettime();dbc.setdate(4, new java.sql.date(new java.util.date().gettime();dbc.setstring(5, feedback.getusername();dbc.setint(6, feedback.getarticleid();/ 執(zhí)行該更新語(yǔ)句dbc.executeupdate();/* * 查詢所有評(píng)論(按最后修改時(shí)間) */public
51、collection getallbylastmodifytime() dbconnect dbc = null;collection c = new arraylist();resultset rs = null;try / 新建數(shù)據(jù)庫(kù)連接和訪問(wèn)對(duì)象dbc = new dbconnect();/ 執(zhí)行sql語(yǔ)句,返回字段集rs=dbc.executequery(select * from feedback order by lastmodifytime desc);feedback feedback = null;while (rs.next() / 新建評(píng)論對(duì)象feedback = new feedback();/ 設(shè)置評(píng)論對(duì)象相關(guān)的屬性 feedback.setfeedbackid(rs.getint(feedbackid); feedback.settitle(rs.getstring(title); feedback.setcontent(rs.getstring(content); feedback.setstrpublishtim
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 買車車位合同范本
- 個(gè)體鋪面出租合同范本
- 冷凍肉購(gòu)銷合同范本
- 咸陽(yáng)市1號(hào)橋施工方案
- 低價(jià)轉(zhuǎn)讓房子合同范本
- 出口英文合同范本
- 買賣訴訟合同范本
- 勞務(wù)扎鋼筋合同范本
- 農(nóng)村耕地長(zhǎng)期轉(zhuǎn)讓合同范本
- 保定勞務(wù)合同范本
- 《ISO 41001-2018 設(shè)施管理- 管理體系 要求及使用指南》專業(yè)解讀與應(yīng)用指導(dǎo)材料之15:“7支持-7.6 組織知識(shí)”(雷澤佳編制-2024)
- 2024年建設(shè)工程質(zhì)量檢測(cè)人員-建設(shè)工程質(zhì)量檢測(cè)人員(主體結(jié)構(gòu)工程)考試近5年真題集錦(頻考類試題)帶答案
- 《向量共線定理》同步課件
- 小學(xué)數(shù)學(xué)學(xué)習(xí)經(jīng)驗(yàn)交流課件
- 2024年第二批政府專職消防員招錄報(bào)名表
- 2024年初級(jí)消防員職業(yè)技能鑒定考試復(fù)習(xí)題庫(kù)(單選、多選題)
- 注塑模具基礎(chǔ)知識(shí)
- 2024年單招考試題
- 三年級(jí)數(shù)學(xué)下冊(cè)期末測(cè)試卷及答案【可打印】
- 蘇教版小學(xué)語(yǔ)文上冊(cè)教學(xué)研究論文
- 片狀鋅粉行業(yè)分析!中國(guó)片狀鋅粉行業(yè)市場(chǎng)發(fā)展前景研究報(bào)告(2024版)
評(píng)論
0/150
提交評(píng)論