Udostępnij za pośrednictwem


SoapClientMessage Klasa

Definicja

Reprezentuje dane w żądaniu PROTOKOŁU SOAP wysłanym lub odpowiedź PROTOKOŁU SOAP odebraną przez klienta usługi sieci Web XML w określonym SoapMessageStage. Klasa ta nie może być dziedziczona.

public ref class SoapClientMessage sealed : System::Web::Services::Protocols::SoapMessage
public sealed class SoapClientMessage : System.Web.Services.Protocols.SoapMessage
type SoapClientMessage = class
    inherit SoapMessage
Public NotInheritable Class SoapClientMessage
Inherits SoapMessage
Dziedziczenie
SoapClientMessage

Przykłady

Poniższy fragment kodu jest częścią rozszerzenia protokołu SOAP, które rejestruje komunikaty PROTOKOŁU SOAP wysyłane i odbierane przez klienta usługi sieci Web XML. Ten konkretny fragment przetwarza SoapClientMessage przekazany do SoapExtension.ProcessMessage metody rozszerzenia SOAP, zapisując właściwości SoapClientMessage do pliku dziennika.

// Process the SOAP message received and write to a log file.
void ProcessMessage( SoapMessage^ message )
{
   switch ( message->Stage )
   {
      case SoapMessageStage::BeforeSerialize:
         break;
      case SoapMessageStage::AfterSerialize:
         WriteOutput( dynamic_cast<SoapClientMessage^>(message) );
         break;
      case SoapMessageStage::BeforeDeserialize:
         WriteInput( dynamic_cast<SoapClientMessage^>(message) );
         break;
      case SoapMessageStage::AfterDeserialize:
         break;
      default:
         throw gcnew Exception( "invalid stage" );
   }
}

