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
- NestPullup.cs
- WFItemsToSpacerVisibility.cs
- ObjectCacheSettings.cs
- SignerInfo.cs
- FormDesigner.cs
- ApplicationDirectory.cs
- NamespaceList.cs
- ClientBuildManager.cs
- WebPartTransformerAttribute.cs
- DefaultObjectMappingItemCollection.cs
- TextTreeUndo.cs
- IPAddress.cs
- EntityDataSourceSelectedEventArgs.cs
- MarshalDirectiveException.cs
- FileStream.cs
- ReferenceList.cs
- ChannelSettingsElement.cs
- NativeObjectSecurity.cs
- HealthMonitoringSection.cs
- TcpDuplicateContext.cs
- HtmlShim.cs
- TabControlEvent.cs
- KernelTypeValidation.cs
- _OverlappedAsyncResult.cs
- InitiatorSessionSymmetricMessageSecurityProtocol.cs
- DataGridViewCheckBoxColumn.cs
- IndexedSelectQueryOperator.cs
- XmlNodeChangedEventManager.cs
- UnmanagedBitmapWrapper.cs
- ViewSimplifier.cs
- PeerSecurityHelpers.cs
- SynchronousReceiveBehavior.cs
- AssociationSetMetadata.cs
- EntityClientCacheEntry.cs
- CharConverter.cs
- _UncName.cs
- HttpListenerException.cs
- ThreadSafeMessageFilterTable.cs
- AuthenticationConfig.cs
- DistributedTransactionPermission.cs
- DataGridViewCell.cs
- Setter.cs
- Button.cs
- DoubleAnimationUsingPath.cs
- InputScopeAttribute.cs
- InvalidateEvent.cs
- FontStyles.cs
- DataGridViewCellLinkedList.cs
- DrawingAttributes.cs
- PropertyPathWorker.cs
- DynamicValidator.cs
- EventBuilder.cs
- PathFigureCollection.cs
- ProcessInfo.cs
- DbParameterCollectionHelper.cs
- DataGridViewElement.cs
- PointCollectionConverter.cs
- EditingMode.cs
- UxThemeWrapper.cs
- XPathException.cs
- EmulateRecognizeCompletedEventArgs.cs
- TransactionException.cs
- EventlogProvider.cs
- MailMessageEventArgs.cs
- GridLength.cs
- TabletDeviceInfo.cs
- LiteralSubsegment.cs
- ConfigurationPropertyCollection.cs
- InvalidOperationException.cs
- CodeCatchClauseCollection.cs
- XmlWellformedWriter.cs
- ItemsControlAutomationPeer.cs
- AccessDataSourceDesigner.cs
- __TransparentProxy.cs
- QueryConverter.cs
- XsdDataContractExporter.cs
- AbsoluteQuery.cs
- MultiplexingDispatchMessageFormatter.cs
- EpmCustomContentWriterNodeData.cs
- ButtonPopupAdapter.cs
- RelationshipConverter.cs
- BaseTemplateParser.cs
- ProtocolsConfiguration.cs
- ErrorStyle.cs
- ValueChangedEventManager.cs
- OdbcStatementHandle.cs
- TextCollapsingProperties.cs
- DataGridViewLinkCell.cs
- Interlocked.cs
- ResourceAssociationSet.cs
- RequiredFieldValidator.cs
- WindowsFont.cs
- Timeline.cs
- ControlEvent.cs
- DataControlFieldHeaderCell.cs
- UriTemplateTrieNode.cs
- ObjectAnimationUsingKeyFrames.cs
- MenuRenderer.cs
- PreservationFileReader.cs
- TextBounds.cs