Chat Program using Asynchronous Socket

.

Environment: C#

This is a simple chat program using asynchronous socket. This program is act like a client or a server. It can connect to another other PC (installed with the same program) or it can wait for another PC to connect to it.

You can test the program on the same PC by running two instances of the program. Each one listens to a port (e.g. first is listen to 998 and the second to 999). Click the listen button of both programs, key in the hostname/Host IP Address as "local" or "127.0.0.1", fill in the port number as 999 on the first program (because you want to connect to the second program which listens to port 999),and finally click connect. The IP address will display in the list of the second instance of the program (if successfully connected). At this point, you can start sending messages.

In this simple program, I also demonstrated how the event is raised during connection, disconnection, sending, and receiving (like the OnConnect, OnSend... in MSVC++ MFC's socket class).

Update on 17 Apr 2001

This is an update to the previous code post on 03/22/2002. In the update, I include the sending and receiving function. The sending and receiving file is based on my own command that can modify according to u requirement. The concept is descript as below:

 

Sending

Client

Server

Receiving

 

Send Filename and size to `

Accepted the file detail

 

 

 

_ Send signal back, tell client to start sending

 

 

Once signal is received, start sending file data. (Block by block until end of file)`

Store to file.

 

 

Done

_ Successfully received all

 

       

Actually, you can base on this kind of command to do a lot of stuff like searching file remotely, check remote PC information and other you can think of. Have fun.

Downloads

Download demo project - 13 Kb
Download source - 10 Kb



Comments

  • There are no comments yet. Be the first to comment!

Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • Complex hybrid environments can make it difficult to track interdependencies, increasing the risk of disrupting critical business services. In this white paper by EMA, you'll learn how application discovery and dependency mapping can help you: Meet granular targets for availability, cost, and time-to-revenue for cloud services. Accelerate mean time to repair (MTTR) while communicating better with stakeholders. Manage even the most complex hybrid environments more efficiently and effectively Understand the …

  • When individual departments procure cloud service for their own use, they usually don't consider the hazardous organization-wide implications. Read this paper to learn best practices for setting up an internal, IT-based cloud brokerage function that service the entire organization. Find out how this approach enables you to retain top-down visibility and control of network security and manage the impact of cloud traffic on your WAN.

Most Popular Programming Stories

More for Developers

RSS Feeds

Thanks for your registration, follow us on our social networks to keep up-to-date