SoapServerMessage-Klasse
Stellt die Daten in einer von einem XML-Webdienstclient gesendeten SOAP-Anforderung oder in einer von diesem empfangenen SOAP-Antwort auf einer bestimmten SoapMessageStage dar. Diese Klasse kann nicht geerbt werden.
Namespace: System.Web.Services.Protocols
Assembly: System.Web.Services (in system.web.services.dll)
Syntax
'Declaration
Public NotInheritable Class SoapServerMessage
Inherits SoapMessage
'Usage
Dim instance As SoapServerMessage
public sealed class SoapServerMessage : SoapMessage
public ref class SoapServerMessage sealed : public SoapMessage
public final class SoapServerMessage extends SoapMessage
public final class SoapServerMessage extends SoapMessage
Beispiel
Das folgende Codefragment ist Teil einer SOAP-Erweiterung, mit der die von einer XML-Webdienstmethode gesendeten und von dieser empfangenen SOAP-Nachrichten protokolliert werden. Dieses spezifische Fragment verarbeitet die an die SoapExtension.ProcessMessage-Methode der SOAP-Erweiterung übergebene SoapServerMessage, indem die Eigenschaften von SoapServerMessage in die Protokolldatei geschrieben werden.
' Process the SOAP message received and write it to a log file.
Public Overrides Sub ProcessMessage(message As SoapMessage)
Select Case message.Stage
Case SoapMessageStage.BeforeSerialize
Case SoapMessageStage.AfterSerialize
WriteOutput(CType(message, SoapServerMessage))
Case SoapMessageStage.BeforeDeserialize
WriteInputBeforeDeserialize(CType(message, SoapServerMessage))
Case SoapMessageStage.AfterDeserialize
WriteInputAfterDeserialize(CType(message, SoapServerMessage))
Case Else
Throw New Exception("invalid stage")
End Select
End Sub 'ProcessMessage
' Write the contents of the incoming SOAP message to the log file.
Public Sub WriteInputAfterDeserialize(message As SoapServerMessage)
Dim myFileStream As New FileStream(filename, FileMode.Append, FileAccess.Write)
Dim myStreamWriter As New StreamWriter(myFileStream)
' Print to the log file the request header field for SoapAction header.
myStreamWriter.WriteLine("The SoapAction Http request header field is: ")
myStreamWriter.WriteLine((ControlChars.Tab + message.Action))
' Print to the log file the type of the XML Web service.
myStreamWriter.WriteLine("The type of the XML Web service is: ")
If message.Server.GetType().Equals(GetType(MathSvc)) Then
myStreamWriter.WriteLine(ControlChars.Tab + "MathSvc")
End If
' Print to the log file the name of the XML Web service method.
myStreamWriter.WriteLine("The name of the XML Web service method requested:")
myStreamWriter.WriteLine((ControlChars.Tab + message.MethodInfo.Name))
' Print to the log file if the method invoked is OneWay.
If message.OneWay Then
myStreamWriter.WriteLine( _
"The client doesn't wait for the server to finish processing")
Else
myStreamWriter.WriteLine( _
"The client waits for the server to finish processing")
End If
' Print to the log file the URL of the site that provides
' implementation of the XML Web service method.
myStreamWriter.WriteLine( _
"The url of the XML Web service method requested: ")
myStreamWriter.WriteLine((ControlChars.Tab + message.Url))
myStreamWriter.Flush()
myStreamWriter.Close()
myFileStream.Close()
End Sub 'WriteInputAfterDeserialize
// Process the SOAP message received and write it to a log file.
public override void ProcessMessage(SoapMessage message)
{
switch (message.Stage)
{
case SoapMessageStage.BeforeSerialize:
break;
case SoapMessageStage.AfterSerialize:
WriteOutput((SoapServerMessage)message);
break;
case SoapMessageStage.BeforeDeserialize:
WriteInputBeforeDeserialize((SoapServerMessage)message);
break;
case SoapMessageStage.AfterDeserialize:
WriteInputAfterDeserialize((SoapServerMessage)message);
break;
default:
throw new Exception("invalid stage");
}
}
// Write the contents of the incoming SOAP message to the log file.
public void WriteInputAfterDeserialize(SoapServerMessage message)
{
FileStream myFileStream =
new FileStream(filename, FileMode.Append, FileAccess.Write);
StreamWriter myStreamWriter = new StreamWriter(myFileStream);
// Print to the log file the request header field for SoapAction header.
myStreamWriter.WriteLine("The SoapAction HTTP request header field is: ");
myStreamWriter.WriteLine("\t" + message.Action);
// Print to the log file the type of the XML Web service.
myStreamWriter.WriteLine("The type of the XML Web service is: ");
if((message.Server.GetType()).Equals(typeof(MathSvc)))
myStreamWriter.WriteLine("\tMathSvc");
// Print to the log file the name of the XML Web service method.
myStreamWriter.WriteLine(
"The method of the XML Web service method requested:");
myStreamWriter.WriteLine("\t" + message.MethodInfo.Name);
// Print to the log file if the method invoked is OneWay.
if(message.OneWay)
myStreamWriter.WriteLine(
"The client doesn't wait for the server to finish processing");
else
myStreamWriter.WriteLine(
"The client waits for the server to finish processing");
// Print to the log file the URL of the site that provides
// implementation of the XML Web service method.
myStreamWriter.WriteLine(
"The URL of the requested XML Web service method: ");
myStreamWriter.WriteLine("\t" + message.Url);
myStreamWriter.Flush();
myStreamWriter.Close();
myFileStream.Close();
}
Vererbungshierarchie
System.Object
System.Web.Services.Protocols.SoapMessage
System.Web.Services.Protocols.SoapServerMessage
Threadsicherheit
Alle öffentlichen statischen (Shared in Visual Basic) Member dieses Typs sind threadsicher. Bei Instanzmembern ist die Threadsicherheit nicht gewährleistet.
Plattformen
Windows 98, Windows 2000 SP4, Windows Millennium Edition, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
.NET Framework unterstützt nicht alle Versionen sämtlicher Plattformen. Eine Liste der unterstützten Versionen finden Sie unter Systemanforderungen.
Versionsinformationen
.NET Framework
Unterstützt in: 2.0, 1.1, 1.0
Siehe auch
Referenz
SoapServerMessage-Member
System.Web.Services.Protocols-Namespace