Click here to Skip to main content
16,017,373 members
Articles / Web Development / HTML
Article

Simple Chat asp.net + Ajax

Rate me:
Please Sign up or sign in to vote.
2.13/5 (12 votes)
12 Dec 20051 min read 104.1K   3K   32   16
this describes how to do a Autorefresh Chat container using a div ajax asp.net

Sample Image - SimpleChat.jpg

Introduction

And why not, how to create an easy chat room for your web site? Well, the best way is to use a nice database to store messages; however, for demo purposes, I'll use a static array. I know, you won't be able to use it in your web farm. Take this article as the concept, not as a solution. This simple web chat program is intended to work in any browser supporting <iFrame>.

Also, you can select multiple chat rooms. Why not extend from there and more from channel to channel.

Background

Some months ago, I was looking for a complete on-line customer service ASP.NET control to make my life easier, did not find anything interesting, so I built my own.

Using the code

Replace this class if you are using a database to save the messages:

C#
public class Chat
{
        static protected ArrayList pArray = new ArrayList();
        

        static public void AddMessage(string sDealer, 
                              string sUser, string sMsg)
        {
            string sAddText = sDealer + "~" + sUser + "~" + sMsg;
            pArray.Add(sAddText);

            if ( pArray.Count > 200 )
            {
                pArray.RemoveRange(0,10);
            }
        }

        static public string GetAllMessages(string sDealer)
        {
            string sResponse = "";

            for (int i=0; i< pArray.Count; i++)
            {
                sResponse = sResponse + 
                    FormatChat(pArray[i].ToString(), sDealer);
            }

            return(sResponse);
        }

        static private string FormatChat(string sLine, string sDealer)
        {
            int iFirst = sLine.IndexOf("~");
            int iLast = sLine.LastIndexOf("~");

            string sDeal = sLine.Substring(0, iFirst);
            if ( sDeal != sDealer)
                return("");

            string sUser = sLine.Substring(iFirst+1, iLast-(iFirst+1));
            
            string sMsg = sLine.Substring(iLast+1);

            string sRet = "" + sUser + ": " + sMsg + "";

            return(sRet);
        }
    }

The above code reads and writes from the static array like in a database. The code only allows having 200 messages in the array, after that it deletes the top 10 at the time.

The Chat page is pretty simple; this is the code behind aspx.cs:

C#
public class ChatWin : System.Web.UI.Page
    {
        protected System.Web.UI.WebControls.TextBox TB_ToSend;
        protected System.Web.UI.WebControls.Button BT_Send;
    
        private void Page_Load(object sender, System.EventArgs e)
        {
            if ( Page.IsPostBack == false )
            {
                if ( Request.Params["Channel"] != null )
                    Session["ChatChannel"] = 
                       Request.Params["Channel"].ToString();
                else
                    Session["ChatChannel"] = "1";
                
            }
        }

        #region Web Form Designer generated code
        override protected void OnInit(EventArgs e)
        {
            //
            // CODEGEN: This call is required by the ASP.NET Web Form Designer.
            //
            InitializeComponent();
            base.OnInit(e);
        }
        
        /// <SUMMARY>
        /// Required method for Designer support - do not modify
        /// the contents of this method with the code editor.
        /// </SUMMARY>
        private void InitializeComponent()
        {    
            this.BT_Send.Click += 
               new System.EventHandler(this.BT_Send_Click);
            this.Load += new System.EventHandler(this.Page_Load);

        }
        #endregion

        public string GetChatPage()
        {
            return("TheChatScreenWin.aspx");
        }

        private void BT_Send_Click(object sender, System.EventArgs e)
        {
            string sChannel = "";
            string sUser = "";

            if ( Request.Params["Channel"] != null )
                sChannel = Request.Params["Channel"].ToString();
            else
                sChannel = "1";

            if ( Request.Params["User"] != null )
                sUser = Request.Params["User"].ToString();
            else
            {
                Random pRan = new Random();
                int iNum = pRan.Next(9);
                sUser = "Annonymouse" + iNum;
            }

            
            if ( TB_ToSend.Text.Length > 0)
            {
                PageModule.Chat.AddMessage(sChannel,
                    sUser,
                    TB_ToSend.Text);
                
                TB_ToSend.Text = "";        
            }
        }
    }

When the SEND button is clicked, it calls the function AddMessage that adds a row into the end of the static array.

The page inside the <iframe> tag refreshes every 4 seconds without refreshing your actual page.

Points of Interest

The magic? None, a simple request of the second page into the <iFrame>. So, Internet Explorer takes care of everything for us to read the static array.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here


Written By
Web Developer
Spain Spain
This member has not yet provided a Biography. Assume it's interesting and varied, and probably something to do with programming.

Comments and Discussions

 
Generalajax-enabled GridView Pin
JoaoSilva200729-May-07 15:34
JoaoSilva200729-May-07 15:34 
GeneralTurn ASP.NET controls into AJAXenabled controls Pin
OmegaCD8-Jul-06 20:46
OmegaCD8-Jul-06 20:46 
GeneralAjax enabled DataGrid - Chat Application Example Pin
OmegaCD26-May-06 2:56
OmegaCD26-May-06 2:56 
General'chat' undefined Pin
Amorous15-May-06 5:13
Amorous15-May-06 5:13 
QuestionRe: 'chat' undefined Pin
Ehsan Abbasi28-Aug-06 22:11
Ehsan Abbasi28-Aug-06 22:11 
AnswerRe: 'chat' undefined Pin
dealarconjose29-Aug-06 7:46
dealarconjose29-Aug-06 7:46 
GeneralRe: 'chat' undefined Pin
LvX743-Mar-08 23:02
LvX743-Mar-08 23:02 
NewszumiPage for ASP.NET Pin
Amir L.21-Dec-05 13:04
Amir L.21-Dec-05 13:04 
GeneralRe: zumiPage for ASP.NET Pin
dealarconjose21-Dec-05 13:37
dealarconjose21-Dec-05 13:37 
GeneralRe: zumiPage for ASP.NET Pin
Amir L.21-Dec-05 21:17
Amir L.21-Dec-05 21:17 
Questionno picture Pin
Adelino Araújo13-Dec-05 13:03
Adelino Araújo13-Dec-05 13:03 
AnswerRe: no picture Pin
dealarconjose13-Dec-05 21:26
dealarconjose13-Dec-05 21:26 
GeneralRe: no picture Pin
Adelino Araújo14-Dec-05 7:32
Adelino Araújo14-Dec-05 7:32 
GeneralRe: no picture--&gt;source+image Pin
dealarconjose14-Dec-05 12:33
dealarconjose14-Dec-05 12:33 
GeneralRe: no picture--&gt;source+image Pin
Amorous13-May-06 8:56
Amorous13-May-06 8:56 
GeneralRe: no picture--&gt;source+image Pin
dealarconjose15-May-06 12:33
dealarconjose15-May-06 12:33 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.