畢業(yè)論文---網(wǎng)絡(luò)聊天室的規(guī)劃和設(shè)計_第1頁
已閱讀1頁,還剩20頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  畢業(yè)設(shè)計(論文)</b></p><p>  題 目 網(wǎng)絡(luò)聊天室的規(guī)劃和設(shè)計</p><p><b>  摘 要 </b></p><p>  聊天室主要分為WebChat、BBSChat兩種。BBSChat是基于Telnet的Tcp協(xié)議,是BBS的附設(shè)功能,需要客戶端Telnet

2、程序。WebChat則采用瀏覽器方式,實際上是一個多人共同使用的CGI程序。其基本原理是把每個用戶的發(fā)言通過瀏覽器傳給系統(tǒng),再由系統(tǒng)收集處理后分發(fā)給特定用戶。</p><p>  下面所做的是一個利用ASP.NET技術(shù)、數(shù)據(jù)庫技術(shù)、#C語言、ADO.NET技術(shù)制作的功能比較完善的文本聊天室。</p><p>  關(guān)鍵詞:ASP.NET技術(shù),數(shù)據(jù)庫技術(shù),#C語言,ADO.NET技術(shù)</

3、p><p><b>  目 錄</b></p><p><b>  第一章 引言8</b></p><p>  第二章 相關(guān)技術(shù)9</p><p>  2.1 ASP.NET技術(shù)9</p><p>  2.2 數(shù)據(jù)庫技術(shù)10</p><p>

4、  2.3 C#語言10</p><p>  2.4 ADO.NET技術(shù)11</p><p>  第三章 需求分析與總體設(shè)計13</p><p>  3.1 需求分析13</p><p>  3.1.1 功能需求13</p><p>  3.1.2 性能需求13</p><p>  

5、3.2系統(tǒng)環(huán)境13</p><p>  3.2.1系統(tǒng)運行環(huán)境13</p><p>  3.2.2系統(tǒng)開發(fā)環(huán)境14</p><p>  3.3 系統(tǒng)框架14</p><p>  3.3.1 系統(tǒng)流程分析14</p><p>  3.3.2 系統(tǒng)功能模塊分析15</p><p>  第

6、四章 具體實現(xiàn)17</p><p>  4.1 數(shù)據(jù)庫的實現(xiàn)17</p><p>  4.1.1 創(chuàng)建表17</p><p>  4.1.2 創(chuàng)建存儲過程18</p><p>  4.2 主要界面及相關(guān)代碼的實現(xiàn)19</p><p>  4.2.1 用戶注冊頁面19</p><p>

7、  4.2.2 用戶登錄頁面22</p><p>  4.2.3 管理員管理頁面25</p><p>  4.2.4用戶信息顯示頁面28</p><p>  4.2.5 取回密碼頁面30</p><p>  4.2.6聊天室主頁33</p><p><b>  第五章 結(jié)論36</b>

8、</p><p>  第六章 參考文獻(xiàn)37</p><p><b>  第七章 謝辭38</b></p><p><b>  第一章 引言</b></p><p>  隨著網(wǎng)絡(luò)的普及和人們溝通的需要,網(wǎng)絡(luò)聊天室已經(jīng)成為人們溝通的一個重要工具。許多大型的門戶網(wǎng)站都提供功能完善的www聊天室系統(tǒng),而

9、這些聊天室系統(tǒng)逐漸成為年輕人認(rèn)識朋友,交流感情的好場所,隨著網(wǎng)絡(luò)速度的提高,目前許多服務(wù)商推出了多媒體聊天室,能夠支持語音聊天,視頻聊天以及文本聊天。</p><p>  聊天室主要分為WebChat、BBSChat兩種。BBSChat是基于Telnet的Tcp協(xié)議,是BBS的附設(shè)功能,需要客戶端Telnet程序。WebChat則采用瀏覽器方式,實際上是一個多人共同使用的CGI程序。其基本原理是把每個用戶的發(fā)言通

10、過瀏覽器傳給系統(tǒng),再由系統(tǒng)收集處理后分發(fā)給特定用戶。</p><p>  下面所做的是一個功能比較完善的文本聊天室。本網(wǎng)站以網(wǎng)絡(luò)交友為主,為廣大用戶提供一個借助網(wǎng)絡(luò)進(jìn)行人際交往的平臺,也是網(wǎng)絡(luò)與現(xiàn)實最貼近的實用型網(wǎng)站。</p><p><b>  第二章 相關(guān)技術(shù)</b></p><p>  2.1 ASP.NET技術(shù)</p>&

11、lt;p>  Asp.net是建立在通用語言運行時刻庫(CLR)上的應(yīng)用程序框架。他用來在服務(wù)器端構(gòu)建功能強大的web應(yīng)用程序。Asp.net提供了幾個超越以前web開發(fā)模式的優(yōu)點: </p><p>  ·增強的性能。Asp.net是運行在服務(wù)器端的編譯后的CLR代碼,而不是像ASP那樣解釋執(zhí)行。 </p><p>  ·Asp.net利用提前綁定,即時編譯,本

