Code:
/ WCF / WCF / 3.5.30729.1 / untmp / Orcas / SP / ndp / cdf / src / WCF / ServiceModel / System / ServiceModel / Channels / MessageEncoder.cs / 1 / MessageEncoder.cs
//------------------------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------------------------- namespace System.ServiceModel.Channels { using System; using System.IO; using System.Net.Mime; using System.Runtime.Serialization; using System.ServiceModel.Diagnostics; public abstract class MessageEncoder { public abstract string ContentType { get; } public abstract string MediaType { get; } public abstract MessageVersion MessageVersion { get; } public virtual T GetProperty() where T : class { if (typeof(T) == typeof(FaultConverter)) { return (T)(object)FaultConverter.GetDefaultFaultConverter(this.MessageVersion); } return null; } public Message ReadMessage(Stream stream, int maxSizeOfHeaders) { return ReadMessage(stream, maxSizeOfHeaders, null); } public abstract Message ReadMessage(Stream stream, int maxSizeOfHeaders, string contentType); public Message ReadMessage(ArraySegment buffer, BufferManager bufferManager) { return ReadMessage(buffer, bufferManager, null); } public abstract Message ReadMessage(ArraySegment buffer, BufferManager bufferManager, string contentType); // used for buffered streaming internal ArraySegment BufferMessageStream(Stream stream, BufferManager bufferManager, int maxBufferSize) { byte[] buffer = bufferManager.TakeBuffer(ConnectionOrientedTransportDefaults.ConnectionBufferSize); int offset = 0; int currentBufferSize = Math.Min(buffer.Length, maxBufferSize); while (offset < currentBufferSize) { int count = stream.Read(buffer, offset, currentBufferSize - offset); if (count == 0) { stream.Close(); break; } offset += count; if (offset == currentBufferSize) { if (currentBufferSize >= maxBufferSize) { throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(MaxMessageSizeStream.CreateMaxReceivedMessageSizeExceededException(maxBufferSize)); } currentBufferSize = Math.Min(currentBufferSize * 2, maxBufferSize); byte[] temp = bufferManager.TakeBuffer(currentBufferSize); Buffer.BlockCopy(buffer, 0, temp, 0, offset); bufferManager.ReturnBuffer(buffer); buffer = temp; } } return new ArraySegment (buffer, 0, offset); } // used for buffered streaming internal virtual Message ReadMessage(Stream stream, BufferManager bufferManager, int maxBufferSize, string contentType) { return ReadMessage(BufferMessageStream(stream, bufferManager, maxBufferSize), bufferManager, contentType); } public override string ToString() { return ContentType; } public abstract void WriteMessage(Message message, Stream stream); public ArraySegment WriteMessage(Message message, int maxMessageSize, BufferManager bufferManager) { return WriteMessage(message, maxMessageSize, bufferManager, 0); } public abstract ArraySegment WriteMessage(Message message, int maxMessageSize, BufferManager bufferManager, int messageOffset); public virtual bool IsContentTypeSupported(string contentType) { if (contentType == null) throw DiagnosticUtility.ExceptionUtility.ThrowHelperError(new ArgumentNullException("contentType")); return IsContentTypeSupported(contentType, this.ContentType, this.MediaType); } internal bool IsContentTypeSupported(string contentType, string supportedContentType, string supportedMediaType) { if (supportedContentType == contentType) return true; if (contentType.Length > supportedContentType.Length && contentType.StartsWith(supportedContentType, StringComparison.Ordinal) && contentType[supportedContentType.Length] == ';') return true; // now check case-insensitively if (contentType.StartsWith(supportedContentType, StringComparison.OrdinalIgnoreCase)) { if (contentType.Length == supportedContentType.Length) { return true; } else if (contentType.Length > supportedContentType.Length) { char ch = contentType[supportedContentType.Length]; // Linear Whitespace is allowed to appear between the end of one property and the semicolon. // LWS = [CRLF]? (SP | HT)+ if (ch == ';') { return true; } // Consume the [CRLF]? int i = supportedContentType.Length; if (ch == '\r' && contentType.Length > supportedContentType.Length + 1 && contentType[i + 1] == '\n') { i += 2; ch = contentType[i]; } // Look for a ';' or nothing after (SP | HT)+ if (ch == ' ' || ch == '\t') { i++; while (i < contentType.Length) { ch = contentType[i]; if (ch != ' ' && ch != '\t') break; ++i; } } if (ch == ';' || i == contentType.Length) return true; } } // sometimes we get a contentType that has parameters, but our encoders // merely expose the base content-type, so we will check a stripped version try { ContentType parsedContentType = new ContentType(contentType); if (supportedMediaType.Length > 0 && !supportedMediaType.Equals(parsedContentType.MediaType, StringComparison.OrdinalIgnoreCase)) return false; if (!IsCharSetSupported(parsedContentType.CharSet)) return false; } catch (FormatException) { // bad content type, so we definitely don't support it! return false; } return true; } internal virtual bool IsCharSetSupported(string charset) { return false; } internal void ThrowIfMismatchedMessageVersion(Message message) { if (message.Version != MessageVersion) { throw TraceUtility.ThrowHelperError( new ProtocolException(SR.GetString(SR.EncoderMessageVersionMismatch, message.Version, MessageVersion)), message); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- ObjectIDGenerator.cs
- GeneralTransform.cs
- returneventsaver.cs
- ClosableStream.cs
- ButtonBase.cs
- WebPartMenuStyle.cs
- SystemIcmpV6Statistics.cs
- MulticastDelegate.cs
- ResolvedKeyFrameEntry.cs
- RegexStringValidator.cs
- ApplicationHost.cs
- XsltException.cs
- SqlRowUpdatingEvent.cs
- ToolBarButtonDesigner.cs
- XPathScanner.cs
- RootContext.cs
- DoubleAnimationClockResource.cs
- PathSegment.cs
- HandledMouseEvent.cs
- HttpApplication.cs
- DocumentApplicationDocumentViewer.cs
- LinkDescriptor.cs
- GenericWebPart.cs
- ClockController.cs
- Line.cs
- TailPinnedEventArgs.cs
- PrimitiveDataContract.cs
- WebPartConnectionsConfigureVerb.cs
- TimeSpanValidator.cs
- FacetValueContainer.cs
- SecurityContext.cs
- DataGridViewRowConverter.cs
- DataGridTablesFactory.cs
- InternalBase.cs
- Exceptions.cs
- TagPrefixInfo.cs
- DisposableCollectionWrapper.cs
- XmlException.cs
- ParseNumbers.cs
- WebPartConnectionsEventArgs.cs
- ConsoleTraceListener.cs
- SystemTcpStatistics.cs
- SqlUdtInfo.cs
- TextBlock.cs
- AlternationConverter.cs
- TextEvent.cs
- UpdatableGenericsFeature.cs
- IndexedSelectQueryOperator.cs
- GlyphTypeface.cs
- MobileControlsSection.cs
- RepeaterItem.cs
- LinkButton.cs
- RequestBringIntoViewEventArgs.cs
- Geometry3D.cs
- Rect3DConverter.cs
- IListConverters.cs
- MetaChildrenColumn.cs
- DataGridrowEditEndingEventArgs.cs
- XmlSchemaObject.cs
- FunctionImportElement.cs
- SessionEndingEventArgs.cs
- TemplateManager.cs
- DateTimeStorage.cs
- JournalEntryListConverter.cs
- ReadOnlyTernaryTree.cs
- DesignerTextWriter.cs
- DaylightTime.cs
- Compilation.cs
- BlurBitmapEffect.cs
- SiteMapPath.cs
- RadialGradientBrush.cs
- SemanticResolver.cs
- RequestResponse.cs
- WebBrowserProgressChangedEventHandler.cs
- ContextItemManager.cs
- FlowStep.cs
- PersianCalendar.cs
- Logging.cs
- TemplateKey.cs
- DictationGrammar.cs
- InfocardExtendedInformationCollection.cs
- TemplatePagerField.cs
- SelectionListDesigner.cs
- DecimalAnimation.cs
- ExportOptions.cs
- StringBuilder.cs
- ElapsedEventArgs.cs
- ServiceXNameTypeConverter.cs
- QilFactory.cs
- Validator.cs
- PathParser.cs
- CacheOutputQuery.cs
- ClrPerspective.cs
- InternalBufferOverflowException.cs
- TCPListener.cs
- MetadataPropertyvalue.cs
- WindowsServiceCredential.cs
- NonVisualControlAttribute.cs
- MenuAdapter.cs
- CompilerGeneratedAttribute.cs