IDispatchMessageInspector.AfterReceiveRequest(Message, IClientChannel, InstanceContext) Methode

Definition

Wird aufgerufen, nachdem eine eingehende Nachricht empfangen wurde, jedoch bevor die Nachricht an den beabsichtigten Vorgang weitergeleitet wird.Called after an inbound message has been received but before the message is dispatched to the intended operation.

public:
 System::Object ^ AfterReceiveRequest(System::ServiceModel::Channels::Message ^ % request, System::ServiceModel::IClientChannel ^ channel, System::ServiceModel::InstanceContext ^ instanceContext);
public object AfterReceiveRequest (ref System.ServiceModel.Channels.Message request, System.ServiceModel.IClientChannel channel, System.ServiceModel.InstanceContext instanceContext);
abstract member AfterReceiveRequest : Message * System.ServiceModel.IClientChannel * System.ServiceModel.InstanceContext -> obj

Parameter

request
Message

Die Anforderungsnachricht.The request message.

channel
IClientChannel

Der eingehende Kanal.The incoming channel.

instanceContext
InstanceContext

Die aktuelle Dienstinstanz.The current service instance.

Gibt zurück

Das Objekt, das verwendet wird, um den Zustand zu korrelieren.The object used to correlate state. Dieses Objekt wird an die BeforeSendReply(Message, Object)-Methode zurückgegeben.This object is passed back in the BeforeSendReply(Message, Object) method.

Beispiele

Im folgenden Codebeispiel wird ein grundlegender IDispatchMessageInspector veranschaulicht, der eine Zeichenfolge in der Konsole ausgibt, wenn er aufgerufen wird.The following code example shows a basic IDispatchMessageInspector that writes a string to the console when it is invoked.

#region IDispatchMessageInspector Members
public object AfterReceiveRequest(ref System.ServiceModel.Channels.Message request, IClientChannel channel, InstanceContext instanceContext)
{
  Console.WriteLine("IDispatchMessageInspector.AfterReceiveRequest called.");
  return null;
}

public void BeforeSendReply(ref System.ServiceModel.Channels.Message reply, object correlationState)
{
  Console.WriteLine("IDispatchMessageInspector.BeforeSendReply called.");
}
#endregion
#Region "IDispatchMessageInspector Members"
    Public Function AfterReceiveRequest(ByRef request As System.ServiceModel.Channels.Message, _
                       ByVal channel As IClientChannel, ByVal instanceContext As InstanceContext) _
                       As Object Implements IDispatchMessageInspector.AfterReceiveRequest
        Console.WriteLine("IDispatchMessageInspector.AfterReceiveRequest called.")
        Return Nothing
    End Function

    Public Sub BeforeSendReply(ByRef reply As System.ServiceModel.Channels.Message, ByVal correlationState As Object) _
    Implements IDispatchMessageInspector.BeforeSendReply
        Console.WriteLine("IDispatchMessageInspector.BeforeSendReply called.")
    End Sub
#End Region

Im folgenden Codebeispiel wird die Implementierung von IServiceBehavior veranschaulicht, das InspectorIDispatchMessageInspector der DispatchRuntime.MessageInspectors-Auflistung hinzufügt.The following code example shows the implementation of an IServiceBehavior that adds the InspectorIDispatchMessageInspector to the DispatchRuntime.MessageInspectors collection.

#region IServiceBehavior Members
public void AddBindingParameters(
  ServiceDescription serviceDescription, 
  ServiceHostBase serviceHostBase, 
  System.Collections.ObjectModel.Collection<ServiceEndpoint> endpoints, 
  BindingParameterCollection bindingParameters
)
{ return; }