12、地優(yōu)化和緩存服務(wù)來提高性能。所有這一切,性能遠(yuǎn)遠(yuǎn)大于你以往寫的每一行代碼。 </p><p>  ·世界級水平的開發(fā)工具支持。在Visual Studio .net的集成開發(fā)環(huán)境(IDE)中,Asp.net框架由豐富的工具箱和設(shè)計器組成。所見即所得的(WYSIWYG)編輯方式、拖放服務(wù)器控件、以及自動部署,僅僅是這一強大工具所提供的一少部分功能。 </p><p>  ·

13、;強大而富有彈性。由于asp.net是基于(CLR)的,因此整個.net平臺的強大和富有彈性,同樣可以應(yīng)用于web應(yīng)用程序開發(fā)者。.net框架的類庫、消息以及數(shù)據(jù)訪問解決方案,都可以無縫集成到web。Asp.net也是語言中立的,因此你可以選擇你最熟悉的語言,或者通過幾種語言來共同完成一個應(yīng)用。而且,CLR的互用性可以保證你升級到asp.ent的時候,現(xiàn)存的基于COM的開發(fā)投資依然保留。 </p><p>  &

14、#183;簡單。Asp.net使執(zhí)行常用的工作變得很容易,比如從簡單的表單提交、客戶端驗證,到部署和站點配置。例如,asp.net允許你建立用戶接口,實現(xiàn)頁面和邏輯代碼的分離,同時,就像vb的表單執(zhí)行模式那樣來處理事件(也就是說,由頁面驅(qū)動模式變成了事件驅(qū)動模式)。此外,CLR簡化了部署,用來管理代碼服務(wù),例如自動參照和垃圾回收。 </p><p>  ·易于管理。Asp.net使用一個基于文本的、分層

15、次的配置系統(tǒng),它簡化了服務(wù)器端環(huán)境和web應(yīng)用程序的設(shè)置。由于配置信息用純文本格式保存,新的設(shè)置不需要本地管理工具的支持。這種“零本地支持”的理念也同樣應(yīng)用到了部署asp.net應(yīng)用程序。Asp.net應(yīng)用程序部署到服務(wù)器,簡化為復(fù)制必要的文件到服務(wù)器。在部署,甚至替換正在運行的變異代碼的時候,也不需要重新啟動服務(wù)器。 </p><p>  ·可伸縮性和有效利用性。Asp.net被設(shè)計成可伸縮的,能為集

16、群和多處理器環(huán)境設(shè)計提高性能。而且,asp.net運行時刻密切監(jiān)視和管理進(jìn)程,這樣,如果發(fā)生了錯誤的行為,例如漏洞和死鎖,新的進(jìn)程會在當(dāng)前位置建立,來幫助你的應(yīng)用程序繼續(xù)處理事件請求。 </p><p>  ·可訂制和擴展。Asp.net提供一種良好的擴充結(jié)構(gòu),允許開發(fā)者在適當(dāng)?shù)募墑e“插入”他們的代碼。事實上,使用自己的編寫的組件可以擴展或者替換asp.net運行時刻的任何子組件。執(zhí)行自定義驗證或狀態(tài)服

17、務(wù)變得前所未有的容易。 </p><p>  ·安全性。內(nèi)建的windows驗證和每一個應(yīng)用程序的獨立配置,你可以認(rèn)為你的應(yīng)用程序是安全的。</p><p><b>  2.2 數(shù)據(jù)庫技術(shù)</b></p><p>  SQL Server是一個關(guān)系型數(shù)據(jù)庫引擎,只要一套系統(tǒng)就既能支持小型數(shù)據(jù)庫,也能支持企業(yè)級大型數(shù)據(jù)庫。數(shù)據(jù)庫系統(tǒng)的管

18、理工作包括許多富于挑戰(zhàn)性的任務(wù),特別是運行性能的管理工作。它采用了多線程技術(shù),支持存儲過程,采用基于成本的優(yōu)化技術(shù),在核心層實現(xiàn)數(shù)據(jù)完整性約束,并具有很強的安全保密性。它的工作主要是負(fù)責(zé)高速計算,數(shù)據(jù)管理,安全性及事務(wù)管理。</p><p>  SQL Server2000在SQL Server7.0的基礎(chǔ)上新增了許多的功能,使得用戶能更方便、更快捷的管理數(shù)據(jù)庫和開發(fā)應(yīng)用程序。SQL Server2000最常用的

