<webMessageEncoding>
Aktiviert Klartext-XML, JavaScript Object Notation (JSON)-Nachrichtencodierungen und unformatierten binären Inhalt, die bei der Verwendung in einer Windows Communication Foundation (WCF)-Bindung gelesen und geschrieben werden sollen.
Schemahierarchie
<<system.serviceModel>>
<bindings>
<customBinding>
<binding>
<webMessageEncoding>
Syntax
<webMessageEncoding
maxReadPoolSize="Integer"
maxWritePoolSize="Integer"
writeEncoding=”UnicodeFffeTextEncoding/Utf16TextEncoding/Utf8TextEncoding" />
Attribute und Elemente
In den folgenden Abschnitten werden Attribute, untergeordnete Elemente sowie übergeordnete Elemente beschrieben.
Attribute
Attribut | Beschreibung |
---|---|
maxReadPoolSize |
Die Anzahl von Nachrichten, die gleichzeitig gelesen werden können, ohne neue Reader zuzuordnen. Durch größere Poolgrößen wird das System toleranter gegenüber Aktivitätsspitzen auf Kosten eines umfangreicheren Workingsets. Der Standard ist 64 Reader für jeden der inneren Encoder (Text, JSON und "unformatiert"). Durch das Erhöhen dieser Zahl wird der Speicherverbrauch gesteigert, jedoch wird der Encoder auf einen plötzlichen Anstieg eingehender Nachrichten vorbereitet, da er Reader aus dem Pool verwenden kann, die bereits erstellt wurden, sodass keine neuen Reader erstellt werden. |
maxWritePoolSize |
Die maximale Anzahl von Nachrichten, die gleichzeitig gesendet werden können, ohne neue Writer zuzuordnen. Durch größere Poolgrößen wird das System toleranter gegenüber Aktivitätsspitzen auf Kosten eines größeren Workingsets. Der Standard ist 16 Writer für jeden der inneren Encoder (Text, JSON und "unformatiert"). Durch das Erhöhen dieser Zahl wird der Speicherverbrauch gesteigert, jedoch wird der Encoder auf einen plötzlichen Anstieg ausgehender Nachrichten vorbereitet, da er Writer aus dem Pool verwenden kann, die bereits erstellt wurden, sodass keine neuen Writer erstellt werden. |
writeEncoding |
Gibt die Zeichensatzcodierung an, die zum Ausgeben von Nachrichten über die Bindung verwendet werden soll. Gültige Werte sind:
Der Standardwert ist Utf8TextEncoding. Dieses Attribut ist vom Typ Encoding. |
Untergeordnete Elemente
Element | Beschreibung |
---|---|
Definiert die Beschränkungen der Komplexität von SOAP-Nachrichten, die von Endpunkten verarbeitet werden können, die mit dieser Bindung konfiguriert wurden. Dieses Element ist vom Typ XmlDictionaryReaderQuotasElement. |
Übergeordnete Elemente
Element | Beschreibung |
---|---|
Definiert alle Bindungsfähigkeiten der benutzerdefinierten Bindung. |
Hinweise
Beim Codieren wird eine Nachricht in eine Bytefolge transformiert. Beim Decodieren wird dieser Vorgang umgekehrt. Diese Vorgänge erfordern die Angabe einer Zeichencodierung.
Dazu delegiert das webMessageEncoding-Element Vorgänge an eine Reihe innerer Encoder, um die Klartext-XML und JSON-Codierungen sowie die unformatierten binären Daten zu verarbeiten. Diese Delegierung wird von einem zusammengesetzten Nachrichtenencoder durchgeführt.
Dieses Bindungselement und die zusammengesetzten Encoder werden zur Steuerung der Codierung in Szenarien eingesetzt, in denen keine SOAP-Nachrichten vom webHttpBinding-Element verwendet werden. Zu den Szenarien gehören u. a. "Plain Old XML" (POX), Representational State Transfer (REST), Really Simple Syndication (RSS) And Atom Syndication sowie Asynchronous JavaScript And XML (AJAX). Der zusammengesetzte Nachrichtenencoder unterstützt SOAP oder WS-Addressing nicht.
Das Bindungselement kann mit dem writeEncoding-Attribut mit einer Schreibzeichencodierung konfiguriert werden. Der bereitgestellte Encoding-Wert gibt das Verhalten beim Schreiben für die JSON- und Text-XML-Fälle an. Beim Lesen wird jede gültige Nachrichtencodierung und Textcodierung interpretiert.
maxReadPoolSize und maxWritePoolSize können auch zum Festlegen der maximalen Anzahl an jeweils zuzuweisenden Readern und Writern verwendet werden. Standardmäßig werden 64 Reader und 16 Writer zugeordnet.
Standardkomplexitätseinschränkungen werden darüber hinaus mit dem <readerQuotas>-Element festgelegt, um vor einer Klasse von DOS-Angriffen (Denial Of Service) zu schützen, die versuchen, die Nachrichtenkomplexität zum Binden von Endpunkt-Verarbeitungsressourcen zu verwenden.
Beispiel
<webMessageEncoding
maxReadPoolSize="256"
maxWritePoolSize="128"
messageVersion="None"
textEncoding=”utf-8”
/>
Siehe auch
Verweis
<customBinding>
WebMessageEncodingElement
CustomBinding
MessageEncodingBindingElement
WebMessageEncodingBindingElement
Konzepte
Weitere Ressourcen
Choosing a Message Encoder
Windows Communication Foundation Bindings
Extending Bindings
Custom Bindings