为什么不调用我的C#Soap扩展?

时间:2013-01-05 03:46:11

标签: c# .net soap-extension

我有一个调用Java Web服务的C#Winforms客户端。该服务被正确调用并返回预期的结果。

我一直在努力,直到我脸红了才能添加肥皂扩展。它编译正确,我完全有理由相信它已经注册了......但它永远不会被调用。我尝试修改app.config;我试着调用“wss.SoapExtensionTypes.Add(soapInterceptor)”:同样的事情。我的SoapException的“Initalize()”和“ProcessMessage()”函数根本就不会被调用。

问:有什么建议吗?任何调试技巧?

ClientTraceExtension.cs =>

using System;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Web.Services.Configuration;
using System.IO;
using System.Net;
using System.Reflection;
using System.Security.Permissions;
using GITSearchClient.ServiceReference1;

/*
 * REFERENCE:
 * http://msdn.microsoft.com/en-US/library/system.web.services.protocols.soapextension%28v=vs.90%29.aspx
 */
namespace GITSearchClient
{
    public class ClientTraceExtension : SoapExtension
    {
        private Stream oldStream;
        private Stream newStream;
        private string filename = "c:\\temp\\soap_result.txt";

        // Custom SoapExtension must override: ChainStream, GetInitializer()x2, Initialize() and ProcessMessage()
        public override Stream ChainStream(Stream stream)
        {
            oldStream = stream;
            newStream = new MemoryStream();
            return newStream;
        }

        public override object GetInitializer(Type WebServiceType)
        {
            // filename = "C:\\temp\\soap_" + WebServiceType.FullName + ".txt";
            //return filename;
            return null;
        }

        public override object GetInitializer(LogicalMethodInfo methodInfo, SoapExtensionAttribute attribute)
        {
            //return filename;
            return null;
        }

        public override void Initialize(object initializer)
        {
            // filename = (string)initializer;
        }

        public override void ProcessMessage(SoapMessage message)
        {
            //int i = 0;
            //int j = 1 / i;  // DEBUG: Stop here
            switch (message.Stage)
            {
                case SoapMessageStage.BeforeSerialize:
                    break;
                case SoapMessageStage.AfterSerialize:
                    WriteOutput(message);
                    break;
                case SoapMessageStage.BeforeDeserialize:
                    WriteInput(message);
                    break;
                case SoapMessageStage.AfterDeserialize:
                    break;
            }
        }
        ...

app.config =>

<?xml version="1.0"?>
<configuration>
  <system.web>
    <webServices>
      <soapExtensionTypes>
        <add 
           type="GITSearchClient.ClientTraceExtension, GITSearchClient" 
           priority="1" 
           group="0"/>
      </soapExtensionTypes>
    </webServices>
  </system.web>
  <startup>
    <supportedRuntime version="v2.0.50727" sku="Client"/>
  </startup>
  <system.serviceModel>
        <bindings>
            <basicHttpBinding>
               ...

Form1.cs =&gt;

    try
    {
        GitSearchServiceSoapClient webService = new GitSearchServiceSoapClient();
        RequestOptions requestOptions = new RequestOptions();
        resp = webService.GetOosData(requestOptions, edtGroupId2.Text, "2012");
        ...

1 个答案:

答案 0 :(得分:7)

我认为您在这里混合了新旧,即ASMX Web服务与WCF,请参阅this问题以了解类似问题。看看约翰的答案。