19、是企業(yè)管理器。通過企業(yè)管理器可以方便的可視化的建立起數(shù)據(jù)庫系統(tǒng),從而可以在對SQL不是很精通的情況下,一樣建立起一個良好的數(shù)據(jù)庫來。</p><p>  企業(yè)管理器是一個集成化的數(shù)據(jù)庫操作環(huán)境,幾乎所有的數(shù)據(jù)庫操作都可以在這里里面完成。它是SQL Server 2000的主要管理工具,提供了一個遵從微軟管理控制臺的用戶界面,使用戶可以進(jìn)行如下的操作:</p><p>  ·定義運

20、行SQL Server的服務(wù)器組。</p><p>  ·將個別服務(wù)器注冊到組中。</p><p>  ·為每個已注冊的服務(wù)器配置所有SQL Server選項。</p><p>  ·在每個已注冊的服務(wù)器中創(chuàng)建并管理所有SQL Server數(shù)據(jù)庫、對象、登錄、用戶和權(quán)限。</p><p>  ·在每個已

21、注冊的服務(wù)器上定義并執(zhí)行所有SQL Server管理任務(wù)。</p><p>  ·通過調(diào)用SQL查詢分析器,交互的設(shè)計并測試SQL語句、批處理和腳本。</p><p>  ·調(diào)用為SQL Server定義的各種向?qū)А?lt;/p><p>  結(jié)構(gòu)化查詢語言SQL(Structured Query Language)是一種介于關(guān)系代數(shù)與關(guān)系演算之間的語

22、言,其功能包括查詢、操縱、定義和控制4個方面,是一種通過的、功能極強的關(guān)系數(shù)據(jù)庫語言。目前已成為關(guān)系數(shù)據(jù)庫的標(biāo)準(zhǔn)語言。常用的功能包括數(shù)據(jù)定義、查詢、數(shù)據(jù)更新和視圖。</p><p>  要在良好的SQL Server方案中實現(xiàn)最優(yōu)的性能,最關(guān)鍵的是要有1個很好的數(shù)據(jù)庫設(shè)計方案。在實際工作中,許多SQL Server方案往往是由于數(shù)據(jù)庫設(shè)計得不好導(dǎo)致性能很差。所以,要實現(xiàn)良好的數(shù)據(jù)庫設(shè)計就必須考慮這些問題。<

23、/p><p><b>  2.3 C#語言</b></p><p>  C#是一種面向?qū)ο蟮某绦蛟O(shè)計語言,它的基本語法與C/C++相同,其將軟件開發(fā)中的邏輯分成5大部分:商業(yè)外觀層(BusinessFacade),商業(yè)規(guī)則層(BusinessRules),數(shù)據(jù)訪問層(DataAccess),Model層等。這種邏輯上的劃分使得軟件的開發(fā)更加方便,并使語句和數(shù)據(jù)庫的訪問分開

24、,而由商業(yè)規(guī)則層單獨提出規(guī)則,便于軟件的擴展和維護(hù)。</p><p>  2.4 ADO.NET技術(shù)</p><p>  ADO.NET是在.NET Framework平臺中負(fù)責(zé)數(shù)據(jù)存儲的對象。ADO.NET是Active Data Objects2.6(ADO)的后續(xù)版本。ADO.NET的主要目的是可以在.NET Framework中更容易的創(chuàng)建分布式的數(shù)據(jù)共享的應(yīng)用程序。ADO.NET

25、建立在如XML的業(yè)界的基礎(chǔ)之上,就像ADO,它提供了一個數(shù)據(jù)訪問接口,以便和OLE DB兼容的數(shù)據(jù)源進(jìn)行通信,如SQL Server或Oracle。應(yīng)用程序可以使用ADO.NET連接這些數(shù)據(jù)源,并檢索,處理和更新數(shù)據(jù)。</p><p>  可能大家已經(jīng)學(xué)過ADO,那么在舊版本還能正常工作時,為什么還要學(xué)習(xí)新的數(shù)據(jù)訪問對象模型呢?如果需要,也可以在NET.Framework中使用ADO,但需要為COM層方面付出一些

26、性能上的代價,另外,NET.Framework并不支持COM Variant數(shù)據(jù)類型,這是ADO用于Recordset對象中的Field對象值的數(shù)據(jù)類型,也就是說,如果在.NET中使用ADO Recordset對象,為了訪問數(shù)據(jù),NETCLR就經(jīng)常會對每個字段進(jìn)行類型轉(zhuǎn)換,如果要一直訪問數(shù)據(jù),進(jìn)行這些類型轉(zhuǎn)換就會造成太大的系統(tǒng)開銷。 使用ADO.NET最重要的理由是可以獲取一個真正斷開連接的數(shù)據(jù)體系結(jié)構(gòu)和XML的緊密集成和一個通用

27、的數(shù)據(jù)表示法,可以將各種不同數(shù)據(jù)源中的數(shù)據(jù)組合起來,并優(yōu)化了和數(shù)據(jù)庫交互的功能,同樣ADO.NET和NET.Framework的其它部分緊密的集成在一起,并充分利用NET.Framework中所有對象的層結(jié)構(gòu)及設(shè)計模式。ADO.NET建立在ADO的基礎(chǔ)之上,而且為數(shù)據(jù)訪問工具集提供了許多工具。</p><p>  ADO.NET的特點</p><p>  · ADO.NET使用不

