Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

How to close a socket in C#?

Posted on 2008-06-18
11
Medium Priority
?
1,074 Views
Last Modified: 2013-12-16
Is there any way to close a socket if you know the port number?
0
Comment
Question by:Tharo_Systems
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 6
  • 5
11 Comments
 
LVL 18

Expert Comment

by:jcoehoorn
ID: 21815598
Not if you don't own it.
0
 

Author Comment

by:Tharo_Systems
ID: 21815616
I have a program that opens a socket for listening. I need to be able to close it from a different function.
0
 
LVL 18

Expert Comment

by:jcoehoorn
ID: 21816173
And do you have the source for that program?  Can we see it?
0
Google Certified Professional - Cloud Architect

This course (1 of 3) is designed to help students who are interested in Google Cloud Platform (GCP) to become familiar with the platform, navigate the console and learn its capabilities. It will also prepare students for the Google Cloud Architect certification exam.

 

Author Comment

by:Tharo_Systems
ID: 21816315
Here's the function that creates the socket. I would like to have another function that closes the socket.
private void CreateListenerSocket(int PortToListenOn)
	{
		// Determine the IP address of the machine
		IPAddress [] aryLocalAddr = null;
		try
		{
			IPHostEntry ipEntry = Dns.GetHostEntry( Dns.GetHostName() );
			aryLocalAddr = ipEntry.AddressList;
		}
		catch( Exception ex )
		{
			theLog.WriteEntry("Error trying to get local address {0}: " + ex.Message, EventLogEntryType.Error);
		}
		// Verify that an address was obtained. Write to the log if not.
		if( aryLocalAddr == null || aryLocalAddr.Length < 1 )
		{
			theLog.WriteEntry("Unable to get local address", EventLogEntryType.Error);
			return;
		}
                listener = new Socket( AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp );
		listener.Blocking = false;
		for (int i = 0; i < aryLocalAddr.Length; i++)
                {
                  if (aryLocalAddr[i].AddressFamily == AddressFamily.InterNetwork)
                  {
                    listener.Bind(new IPEndPoint(aryLocalAddr[i], PortToListenOn));
                    break;
                }
            }
	listener.Listen( 10 );
	listener.BeginAccept( new AsyncCallback( OnConnectRequest ), listener );
	}

Open in new window

0
 
LVL 18

Expert Comment

by:jcoehoorn
ID: 21816399
If you keep a reference to your listener variable handy it's as simple as calling listener.Close();
0
 

Author Comment

by:Tharo_Systems
ID: 21816486
I was hoping it would be a simple answer. I'm very new to this. Can you elaborate on how to do that? Thanks!
0
 
LVL 18

Expert Comment

by:jcoehoorn
ID: 21816555
Well, the method you posted doesn't declare listener anywhere, so I'm assuming it's a class-level variable.  With that in mind, you can just say this in any non-static method in your class and the socket will close:

if (listener!= null) listener.Close();

That's it.
0
 

Author Comment

by:Tharo_Systems
ID: 21821125
Can it be done from another class?
0
 

Author Comment

by:Tharo_Systems
ID: 21821250
OK, I tried adding that code before the line that creates the socket. I want to prevent the program from opening more than one. The first time through, it's fine because listener is null. The second time it's called, it does close listener, but when it hits the "listener = new socket..." line, it crashes. Am i doing something wrong? Thanks!
private void CreateListenerSocket(int PortToListenOn)
	{
		// Determine the IP address of the machine
		IPAddress [] aryLocalAddr = null;
		try
		{
			IPHostEntry ipEntry = Dns.GetHostEntry( Dns.GetHostName() );
			aryLocalAddr = ipEntry.AddressList;
		}
		catch( Exception ex )
		{
			theLog.WriteEntry("Error trying to get local address {0}: " + ex.Message, EventLogEntryType.Error);
		}
		// Verify that an address was obtained. Write to the log if not.
		if( aryLocalAddr == null || aryLocalAddr.Length < 1 )
		{
			theLog.WriteEntry("Unable to get local address", EventLogEntryType.Error);
			return;
		}
 
            try
            {
                if (listener != null)
                {
                    listener.Close();
                }
            }
            catch (Exception ex)
            {
                theLog.WriteEntry(ex.Message, EventLogEntryType.Error);
            }  
 
                listener = new Socket( AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp );
		listener.Blocking = false;
		for (int i = 0; i < aryLocalAddr.Length; i++)
                {
                  if (aryLocalAddr[i].AddressFamily == AddressFamily.InterNetwork)
                  {
                    listener.Bind(new IPEndPoint(aryLocalAddr[i], PortToListenOn));
                    break;
                }
            }
	listener.Listen( 10 );
	listener.BeginAccept( new AsyncCallback( OnConnectRequest ), listener );
	}
 

Open in new window

0
 

Author Comment

by:Tharo_Systems
ID: 21821525
Upon further inspection, it seems it's crashing when it tries to access aryLocalAddr. Not sure why, but I'm getting "system.objectdisposedexception" errors. Any ideas? I also want to be able to close the socket completely by a button/checkbox/whatever in a separate configuration window in a different class, but I don't know how to access listener from there. Thanks!
0
 
LVL 18

Accepted Solution

by:
jcoehoorn earned 2000 total points
ID: 21821890
Any other class that needs to use the listener member will then need a reference to the correct instance of this class, and listener will need to be public- preferably exposed as a property.

Not sure what's going on with aryLocalAddr.  Calling listener.Close() is the exact same thing as disposing (calling listener.Dispose()) - the two are interchangeable, if that helps.  Is seems that two are intertwined there somehow.  The error puzzles me because if closing the socket also disposed the the IPEndPoint then I would expect it to dispose of the individual items in the array and not the array itself.  That would leave with an error message complaining about aryLocalAddr[n] rather than aryLocalAddr itself.
0

Featured Post

NFR key for Veeam Backup for Microsoft Office 365

Veeam is happy to provide a free NFR license (for 1 year, up to 10 users). This license allows for the non‑production use of Veeam Backup for Microsoft Office 365 in your home lab without any feature limitations.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
Performance in games development is paramount: every microsecond counts to be able to do everything in less than 33ms (aiming at 16ms). C# foreach statement is one of the worst performance killers, and here I explain why.
This tutorial covers a step-by-step guide to install VisualVM launcher in eclipse.
THe viewer will learn how to use NetBeans IDE 8.0 for Windows to perform CRUD operations on a MySql database.

704 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question