Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / ManagedLibraries / Remoting / Channels / TCP / TcpClientSocketManager.cs / 1305376 / TcpClientSocketManager.cs
// ==++==
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// ==--==
//==========================================================================
// File: TcpClientSocketManager.cs
//
// Summary: Class for managing a socket connection.
//
//=========================================================================
using System;
using System.Collections;
using System.IO;
using System.Net;
using System.Net.Sockets;
using System.Runtime.Remoting.Messaging;
using System.Text;
using System.Threading;
using System.Globalization;
namespace System.Runtime.Remoting.Channels.Tcp
{
// A client socket manager instance should encapsulate the socket
// for the purpose of reading a response
internal class TcpClientSocketHandler : TcpSocketHandler
{
// prebaked bytes
private static byte[] s_endOfLineBytes = Encoding.ASCII.GetBytes("\r\n");
private String _machinePortAndSid; // "machineName:port:Sid"
// connection state information
private bool _bOneWayRequest = false; // was the request made OneWay?
private bool _bChunked;
private int _contentLength;
private Stream _requestStream; // the request stream that we return from GetRequestStream()
private TcpReadingStream _responseStream; // the stream that we returned from GetResponseStream()
private TcpClientTransportSink _sink = null;
public TcpClientSocketHandler(Socket socket, String machinePortAndSid, Stream stream, TcpClientTransportSink sink) :
base(socket, stream)
{
_machinePortAndSid = machinePortAndSid;
_sink = sink;
} // TcpClientSocketHandler
// Prepare for reading a new request off of the same socket
protected override void PrepareForNewMessage()
{
_requestStream = null;
_responseStream = null;
} // PrepareForNewRequest
public override void OnInputStreamClosed()
{
// make sure we read to the end of the response stream
if (_responseStream != null)
{
_responseStream.ReadToEnd();
_responseStream = null;
}
// return socket to the cache
ReturnToCache();
} // OnInputStreamClosed
public BaseTransportHeaders ReadHeaders()
{
BaseTransportHeaders headers = new BaseTransportHeaders();
UInt16 operation;
ReadVersionAndOperation(out operation);
// At this point, we're always expecting a Reply, so check for that.
if (operation != TcpOperations.Reply)
{
throw new RemotingException(
String.Format(
CultureInfo.CurrentCulture, CoreChannel.GetResourceString("Remoting_Tcp_ExpectingReplyOp"),
operation.ToString(CultureInfo.CurrentCulture)));
}
// content length must come next (may be chunked or a specific length)
ReadContentLength(out _bChunked, out _contentLength);
// read to end of headers
ReadToEndOfHeaders(headers);
return headers;
} // ReadHeaders
public Stream GetRequestStream(IMessage msg, int contentLength,
ITransportHeaders headers)
{
IMethodCallMessage mcm = (IMethodCallMessage)msg;
String uri = mcm.Uri;
_bOneWayRequest = RemotingServices.IsOneWay(mcm.MethodBase);
ChunkedMemoryStream headerStream = new ChunkedMemoryStream(CoreChannel.BufferPool);
// output preamble and version
WritePreambleAndVersion(headerStream);
// output opcode
if (!_bOneWayRequest)
WriteUInt16(TcpOperations.Request, headerStream);
else
WriteUInt16(TcpOperations.OneWayRequest, headerStream);
// output content delimiter style
WriteUInt16(TcpContentDelimiter.ContentLength, headerStream);
WriteInt32(contentLength, headerStream);
// output request uri
WriteUInt16(TcpHeaders.RequestUri, headerStream);
WriteByte(TcpHeaderFormat.CountedString, headerStream);
WriteCountedString(uri, headerStream);
// output rest of headers
WriteHeaders(headers, headerStream);
headerStream.WriteTo(NetStream);
headerStream.Close();
_requestStream = NetStream;
return _requestStream;
} // GetRequestStream
public void SendRequest(IMessage msg, ITransportHeaders headers, Stream contentStream)
{
int requestLength = (int)contentStream.Length;
GetRequestStream(msg, requestLength, headers);
StreamHelper.CopyStream(contentStream, NetStream);
contentStream.Close();
} // SendRequest
public Stream GetResponseStream()
{
if (!_bChunked)
_responseStream = new TcpFixedLengthReadingStream(this, _contentLength);
else
_responseStream = new TcpChunkedReadingStream(this);
return _responseStream;
} // GetResponseStream
public bool OneWayRequest
{
get { return _bOneWayRequest; }
}
public void ReturnToCache()
{
_sink.ClientSocketCache.ReleaseSocket(
_machinePortAndSid, this);
}
} // TcpClientSocketHandler
} // namespace System.Runtime.Remoting.Channels
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// ==++==
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// ==--==
//==========================================================================
// File: TcpClientSocketManager.cs
//
// Summary: Class for managing a socket connection.
//
//=========================================================================
using System;
using System.Collections;
using System.IO;
using System.Net;
using System.Net.Sockets;
using System.Runtime.Remoting.Messaging;
using System.Text;
using System.Threading;
using System.Globalization;
namespace System.Runtime.Remoting.Channels.Tcp
{
// A client socket manager instance should encapsulate the socket
// for the purpose of reading a response
internal class TcpClientSocketHandler : TcpSocketHandler
{
// prebaked bytes
private static byte[] s_endOfLineBytes = Encoding.ASCII.GetBytes("\r\n");
private String _machinePortAndSid; // "machineName:port:Sid"
// connection state information
private bool _bOneWayRequest = false; // was the request made OneWay?
private bool _bChunked;
private int _contentLength;
private Stream _requestStream; // the request stream that we return from GetRequestStream()
private TcpReadingStream _responseStream; // the stream that we returned from GetResponseStream()
private TcpClientTransportSink _sink = null;
public TcpClientSocketHandler(Socket socket, String machinePortAndSid, Stream stream, TcpClientTransportSink sink) :
base(socket, stream)
{
_machinePortAndSid = machinePortAndSid;
_sink = sink;
} // TcpClientSocketHandler
// Prepare for reading a new request off of the same socket
protected override void PrepareForNewMessage()
{
_requestStream = null;
_responseStream = null;
} // PrepareForNewRequest
public override void OnInputStreamClosed()
{
// make sure we read to the end of the response stream
if (_responseStream != null)
{
_responseStream.ReadToEnd();
_responseStream = null;
}
// return socket to the cache
ReturnToCache();
} // OnInputStreamClosed
public BaseTransportHeaders ReadHeaders()
{
BaseTransportHeaders headers = new BaseTransportHeaders();
UInt16 operation;
ReadVersionAndOperation(out operation);
// At this point, we're always expecting a Reply, so check for that.
if (operation != TcpOperations.Reply)
{
throw new RemotingException(
String.Format(
CultureInfo.CurrentCulture, CoreChannel.GetResourceString("Remoting_Tcp_ExpectingReplyOp"),
operation.ToString(CultureInfo.CurrentCulture)));
}
// content length must come next (may be chunked or a specific length)
ReadContentLength(out _bChunked, out _contentLength);
// read to end of headers
ReadToEndOfHeaders(headers);
return headers;
} // ReadHeaders
public Stream GetRequestStream(IMessage msg, int contentLength,
ITransportHeaders headers)
{
IMethodCallMessage mcm = (IMethodCallMessage)msg;
String uri = mcm.Uri;
_bOneWayRequest = RemotingServices.IsOneWay(mcm.MethodBase);
ChunkedMemoryStream headerStream = new ChunkedMemoryStream(CoreChannel.BufferPool);
// output preamble and version
WritePreambleAndVersion(headerStream);
// output opcode
if (!_bOneWayRequest)
WriteUInt16(TcpOperations.Request, headerStream);
else
WriteUInt16(TcpOperations.OneWayRequest, headerStream);
// output content delimiter style
WriteUInt16(TcpContentDelimiter.ContentLength, headerStream);
WriteInt32(contentLength, headerStream);
// output request uri
WriteUInt16(TcpHeaders.RequestUri, headerStream);
WriteByte(TcpHeaderFormat.CountedString, headerStream);
WriteCountedString(uri, headerStream);
// output rest of headers
WriteHeaders(headers, headerStream);
headerStream.WriteTo(NetStream);
headerStream.Close();
_requestStream = NetStream;
return _requestStream;
} // GetRequestStream
public void SendRequest(IMessage msg, ITransportHeaders headers, Stream contentStream)
{
int requestLength = (int)contentStream.Length;
GetRequestStream(msg, requestLength, headers);
StreamHelper.CopyStream(contentStream, NetStream);
contentStream.Close();
} // SendRequest
public Stream GetResponseStream()
{
if (!_bChunked)
_responseStream = new TcpFixedLengthReadingStream(this, _contentLength);
else
_responseStream = new TcpChunkedReadingStream(this);
return _responseStream;
} // GetResponseStream
public bool OneWayRequest
{
get { return _bOneWayRequest; }
}
public void ReturnToCache()
{
_sink.ClientSocketCache.ReleaseSocket(
_machinePortAndSid, this);
}
} // TcpClientSocketHandler
} // namespace System.Runtime.Remoting.Channels
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- PrintingPermission.cs
- FloaterBaseParagraph.cs
- StrongNamePublicKeyBlob.cs
- GridViewDeletedEventArgs.cs
- DescendantOverDescendantQuery.cs
- SqlProvider.cs
- SqlClientWrapperSmiStreamChars.cs
- ProcessMonitor.cs
- XmlParser.cs
- HtmlInputReset.cs
- ReliableRequestSessionChannel.cs
- WeakReference.cs
- EncodingNLS.cs
- Walker.cs
- RequestDescription.cs
- ColorDialog.cs
- WorkflowMarkupSerializationException.cs
- EntityDataSourceReferenceGroup.cs
- UniqueConstraint.cs
- MSG.cs
- InheritanceAttribute.cs
- CaseInsensitiveHashCodeProvider.cs
- DoubleCollection.cs
- BinaryWriter.cs
- OpCellTreeNode.cs
- PolicyUnit.cs
- SystemMulticastIPAddressInformation.cs
- Control.cs
- Documentation.cs
- StateRuntime.cs
- XmlCharacterData.cs
- HttpModuleAction.cs
- FlowPosition.cs
- DesignTimeXamlWriter.cs
- CTreeGenerator.cs
- GridViewRowCollection.cs
- _OverlappedAsyncResult.cs
- PasswordBox.cs
- DefaultTraceListener.cs
- TraceContextEventArgs.cs
- RotationValidation.cs
- GroupPartitionExpr.cs
- LocatorGroup.cs
- DataObjectSettingDataEventArgs.cs
- Interlocked.cs
- FieldCollectionEditor.cs
- SrgsRuleRef.cs
- ScopelessEnumAttribute.cs
- CqlParserHelpers.cs
- DBCommand.cs
- DataSysAttribute.cs
- SqlTypesSchemaImporter.cs
- BindingWorker.cs
- CodeIterationStatement.cs
- IsolatedStorageFileStream.cs
- SiteMapHierarchicalDataSourceView.cs
- TableLayoutStyle.cs
- WindowsScrollBar.cs
- TreeNodeMouseHoverEvent.cs
- InputLanguageCollection.cs
- StaticExtensionConverter.cs
- CalendarDataBindingHandler.cs
- ByteStream.cs
- DataGridViewHitTestInfo.cs
- RestClientProxyHandler.cs
- Calendar.cs
- AsynchronousChannel.cs
- ItemChangedEventArgs.cs
- CodeMemberMethod.cs
- PackUriHelper.cs
- InfoCardRSAPKCS1KeyExchangeFormatter.cs
- AssemblyBuilderData.cs
- WebEventTraceProvider.cs
- Vector3DCollectionConverter.cs
- DBProviderConfigurationHandler.cs
- TaskHelper.cs
- QilUnary.cs
- WorkerRequest.cs
- GeneralTransform3DTo2D.cs
- AuthorizationRule.cs
- Trace.cs
- FormParameter.cs
- SQLInt64Storage.cs
- objectresult_tresulttype.cs
- ServiceNotStartedException.cs
- MissingSatelliteAssemblyException.cs
- SortAction.cs
- PtsContext.cs
- HandleExceptionArgs.cs
- PermissionAttributes.cs
- PropertyEmitterBase.cs
- ClientConfigPaths.cs
- ErrorWrapper.cs
- BezierSegment.cs
- FirstMatchCodeGroup.cs
- _NtlmClient.cs
- BlurEffect.cs
- FormsAuthenticationUser.cs
- ErrorInfoXmlDocument.cs
- SHA1.cs