28、連接的數(shù)據(jù)結(jié)構(gòu);</p><p>  · 數(shù)據(jù)被緩存到數(shù)據(jù)集內(nèi);</p><p>  · 數(shù)據(jù)集獨立于數(shù)據(jù)源;</p><p>  · 數(shù)據(jù)保持為XML</p><p>  數(shù)據(jù)需要從數(shù)據(jù)存儲區(qū)移動到數(shù)據(jù)集以及從數(shù)據(jù)集移動到各種組件,在ADO.NET中,傳統(tǒng)數(shù)據(jù)的格式是XML。類似地,如果需要保持?jǐn)?shù)據(jù),則將其存儲

29、為XML,如果有XML文件,則可以像使用任何數(shù)據(jù)源一樣使用它,并從它創(chuàng)建數(shù)據(jù)集。</p><p>  實際上,在ADO.NET,XML是數(shù)據(jù)的基本格式,ADO.NET數(shù)據(jù)API自動用數(shù)據(jù)集內(nèi)的信息創(chuàng)建XML文件或流,并將它們發(fā)送給另一個組件,第二個組件可以調(diào)用類似的API將XML讀回數(shù)據(jù)集。</p><p>  · 使數(shù)據(jù)協(xié)議以XML為基礎(chǔ)可提供一個多便利之處,XML是工業(yè)標(biāo)準(zhǔn)格

30、式。這意味著你的應(yīng)用程序數(shù)據(jù)組件可以與其他任何應(yīng)用程序中其他任何組件交換數(shù)據(jù),只要該組件理解為XML,許多應(yīng)用程序被編寫為可理解XML,為異類應(yīng)用程序間交換提供空前高的水平。</p><p>  ·XML是基于文本的,數(shù)據(jù)的XML表示形式不使用任何二進(jìn)制信息,這使它可以通過任何協(xié)議發(fā)送,大多數(shù)防火墻將阻塞二進(jìn)制信息,但通過將信息格式化為XML,組件仍可以方便的交換信息。對于大多數(shù)方案,不必知道XML便可

31、以使用ADO.NET中的數(shù)據(jù)。ADO.NET自動根據(jù)需要將數(shù)據(jù)轉(zhuǎn)換為XML或XML自動根據(jù)需要將數(shù)據(jù)轉(zhuǎn)化為ADO.NET,便使用普通編程的方法與數(shù)據(jù)進(jìn)行交互。</p><p>  · 架構(gòu)定義數(shù)據(jù)結(jié)構(gòu)</p><p>  盡管不必知道有關(guān)XML的任何事情便可以讀寫數(shù)據(jù)庫和數(shù)據(jù)集,但也有一些事情使用XML恰是你追求的標(biāo)準(zhǔn)。不打算訪問數(shù)據(jù)而要進(jìn)行數(shù)據(jù)設(shè)計時的情況,也就是,在ADO.N

32、ET中使用元數(shù)據(jù)時,將直接使用XML。</p><p>  數(shù)據(jù)集以XML表示,數(shù)據(jù)集的結(jié)構(gòu)使用XML架構(gòu)進(jìn)行定義,就像數(shù)據(jù)集包含的數(shù)據(jù)可以從XML加載和序列化為XML,數(shù)據(jù)集的結(jié)構(gòu)也可以從XSD架構(gòu)和序列化為XSD架構(gòu)。</p><p>  對ADO.NET中的數(shù)據(jù)進(jìn)行的大部分操作,不必深入鉆研架構(gòu)。通常,基于Visual Studio.NET工具將可以在可視化設(shè)計器中進(jìn)行操作,并根據(jù)需

33、要生成和更新架構(gòu)。</p><p>  ADO.NET中的連接是在每個托管提供程序中,一單個connection類的形式來建模的。Connection類表示到一個數(shù)據(jù)源的單個連接,但并非一定表示單個調(diào)用。ADO.NET是為斷開數(shù)據(jù)而設(shè)計的,所以必須為重復(fù)打開和關(guān)閉連接提供connection類。創(chuàng)建好connection對象后,接著要設(shè)置連接字符串,它描述了數(shù)據(jù)源的位置(本地數(shù)據(jù)庫服務(wù)器)。接著,我們打開連接并在