// Write the contents of the outgoing SOAP message to the log file.
void WriteOutput( SoapClientMessage^ message )
{
   newStream->Position = 0;
   FileStream^ myFileStream = gcnew FileStream( filename, FileMode::Append,
      FileAccess::Write );
   StreamWriter^ myStreamWriter = gcnew StreamWriter( myFileStream );
   myStreamWriter->WriteLine(
      "================================== Request at {0}", DateTime::Now );
   
   // Print to the log file the request header field for SoapAction header.
   myStreamWriter->WriteLine( "The SoapAction Http request header field is: " );
   myStreamWriter->WriteLine( "\t{0}", message->Action );
   
   // Print to the log file the type of the client that invoked 
   // the XML Web service method.
   myStreamWriter->WriteLine( "The type of the client is: " );
   if ( (message->Client->GetType())->Equals( typeid<MathSvc^> ) )
   {
      myStreamWriter->WriteLine( "\tMathSvc" );
   }
   
   // Print to the log file the method invoked by the client.
   myStreamWriter->WriteLine(
      "The method that has been invoked by the client is:" );
   myStreamWriter->WriteLine( "\t{0}", 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 method.
   myStreamWriter->WriteLine(
      "The URL of the XML Web service method that has been requested is: " );
   myStreamWriter->WriteLine( "\t{0}", message->Url );
   myStreamWriter->WriteLine( "The contents of the SOAP envelope are: " );
   myStreamWriter->Flush();
   
   // Copy the contents of one stream to another. 
   Copy( newStream, myFileStream );
   myFileStream->Close();
   newStream->Position = 0;
   
   // Copy the contents of one stream to another. 
   Copy( newStream, oldStream );
}

// Process the SOAP message received and write to a log file.
public override void ProcessMessage(SoapMessage message)
{
   switch (message.Stage)
   {
      case SoapMessageStage.BeforeSerialize:
         break;
      case SoapMessageStage.AfterSerialize:
         WriteOutput((SoapClientMessage)message);
         break;
      case SoapMessageStage.BeforeDeserialize:
         WriteInput((SoapClientMessage)message);
         break;
      case SoapMessageStage.AfterDeserialize:
         break;
      default:
         throw new Exception("invalid stage");
   }
}

// Write the contents of the outgoing SOAP message to the log file.
public void WriteOutput(SoapClientMessage message)
{
   newStream.Position = 0;
   FileStream myFileStream = new FileStream(filename, FileMode.Append,
      FileAccess.Write);
   StreamWriter myStreamWriter = new StreamWriter(myFileStream);
   myStreamWriter.WriteLine(
      "================================== Request at "
      + DateTime.Now);

   // 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 client that invoked
   // the XML Web service method.
   myStreamWriter.WriteLine("The type of the client is: ");
   if((message.Client.GetType()).Equals(typeof(MathSvc)))
      myStreamWriter.WriteLine("\tMathSvc");

   // Print to the log file the method invoked by the client.
   myStreamWriter.WriteLine(
      "The method that has been invoked by the client is:");
   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 method.
   myStreamWriter.WriteLine(
      "The URL of the XML Web service method that has been requested is: ");
   myStreamWriter.WriteLine("\t" + message.Url);
   myStreamWriter.WriteLine("The contents of the SOAP envelope are: ");
   myStreamWriter.Flush();

   // Copy the contents of one stream to another.
   Copy(newStream, myFileStream);
   myFileStream.Close();
   newStream.Position = 0;

   // Copy the contents of one stream to another.
   Copy(newStream, oldStream);
}
 ' Process the SOAP message received and write to a log file.
 Public Overrides Sub ProcessMessage(message As SoapMessage)
    Select Case message.Stage
       Case SoapMessageStage.BeforeSerialize
       Case SoapMessageStage.AfterSerialize
          WriteOutput(CType(message, SoapClientMessage))
       Case SoapMessageStage.BeforeDeserialize
          WriteInput(CType(message, SoapClientMessage))
       Case SoapMessageStage.AfterDeserialize
       Case Else
             Throw New Exception("invalid stage")
    End Select
 End Sub
 
 
 ' Write the contents of the outgoing SOAP message to the log file.
 Public Sub WriteOutput(message As SoapClientMessage)
    newStream.Position = 0
    Dim myFileStream As New FileStream(filename, FileMode.Append, _
       FileAccess.Write)
    Dim myStreamWriter As New StreamWriter(myFileStream)
    myStreamWriter.WriteLine( _
       "================================== Request at " & DateTime.Now)

    ' 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 client that invoked
    ' the XML Web service method.
    myStreamWriter.WriteLine("The type of the client is: ")
    If message.Client.GetType().Equals(GetType(MathSvc)) Then
       myStreamWriter.WriteLine(ControlChars.Tab & "MathSvc")
    End If

   ' Print to the log file the method invoked by the client.
    myStreamWriter.WriteLine( _
       "The method that has been invoked by the client is:")
    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 method.
    myStreamWriter.WriteLine( _
       "The url of the XML Web service method that has been requested is: ")
    myStreamWriter.WriteLine(ControlChars.Tab & message.Url)
    myStreamWriter.WriteLine("The contents of the SOAP envelope are: ")
    myStreamWriter.Flush()

    ' Copy the contents of one stream to another. 
    Copy(newStream, myFileStream)
    myStreamWriter.Close()
    myFileStream.Close()
    newStream.Position = 0

    ' Copy the contents of one stream to another. 
    Copy(newStream, oldStream)
End Sub

Właściwości

Action

Pobiera pole nagłówka SOAPAction żądania HTTP dla żądania SOAP lub odpowiedzi protokołu SOAP.

Client

Pobiera wystąpienie klasy serwera proxy klienta, które pochodzi z klasy SoapHttpClientProtocol.

ContentEncoding

Pobiera lub ustawia zawartość nagłówka Content-Encoding HTTP.

(Odziedziczone po SoapMessage)
ContentType

Pobiera lub ustawia protokół HTTP Content-Type żądania SOAP lub odpowiedzi protokołu SOAP.

(Odziedziczone po SoapMessage)
Exception

SoapException Pobiera element z wywołania do metody usługi sieci Web XML.

(Odziedziczone po SoapMessage)
Headers

Kolekcja nagłówków PROTOKOŁU SOAP zastosowanych do bieżącego żądania SOAP lub odpowiedzi PROTOKOŁU SOAP.

(Odziedziczone po SoapMessage)
MethodInfo

Pobiera reprezentację prototypu metody metody usługi sieci Web XML, dla której ma być przeznaczone żądanie PROTOKOŁU SOAP.

OneWay

Pobiera wartość wskazującą, czy klient czeka na zakończenie przetwarzania metody usługi sieci Web XML.

SoapVersion

Pobiera wersję protokołu SOAP używanego do komunikowania się z usługą sieci Web XML.

SoapVersion

Pobiera wersję protokołu SOAP używaną do komunikowania się z usługą sieci Web XML.

(Odziedziczone po SoapMessage)
Stage

SoapMessageStage Pobiera element .SoapMessage

(Odziedziczone po SoapMessage)
Stream

Pobiera dane reprezentujące żądanie SOAP lub odpowiedź PROTOKOŁU SOAP w postaci Stream.

(Odziedziczone po SoapMessage)
Url

Pobiera adres URL usługi sieci Web XML.

Metody

EnsureInStage()

W przypadku zastąpienia w klasie pochodnej potwierdza, że bieżący SoapMessageStage jest etapem, w którym są dostępne parametry.

(Odziedziczone po SoapMessage)
EnsureOutStage()

Po przesłonięciu w klasie pochodnej potwierdza, że bieżący SoapMessageStage etap jest etapem, w którym dostępne są parametry.

(Odziedziczone po SoapMessage)
EnsureStage(SoapMessageStage)

Zapewnia, że SoapMessageStage wywołanie metody usługi sieci Web XML jest etapem lub etapami przekazywanymi. Jeśli bieżący etap przetwarzania nie jest jednym z przekazanych etapów, zgłaszany jest wyjątek.

(Odziedziczone po SoapMessage)
Equals(Object)

Określa, czy dany obiekt jest taki sam, jak bieżący obiekt.

(Odziedziczone po Object)
GetHashCode()

Służy jako domyślna funkcja skrótu.

(Odziedziczone po Object)
GetInParameterValue(Int32)

Pobiera parametr przekazany do metody usługi sieci Web XML w określonym indeksie.

(Odziedziczone po SoapMessage)
GetOutParameterValue(Int32)

Pobiera parametr out przekazany do metody usługi sieci Web XML w określonym indeksie.

(Odziedziczone po SoapMessage)
GetReturnValue()

Pobiera wartość zwracaną przez metodę usługi sieci Web XML.

(Odziedziczone po SoapMessage)
GetType()

Type Pobiera wartość bieżącego wystąpienia.

(Odziedziczone po Object)
MemberwiseClone()

Tworzy płytkią kopię bieżącego Objectelementu .

(Odziedziczone po Object)
ToString()

Zwraca ciąg reprezentujący bieżący obiekt.

(Odziedziczone po Object)

Dotyczy