public void ApplyDispatchBehavior(ServiceDescription serviceDescription, ServiceHostBase serviceHostBase)
{
  foreach (ChannelDispatcher chDisp in serviceHostBase.ChannelDispatchers)
  {
    foreach (EndpointDispatcher epDisp in chDisp.Endpoints)
    {
      epDisp.DispatchRuntime.MessageInspectors.Add(new Inspector());
      foreach (DispatchOperation op in epDisp.DispatchRuntime.Operations)
        op.ParameterInspectors.Add(new Inspector());
    }
  }
}
#Region "IServiceBehavior Members"
    Public Sub AddBindingParameters(ByVal serviceDescription As ServiceDescription, _
                   ByVal serviceHostBase As ServiceHostBase, ByVal endpoints As  _
                   System.Collections.ObjectModel.Collection(Of ServiceEndpoint), _
                   ByVal bindingParameters As BindingParameterCollection) Implements IServiceBehavior.AddBindingParameters
        Return
    End Sub

    Public Sub ApplyDispatchBehavior(ByVal serviceDescription As ServiceDescription, _
                                     ByVal serviceHostBase As ServiceHostBase) Implements _
                                     IServiceBehavior.ApplyDispatchBehavior
        For Each chDisp As ChannelDispatcher In serviceHostBase.ChannelDispatchers
            For Each epDisp As EndpointDispatcher In chDisp.Endpoints
                epDisp.DispatchRuntime.MessageInspectors.Add(New Inspector())
                For Each op As DispatchOperation In epDisp.DispatchRuntime.Operations
                    op.ParameterInspectors.Add(New Inspector())
                Next op
            Next epDisp
        Next chDisp
    End Sub

Im folgenden Codebeispiel wird veranschaulicht, wie eine Anwendungskonfigurationsdatei verwendet wird, um das Dienstverhalten zu laden, das den InspectorIDispatchMessageInspector einfügt.The following code example shows the use of an application configuration file to load the service behavior that inserts the InspectorIDispatchMessageInspector.

<configuration>
  <system.serviceModel>
    <services>
      <service 
        name="Microsoft.WCF.Documentation.SampleService"
        behaviorConfiguration="metadataSupport">
        <host>
          <baseAddresses>
            <add baseAddress="http://localhost:8080/SampleService" />
          </baseAddresses>
        </host>
        <endpoint
          address=""
          binding="wsHttpBinding"
          contract="Microsoft.WCF.Documentation.ISampleService"
        />
        <endpoint
           address="mex"
           binding="mexHttpBinding"
           contract="IMetadataExchange"
        />
      </service>
    </services>
    <behaviors>
      <serviceBehaviors>
        <behavior name="metadataSupport">
          <serviceMetadata httpGetEnabled="true" httpGetUrl=""/>
          <serviceInterceptors />
        </behavior>
      </serviceBehaviors>
    </behaviors>
    <extensions>
      <behaviorExtensions>
        <add 
          name="serviceInterceptors" 
          type="Microsoft.WCF.Documentation.InspectorInserter, HostApplication, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null"
        />
      </behaviorExtensions>
    </extensions>
  </system.serviceModel>
</configuration>

Hinweise

Verwenden Sie die AfterReceiveRequest-Methode, um die eingehende Nachricht, den Clientkanal, der sie bereitgestellt hat, und die aktuelle Dienstinstanz zu prüfen oder zu ändern.Use the AfterReceiveRequest method to inspect or modify the incoming message, the client channel that provided it, and the current service instance. Der Rückgabewert kann jedes Objekt sein, das Sie für Korrelationszwecke verwenden möchten; es wird als correlationState-Parameter in der BeforeSendReply-Methode zurückgegeben.The return value can be any object that you want to use for correlation purposes; it is returned to you as the correlationState parameter in the BeforeSendReply method.

Wichtig

Sie können den Text der Nachricht nicht verwenden, sofern Sie nicht die gesamte Nachricht puffern und eine Kopie davon erstellen.You cannot use the body of the message unless you buffer the entire message and make a copy. Wenn Sie so vorgehen, müssen Sie zwei Kopien der Nachricht erstellen: eine für das Überprüfen und die zweite für das Überschreiben des request-Parameters.If you do this, you must make two copies of the message: one to inspect, and the other to overwrite the request parameter.

Gilt für: