如何在致电webservice

时间:2016-06-14 10:22:32

标签: c# xml web-services wcf soap

问题:作为调试问题的一部分,我想阅读WCF Web服务的XML请求。

显然,这比看上去更困难,在这方面的任何帮助都将非常感激。以下是我已经尝试过的内容。就像StackOverflow(link)上类似问题的答案一样。

我的解决方案:我已经创建了客户端设置网络服务提供商提供的端点。我已将客户端凭据添加为端点行为。在我调用服务之前,我添加了另一个端点行为,将请求和响应写为XML文件。唉,无济于事。

对webservice的简单调用:

public SaveAvailabilityAssessmentResponseType SaveAvailabilityAssessment(SaveAvailabilityAssessmentRequestType request)
{
   Client.Endpoint.Behaviors.Add(new CustomEndpointBehavior());

   return Client.SaveAvailabilityAssessment(_ocesCertHeader, _activeOrganisationHeader, request);
}

这是CustomEndpointBehavior类(简化了一点):

public class CustomEndpointBehavior : IEndpointBehavior
{
    public void ApplyClientBehavior(ServiceEndpoint endpoint, System.ServiceModel.Dispatcher.ClientRuntime clientRuntime)
    {
        clientRuntime.MessageInspectors.Add(new MessageExpector());
    }
}

这里是MessageExpector类:

internal class MessageExpector : IClientMessageInspector
{
    public void AfterReceiveReply(ref Message reply, object correlationState)
    {
        using (var sw = new StreamWriter(@"C:\temp\response.xml"))
        {
            sw.WriteLine(reply);
        }
    }

    public object BeforeSendRequest(ref Message request, IClientChannel channel)
    {
        using (var sw = new StreamWriter(@"C:\temp\request.xml"))
        {
            sw.WriteLine(request);
        }
        return new object();
    }
}

谁能告诉我我失踪了什么?

编辑:进一步调试显示,CustomEndpointBehavior中的代码尚未激活。就好像客户端点没有被添加到客户端的端点行为中。但那怎么可能呢?

1 个答案:

答案 0 :(得分:1)

您可以在不修改代码的情况下配置消息记录。 Here's a link to documentation。 您可以使用SvcTraceViewer.exe查看此日志