0

私はWebサービスを利用していますが、突然、次のエラーで失敗します。

System.InvalidOperationException was caught
  Message="No corresponding start element is open."
  Source="mscorlib"

Webサービスは正しく呼び出され、有効なxmlを使用して(fiddlerでチェックされた)通常の応答を返します。

生成されたsoapクライアントのどこかにデータ要素がありませんが、自動生成されたsoapクライアントコードにステップインできないため、どこから始めればよいのかわかりません。

数時間の無駄な時間の後、誰かがこれのトラブルシューティングを開始する方法を手伝ってくれることを願っています。自動生成されたsoapクライアントコードにステップインする方法はありますか? 何が悪いのかを特定するために私が取ることができる代替アプローチはありますか?

私はVS2008SP1で開発しています。自動生成されたコードのランタイムバージョン:2.0.50727.3634

生成されたコードはクラスライブラリにあり、コンソールアプリから呼び出されます。サービスバインディングの場合、コンソールアプリからapp.configに以下が追加されました。

  <system.serviceModel>
   <bindings>
    <basicHttpBinding>
      <binding name="OrderServiceSoap" closeTimeout="00:01:00" openTimeout="00:01:00"
          receiveTimeout="00:10:00" sendTimeout="00:01:00" allowCookies="false"
          bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard"
          maxBufferSize="65536" maxBufferPoolSize="524288" maxReceivedMessageSize="65536"
          messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered"
          useDefaultWebProxy="true">
        <readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
            maxBytesPerRead="4096" maxNameTableCharCount="16384" />
        <security mode="None">
          <transport clientCredentialType="None" proxyCredentialType="None"
              realm="" />
          <message clientCredentialType="UserName" algorithmSuite="Default" />
        </security>
      </binding>
    </basicHttpBinding>
  </bindings>
  <client>
    <endpoint address="http://www.acdc.com/services/order.asmx"
        binding="basicHttpBinding" bindingConfiguration="OrderServiceSoap"
        contract="MLOrderServiceReference.OrderServiceSoap" name="OrderServiceSoap" />
  </client>
  </system.serviceModel>

そして、これはエラーの私のスタックトレースです:

 System.InvalidOperationException was caught
  Message="No corresponding start element is open."
  Source="mscorlib"
  StackTrace:
 Server stack trace: 
  at System.Xml.XmlBaseReader.ReadEndElement()
   at System.ServiceModel.Channels.Message.ReadFromBodyContentsToEnd(XmlDictionaryReader reader, EnvelopeVersion envelopeVersion)
   at System.ServiceModel.Channels.Message.ReadFromBodyContentsToEnd(XmlDictionaryReader reader)
   at System.ServiceModel.Dispatcher.OperationFormatter.DeserializeBodyContents(Message message, Object[] parameters, Boolean isRequest)
   at System.ServiceModel.Dispatcher.OperationFormatter.DeserializeReply(Message message, Object[] parameters)
   at System.ServiceModel.Dispatcher.ProxyOperationRuntime.AfterReply(ProxyRpc& rpc)
   at System.ServiceModel.Channels.ServiceChannel.HandleReply(ProxyOperationRuntime operation, ProxyRpc& rpc)
   at System.ServiceModel.Channels.ServiceChannel.Call(String action, Boolean oneway, ProxyOperationRuntime operation, Object[] ins, Object[] outs, TimeSpan timeout)
   at System.ServiceModel.Channels.ServiceChannel.Call(String action, Boolean oneway, ProxyOperationRuntime operation, Object[] ins, Object[] outs)
   at System.ServiceModel.Channels.ServiceChannelProxy.InvokeService(IMethodCallMessage methodCall, ProxyOperationRuntime operation)
   at System.ServiceModel.Channels.ServiceChannelProxy.Invoke(IMessage message)\r\n\r\nException rethrown at [0]: 
   at System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg)
   at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type)
   at DS.ACDC.AppService.MLOrderServiceReference.OrderServiceSoap.GetOrderDetail(Int32 ClientId, Int32 OrderId)
   at DS.ACDC.AppService.MLOrderServiceReference.OrderServiceSoapClient.GetOrderDetail(Int32 ClientId, Int32 OrderId) in C:\\localdata\\ML\\ACDC\\DS.ACDC.AppService\\Service References\\MLOrderServiceReference\\Reference.cs:line 4151
   at DS.ACDC.AppService.OrderService.getOrder(CISmapping CISdetails) in C:\\localdata\\ML\\ACDC\\DS.ACDC.AppService\\OrderService.cs:line 123

編集: 古き良きWeb参照の代わりにWCFサービス参照の使用に関連しているようです。XmlSerializerが機能しているときに、どういうわけかDataContractSerializerが混乱しています。

4

1 に答える 1

1

さて、他の誰かが同じ問題に直面した場合に備えて、私はここで私自身の質問に答えています。

「外部Webサービスのデバッグを開始する場所/方法」の質問に対する答えは、構成ファイルに以下を追加することです。

   <system.diagnostics>
     <switches>
       <add name="XmlSerialization.Compilation" value="1" />
     </switches>
   </system.diagnostics>
于 2013-01-18T11:57:58.073 に答える