34、ADO.NET數(shù)據(jù)庫上執(zhí)行一個命令。一旦檢索到相關(guān)數(shù)據(jù),就關(guān)閉連接。完成對數(shù)據(jù)的處理之后,就可以重新打開連接,并繼續(xù)操縱相同的數(shù)據(jù)元。數(shù)據(jù)處理期間,數(shù)據(jù)庫的連接處于釋放狀態(tài),所以數(shù)據(jù)庫服務(wù)器的復(fù)合大大的減輕了。需要時,我們在重新建立連接。雖然重新建立連接會產(chǎn)生一定的開銷,但利用ADO.NET的連接池功能,就可以盡可能的減少這種開銷。</p><p>  我們將數(shù)據(jù)庫連接字符串放在web.config文件中,便于運

35、用連接池,提高系統(tǒng)的性能。</p><p>  第三章 需求分析與總體設(shè)計</p><p><b>  3.1 需求分析</b></p><p>  3.1.1 功能需求</p><p>  · 能夠注冊用戶,管理用戶信息,獲取登錄用戶的IP;</p><p>  · 聊天者把

36、語句寫入文本,輸出到屏幕上;</p><p>  · 瀏覽器不斷的對屏幕輸出進(jìn)行刷新、讀??;</p><p>  · 實時更新在線的客戶;</p><p>  · 能夠公開聊天、私下聊天等等;</p><p>  · 管理員對聊天者進(jìn)行管理,能夠禁止某用戶或者IP登錄,把用戶踢出聊天室等等</p&

37、gt;<p>  3.1.2 性能需求</p><p>  在聊天室沒有滿員的情況下,普通用戶能夠登錄的聊天室進(jìn)行文本的聊天,能夠方便的實現(xiàn)公共交談、選擇顏色、添加表情、進(jìn)行私聊等,新用戶注冊時能夠保證用戶昵稱的唯一性。網(wǎng)絡(luò)管理員能夠方便的瀏覽所有用戶的信息,能夠禁止某用戶或者IP登錄,把用戶踢出聊天室等等。考慮到需要驗證的內(nèi)容,聊天室能容納的用戶不能太多,在本聊天室中設(shè)置最多可以容納20個用戶。在

38、程序中使用Application(“usercount”)來標(biāo)記當(dāng)前的用戶數(shù),在進(jìn)入聊天室之前首先監(jiān)測聊天室是否已滿,如果已經(jīng)達(dá)到極限人數(shù),則不允許任何用戶登錄。在登錄時用Session["upower"]來判斷用戶的權(quán)限,如果是普通用戶通過驗證后會進(jìn)入聊天室主頁,如果是管理員則會進(jìn)入管理員管理管理頁面。</p><p><b>  3.2系統(tǒng)環(huán)境</b></p&g

39、t;<p>  由于本系統(tǒng)采用了Visual Studio.NET設(shè)計,故可以運行在所有支持.NET虛擬機的系統(tǒng)中。</p><p>  3.2.1系統(tǒng)運行環(huán)境</p><p><b>  硬件配置:</b></p><p>  CPU:400HZ Pentium處理器、或者AMD處理器 內(nèi)存:128M 硬盤:800M自由空間

40、. 顯示器分辨率:不低于800*600 4、所需軟件 IIS 5.0或者IIS 5.5 或者IIS 6.0 .NET Framework 1.1 或者 .net Framework 2.0 beta Microsoft Access、SQL Server 2000 </p><p><b>  軟件環(huán)境:</b></p><p>  所需要的操作系統(tǒng): Wi

41、ndows 2000 Server </p><p>  瀏覽要求 :不低于IE 5.5 </p><p>  3.2.2系統(tǒng)開發(fā)環(huán)境</p><p><b>  硬件配置:</b></p><p>  CPU:400HZ Pentium處理器、或者AMD處理器 內(nèi)存:128M 硬盤:800M自由空間. 顯示器分辨

42、率:不低于800*600 4、所需軟件 IIS 5.0或者IIS 5.5 或者IIS 6.0 .NET Framework 1.1 或者 .net Framework 2.0 beta Microsoft Access、SQL Server 2000 </p><p><b>  軟件環(huán)境:</b></p><p>  操作系統(tǒng):開發(fā)環(huán)境所在的系統(tǒng)為Windo

43、ws2000 Server。 </p><p>  數(shù)據(jù)庫:使用Microsoft SQL Server 2000 數(shù)據(jù)庫。</p><p>  開發(fā)工具:使用Visual Studio.NET編程語言,版本為Microsoft Visual Studio.NET 2003。</p><p><b>  3.3 系統(tǒng)框架</b></p&g

44、t;<p>  3.3.1 系統(tǒng)流程分析</p><p><b>  流程圖:</b></p><p><b>  進(jìn)入</b></p><p><b>  圖1 系統(tǒng)流程圖</b></p><p>  3.3.2 系統(tǒng)功能模塊分析</p><

45、p>  在此聊天室的完成過程中我主要做用戶管理,如注冊、刪除、對用戶的聊天內(nèi)容限制、禁用某用戶或某IP,下面我主要對這幾部分的功能進(jìn)行分析:</p><p>  用戶登錄界面(Login.aspx):管理員和普通用戶我都用這一個界面,在數(shù)據(jù)庫的用戶表中我設(shè)置了一個用戶級別的字段,用于區(qū)分普通用戶和管理員,在程序中用Session(“UPower”)來保存用戶的權(quán)限,如果是0則為管理員通過驗證后會進(jìn)入管理員管

