How to: Inspect and Modify Messages on the Service

 

You can inspect or modify the incoming or outgoing messages across a Windows Communication Foundation (WCF) client by implementing a System.ServiceModel.Dispatcher.IDispatchMessageInspector and inserting it into the service runtime. For more information, see Extending Dispatchers. The equivalent feature on the service is the System.ServiceModel.Dispatcher.IClientMessageInspector.

To inspect or modify messages

  1. Implement a System.ServiceModel.Description.IServiceBehavior, System.ServiceModel.Description.IEndpointBehavior, or System.ServiceModel.Description.IContractBehavior interface depending upon the scope at which you want to easily insert your service message inspector.

  2. Insert your behavior prior to calling the ICommunicationObject.Open method on the System.ServiceModel.ServiceHost. For details, see Configuring and Extending the Runtime with Behaviors.

Example

The following code examples show, in order:

  • A service inspector implementation.

  • A service behavior that inserts the inspector.

  • A configuration file that loads and runs the behavior in a service application.

#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 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());
    }
  }
}
Show: