版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 畢業(yè)論文---多人聊天室設(shè)計
- 畢業(yè)論文 java聊天室的設(shè)計
- java聊天室畢業(yè)論文
- 畢業(yè)論文asp聊天室
- 聊天室(java)-畢業(yè)論文
- jsp在線聊天室-畢業(yè)論文
- 基于web的聊天室畢業(yè)論文
- 基于web的聊天室畢業(yè)論文
- 畢業(yè)論文——網(wǎng)上聊天室
- 基于web的聊天室構(gòu)建畢業(yè)論文
- 基于java的聊天室設(shè)計與實現(xiàn)畢業(yè)論文
- 基于java的聊天室設(shè)計與實現(xiàn)畢業(yè)論文
- 畢業(yè)論文——網(wǎng)上聊天室 (3)
- 畢業(yè)論文——網(wǎng)上聊天室 (3)
- 畢業(yè)論文——網(wǎng)上聊天室 (2)
- 畢業(yè)論文——網(wǎng)上聊天室 (3)
- 畢業(yè)設(shè)計----網(wǎng)絡(luò)聊天室的設(shè)計與實現(xiàn)
- java局域網(wǎng)聊天室系統(tǒng)畢業(yè)論文
- 基于java網(wǎng)絡(luò)聊天室設(shè)計
- 基于asp的網(wǎng)絡(luò)聊天室的設(shè)計和實現(xiàn)
評論
0/150
提交評論