46、理頁面,如果是1通過驗證后會進(jìn)入聊天室主頁可以進(jìn)行聊天。</p><p>  用戶注冊頁面(register.aspx):此頁面用于新用戶注冊,將新用戶信息保存數(shù)據(jù)庫中,此過程要保證用戶的昵稱不能有重復(fù),另外要取得登錄用戶的IP地址保存到數(shù)據(jù)庫中。</p><p>  管理員管理頁面(manage.aspx):管理員能夠瀏覽用戶的信息,能夠根據(jù)用戶名或者用戶的IP地址剔除用戶。</p

47、><p>  取回密碼頁面(takepwd.aspx):如果用戶已經(jīng)注冊過,但由于某種原因忘記密碼了,可以進(jìn)入此頁面取回用戶的密碼。密碼將被發(fā)送到用戶注冊的郵箱當(dāng)中。</p><p><b>  第四章 具體實現(xiàn)</b></p><p>  4.1 數(shù)據(jù)庫的實現(xiàn)</p><p>  管理數(shù)據(jù)庫和數(shù)據(jù)庫對象當(dāng)你使用SQL se

48、rver時,面臨的第一個任務(wù)就是創(chuàng)建一個新的數(shù)據(jù)庫。SQL server提供了三種不同的方式用于創(chuàng)建新數(shù)據(jù)庫:</p><p>  ·使用創(chuàng)建數(shù)據(jù)庫向?qū)?lt;/p><p>  ·使用SQL server Enterprise Manager</p><p>  ·使用Transact-SQL語言</p><p> 

49、 創(chuàng)建數(shù)據(jù)庫向?qū)龑?dǎo)你完成整個的數(shù)據(jù)庫創(chuàng)建過程。使用向?qū)В合葐螕鬍nterprise Manager工具欄中的Run a wizard 按紐,然后選擇Database文件夾,雙擊相應(yīng)的向?qū)А?lt;/p><p>  使用Enterprise manager創(chuàng)建數(shù)據(jù)庫:單擊工具欄NEW DATABASE按紐(注意:無論是創(chuàng)建數(shù)據(jù)庫向?qū)н€是NEW DATABASE按紐,都只是在選擇了服務(wù)器或是選擇它的一個子實體后才會出

50、現(xiàn))。另一種辦法是:在DATABASE文件家上單擊右鍵(該文件家出現(xiàn)在服務(wù)器層次之下)并選擇NEW DATABASE。使用DATABASE PROPRETEES對話框可以顯示或設(shè)置新數(shù)據(jù)庫所有屬性。</p><p>  本系統(tǒng)中用到的數(shù)據(jù)庫使用SQL server Enterprise Manager來創(chuàng)建,程序中的用的sql命令多用存儲過程實現(xiàn)。</p><p><b>  4

51、.1.1 創(chuàng)建表</b></p><p>  下面為數(shù)據(jù)庫表USERS(表1)</p><p>  表1 users表結(jié)構(gòu)</p><p>  4.1.2 創(chuàng)建存儲過程</p><p>  /*下面存儲過程為用戶注冊所用,用于向數(shù)據(jù)庫中添加新用戶*/</p><p>  CREATE PROCEDURE p

52、rocAddUsers</p><p>  ( @name varchar(50),@password varchar(50),</p><p>  @tname varchar(50),@age int,</p><p>  @school varchar(50),@Tel varchar(50),</p><p>  @email var

53、char(50),@ip varchar(50)) </p><p>  AS INSERT INTO users</p><p>  (UName,UPassword,Tname,Age,School,Tel,Email,UPower,UIP)</p><p><b>  VALUES</b></p><p>  (@

54、name,@password,@tname,@age,@school,@Tel,@email,'1',@ip)</p><p><b>  GO</b></p><p>  /*下面存儲過程為根據(jù)用戶IP地址來刪除用戶*/</p><p>  CREATE PROCEDURE procDelByIP</p><

55、;p>  (@ip varchar(50))</p><p>  AS delete users where UIP=@ip</p><p><b>  GO</b></p><p>  CREATE PROCEDURE procDelByName</p><p>  (@uname varchar(50))

56、</p><p>  AS delete users </p><p>  where uname=@uname</p><p><b>  GO</b></p><p>  /*下面存儲過程為用戶登錄所用,用于檢索數(shù)據(jù)庫中是否存在登錄用戶的紀(jì)錄*/</p><p>  CREATE PROCE

57、DURE procLogin</p><p>  (@uname varchar(50),@password varchar(50))</p><p>  AS select * from users</p><p>  where UName=@uname and UPassword=@password</p><p><b>

