免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
用Asp.Net創(chuàng)建基于Ajax的聊天室程序

用Asp.Net創(chuàng)建基于Ajax的聊天室程序

原作者Dahan Abdo
譯自CodeProject

如要下載源代碼,請(qǐng)到我的網(wǎng)站,地址:http://www.vczx.com/article/show.php?id=1796

簡 介

  我的第一個(gè)chat room 是用ASP 3.0寫的。 程序比較簡單,兩個(gè)text box, 用來處理頁面上每秒刷新的信息。那時(shí)候,要想建一個(gè)真正的chat room,要用到Java Applet 或者 ActiveX control?;贖TTP的chart rooms都面臨著一些跟我第一個(gè)chat room一樣的問題。這些問題包括頁面刷新導(dǎo)致的屏幕閃爍現(xiàn)象。但這個(gè)問題已經(jīng)被AJAX解決了。 AJAX是JavaScript和 XML異步調(diào)用的結(jié)合?,F(xiàn)在在server端用一些JavaScript代碼就可以實(shí)現(xiàn)一個(gè)真正的chat room了。這篇文章不會(huì)介紹Ajax,并假設(shè)你已經(jīng)對(duì)Ajax和ASP.NET的運(yùn)用有一定了解。只是介紹如何用Ajax技術(shù)來創(chuàng)建一個(gè)基本的chat room。

例 程

  這是一個(gè)多用戶的單一chat room??梢詫?shí)現(xiàn)基本的聊天功能,還支持一些命令行如: /admin clear 用來清除聊天記錄,/nick [Name] 用來更改用戶昵稱等。程序說明這個(gè)程序用一個(gè)ChatEngine類來處理所有的聊天信息和用戶信息,用戶信息存儲(chǔ)在一個(gè)Hashtable中,聊天信息存儲(chǔ)在StringCollection中。

Hashtable users;
StringCollection chat;

  在Global.asax.cs 中聲明一個(gè)全局的ChatEngine的實(shí)例,為chat room中所有users共用:

public static UChat.ChatEngine.IChatEngine Engine = new UChat.ChatEngine.ChatEngine();

  還有一個(gè)JavaScript timer函數(shù)用來同步全局變量和頁面信息。


function setTimers()
{
  timeID = window.setTimeout( "updateAll()", refreshRate );
}

每一個(gè)user都由一個(gè)username和一個(gè)GUID來唯一標(biāo)識(shí)。

public void AddUser(string id, string user)
{
      //make sure user name does not exist already
      if( !UserExists( user ) )
      {
            //add user to users list
            users.Add( id, user );
                                    
            //display a notification message to all users 
            chat.Add( this.MakeServerMessage(string.Format(
                      joinedfmt, user ) ));
      }
}

程序運(yùn)行界面
 


  開始頁面顯示一些有關(guān)當(dāng)前session的基本信息,比如user number、聊天記錄的大小等。用戶必須提供用戶名才能進(jìn)入聊天室。點(diǎn)擊Login button進(jìn)入下面的函數(shù):

protected void Login( object sender, EventArgs e )
{
      string user = txtUsername.Text;

      if( !ValidateNick( user ) ) return;

      if( Global.Engine.UserExists( user ) )
      {
            lblErrorMsg.Text = "A user with this " + 
                 "name already exists, try again.";
            return;
      }
      Response.Redirect( "Server.aspx?action=Login&u=" + user );
}

  經(jīng)過一些簡單驗(yàn)證后,通過AddUser函數(shù)將用戶加到user lists,然后就進(jìn)入了聊天室頁面chat.aspx,這時(shí)下面的JavaScript函數(shù)就會(huì)被執(zhí)行:
 


<script type="text/javascript">
      sniffBrowserType();
      //Shows loading.. screen
      showLoadScreen();
      //Set the javascript timer and 
      
//loads user list and messages 
      setTimers();
      setFocus('mytext');
</script>

  當(dāng)用戶鍵入一些信息并回車時(shí),就會(huì)調(diào)用下面的函數(shù):

<input type="text" class="mytext" 
       id="mytext" onkeydown="captureReturn(event)">

// Capture the enter key on the input box and post message
function captureReturn( event )
{
      if(event.which || event.keyCode)
      {
            if ((event.which == 13) || (event.keyCode == 13)) 
            {
                  postText();
                  return false;
            }
            else {
                  return true;
            }
      }     
}
function postText()
{
      rnd++;
      //Clear text box first
      chatbox = getElement( "mytext" );
      chat = chatbox.value;
      chatbox.value = "";
      
      //get user GUID from url
      userid = location.search.substring( 1, location.search.length );
      
      //construct Ajax Server URL
      url = 'Server.aspx?action=PostMsg&u=' + userid + '&t=' +
             encodeURIComponent(chat) + '&session=' + rnd;
      
      //Create and set the instance 
      
//of appropriate XMLHTTP Request      object
      req = getAjax();
      
      //Update page with new message
      req.onreadystatechange = function(){
      
            if( req.readyState == 4 && req.status == 200 ) {
                  updateAll();
            }
      }
      
      req.open( 'GET', url, true );
      req.send( null );
}

  就這么多,沒什么特別的,你可以看源代碼,里面有很多注釋信息。

結(jié) 論

  要用Java Applet建一個(gè)chat room需要在用戶的機(jī)器上安裝JVM。用ActiveX control存在一些安全問題。而用剛才介紹的AJAX,你卻可以輕而易舉的創(chuàng)建一個(gè)基于HTTP并不需要用戶安裝任何軟件就可以運(yùn)行的聊天室程序,并且很容易維護(hù)。
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
在ASP.NET中實(shí)現(xiàn)AJAX
Ajax 技術(shù)匯總
JavaScript模擬命名空間
看看如何透過JavaScript調(diào)用C#函數(shù) - 51CTO.COM
AjaxPro 內(nèi)部機(jī)制探討
本周ASP.NET英文技術(shù)文章推薦[03/25 - 03/31]
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服