Java Web サービスを呼び出す C# Winforms クライアントがあります。サービスが正しく呼び出され、期待される結果が返されます。
顔が青くなるまで、ソープエクステンションを追加しようとしています. それは正しくコンパイルされ、登録されていると信じるあらゆる理由があります...しかし、呼び出されることはありません。app.config を変更してみました。「wss.SoapExtensionTypes.Add(soapInterceptor)」を呼び出してみました: 同じこと。私の SoapException の "Initalize()" および "ProcessMessage()" 関数は、決して呼び出されません。
Q: 何か提案はありますか? デバッグのヒントはありますか?
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 =>
try
{
GitSearchServiceSoapClient webService = new GitSearchServiceSoapClient();
RequestOptions requestOptions = new RequestOptions();
resp = webService.GetOosData(requestOptions, edtGroupId2.Text, "2012");
...