58、  GO</b></p><p>  /*此存儲過程用于檢索所有的注冊用戶*/</p><p>  CREATE PROCEDURE procUsers</p><p>  AS select * from users</p><p><b>  GO</b></p><p>  4

59、.2 主要界面及相關(guān)代碼的實現(xiàn)</p><p>  4.2.1 用戶注冊頁面</p><p>  昵稱是用于代表聊天室用戶的身份,不能重復(fù)。用戶在注冊時為了避免用戶重名,必須驗證用戶昵稱。如果在聊天室中已經(jīng)存在該用戶昵稱,則要求用戶更改昵稱之后才能進(jìn)入聊天室。設(shè)計此界面要注意的問題:加入asp:RequiredFieldValidator驗證控件保證必須填寫的字段不能為空;加入asp:Re

60、gularExpressionValidator驗證控件保證輸入的郵箱必須是電子郵箱的正確格式;加入asp:CompareValidator驗證控件保證輸入的密碼和驗證密碼必須一致。</p><p><b>  圖2 用戶注冊</b></p><p>  如果是注冊成功,則會出現(xiàn)圖3所示的頁面,可以返回到登錄頁面登錄到聊天室主頁當(dāng)中,數(shù)據(jù)庫中就會添加上一條紀(jì)錄。注意的

61、問題:由于必添項中都加了驗證控件,不能為空,否則不能注冊,郵箱必須是正確的格式,否則提示錯誤。</p><p><b>  注冊成功后的頁面:</b></p><p>  圖3 用戶注冊成功提示頁面</p><p>  可以查看一下數(shù)據(jù)庫中的用戶信息,沒有注冊前為圖9所示,注冊后添加了一條紀(jì)錄,如圖4所示。</p><p&g

62、t;  圖4 顯示用戶信息頁面</p><p><b>  主要代碼:</b></p><p>  //次過程用于響應(yīng)注冊按鈕</p><p>  private void btnRegister_Click(object sender, System.EventArgs e)</p><p><b>  {&

63、lt;/b></p><p><b>  try</b></p><p>  {//從文件web.config中讀取連接字符串</p><p>  string strconn=ConfigurationSettings.AppSettings["chat"];</p><p>  //連接本地

64、計算機的chat數(shù)據(jù)庫</p><p>  SqlConnection conn=new SqlConnection(strconn);</p><p>  conn.Open();</p><p>  //判斷用戶想要注冊的用戶名是否已經(jīng)被注冊過</p><p>  SqlCommand cm0=new SqlCommand("s

65、elect * from users where uname='"+this.txtName.Text.ToString()+"'",conn);</p><p>  SqlDataReader dr0=cm0.ExecuteReader();</p><p>  if(dr0.Read())</p><p><b

66、>  {</b></p><p>  this.lblMessage.Text="您要注冊的用戶名已經(jīng)存在,請重新選擇一個用戶名再注冊!";</p><p><b>  }</b></p><p><b>  else</b></p><p><b>

67、  {</b></p><p>  dr0.Close();</p><p>  //利用Command對象調(diào)用存儲過程</p><p>  SqlCommand cm=new SqlCommand("procAddUsers",conn);</p><p>  //將命令類型轉(zhuǎn)化為存儲類型</p>

68、<p>  cm.CommandType=CommandType.StoredProcedure;</p><p>  //往存儲過程中添加參數(shù)</p><p>  cm.Parameters.Add("@name",SqlDbType.VarChar);</p><p>  cm.Parameters.Add("@pas

69、sword",SqlDbType.VarChar);</p><p>  cm.Parameters.Add("@tname",SqlDbType.VarChar);</p><p>  cm.Parameters.Add("@age",SqlDbType.Int);</p><p>  cm.Parameters.

70、Add("@school",SqlDbType.VarChar);</p><p>  cm.Parameters.Add("@Tel",SqlDbType.VarChar);</p><p>  cm.Parameters.Add("@email",SqlDbType.VarChar);</p><p>

71、  cm.Parameters.Add("@ip",SqlDbType.VarChar);</p><p>  //給存儲過程的參數(shù)負(fù)值</p><p>  cm.Parameters["@name"].Value=this.txtName.Text.ToString();</p><p>  cm.Parameters[&q

72、uot;@password"].Value=this.txtPassword.Text.ToString();</p><p>  cm.Parameters["@tname"].Value=this.txtTName.Text.ToString();</p><p>  cm.Parameters["@age"].Value=Conver

73、t.ToInt32(this.txtAge.Text.ToString());</p><p>  cm.Parameters["@school"].Value=this.txtSchool.Text.ToString();</p><p>  cm.Parameters["@Tel"].Value=this.txtTel.Text.ToString

74、();</p><p>  cm.Parameters["@email"].Value=this.txtEmail.Text.ToString();</p><p>  //取得用戶的ip地址傳遞給存儲過程的參數(shù)</p><p>  cm.Parameters["@ip"].Value=Request.UserHostAddr

75、ess.ToString();</p><p>  cm.ExecuteNonQuery();</p><p><b>  }</b></p><p>  conn.Close();</p><p>  this.txtAge.Text="";</p><p>  this.t

76、xtName.Text="";</p><p>  this.txtSchool.Text="";</p><p>  this.txtTel.Text="";</p><p>  this.txtEmail.Text="";</p><p>  this.txt

77、TName.Text="";</p><p>  this.lblMessage.Text="注冊成功!登錄聊天室請點";</p><p><b>  }</b></p><p>  catch(SqlException ex)</p><p><b>  {</b

78、></p><p>  Response.Write("發(fā)生數(shù)據(jù)庫錯誤"+ex.Message);</p><p>  this.lblMessage.Text="注冊失敗,請重試!";</p><p><b>  }</b></p><p>  //次過程用于響應(yīng)取消按鈕&

79、lt;/p><p>  private void btnCancel_Click(object sender, System.EventArgs e)</p><p><b>  {</b></p><p>  this.txtAge.Text="";</p><p>  this.txtName.Tex

80、t="";</p><p>  this.txtSchool.Text="";</p><p>  this.txtTel.Text="";</p><p>  this.txtEmail.Text="";</p><p>  this.txtTName.Text

81、="";</p><p>  this.txtConfirmPwd.Text="";</p><p>  this.txtPassword.Text="";</p><p><b>  }</b></p><p><b>  }</b>&l

82、t;/p><p>  4.2.2 用戶登錄頁面</p><p>  為使用聊天室勢必要使用Application對象和Session對象,所以必須使用Global.asax文件。考慮到需要驗證的內(nèi)容,聊天室能容納的用戶不能太多,在本聊天室中設(shè)置最多可以容納20個用戶。在程序中使用Application[“usercount”]來標(biāo)記當(dāng)前的用戶數(shù),在進(jìn)入聊天室之前首先監(jiān)測聊天室是否已滿,如果已經(jīng)

83、達(dá)到極限人數(shù),則不允許任何用戶登錄。在登錄時用Session["upower"]來判斷用戶的權(quán)限,如果是普通用戶通過驗證后會進(jìn)入聊天室主頁,如果是管理員則會進(jìn)入管理員管理管理頁面。</p><p><b>  圖5 用戶登錄頁面</b></p><p><b>  主要代碼:</b></p><p> 

84、 //此過程用于響應(yīng)登錄按鈕</p><p>  private void btnLogin_Click(object sender, System.EventArgs e)</p><p>  { //判斷聊天室是否已滿</p><p>  if(Application["UserCount"]==20)</p><p>

85、;  { this.lblMessage.Text="對不起!聊天室人員已滿,請稍后在登錄!"; }</p><p><b>  else</b></p><p><b>  {</b></p><p><b>  try</b></p><p>  {//

86、從web.config文件中讀取數(shù)據(jù)庫連接字符串</p><p>  string strconn=ConfigurationSettings.AppSettings["chat"];</p><p>  //建立到本地數(shù)據(jù)庫chat的連接</p><p>  SqlConnection cn=new SqlConnection(strconn)

87、;</p><p>  cn.Open();</p><p>  //利用Command對象調(diào)用存儲過程</p><p>  SqlCommand cmd=new SqlCommand("procLogin",cn);</p><p>  //將命令類型轉(zhuǎn)化為存儲類型 </p><p>  cmd.

88、CommandType=CommandType.StoredProcedure;</p><p>  //給存儲過程添加參數(shù)并負(fù)值</p><p>  cmd.Parameters.Add("@uname",SqlDbType.VarChar);</p><p>  cmd.Parameters.Add("@password"

89、,SqlDbType.VarChar);</p><p>  cmd.Parameters["@uname"].Value=this.txtName.Text.ToString();</p><p>  cmd.Parameters["@password"].Value=this.txtPassword.Text.ToString();</p&

90、gt;<p>  SqlDataReader dr=cmd.ExecuteReader();</p><p>  if(dr.Read())</p><p>  { //保存當(dāng)前用戶名及用戶權(quán)限</p><p>  Session["uname"]=dr["UName"].ToString();</p&

91、gt;<p>  Session["UPower"]=dr["UPower"].ToString();</p><p>  string strname=Session["uname"].ToString();</p><p>  if(Session["upower"].ToString()==

92、"1")</p><p>  { //普通用戶登錄Response.Redirect("chatexplain.aspx?uname="+strname);</p><p><b>  }</b></p><p><b>  else</b></p><p>

93、;<b>  {//管理員登錄</b></p><p>  Response.Redirect("manage.aspx");</p><p><b>  }</b></p><p>  dr.Close();</p><p><b>  }</b><

溫馨提示

  • 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(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

提交評論