Пример:
public class Service1 : System.Web.Services.WebService
{
[WebMethod]
public int Add(int x, int y)
{
string request = getRawSOAPRequest();//How could you implement this part?
//.. do something with complete soap request
int sum = x + y;
return sum;
}
}
Альтернативой SoapExtensions является реализация IHttpModule и захват входящего потока по мере его поступления.
public class LogModule : IHttpModule
{
public void Init(HttpApplication context)
{
context.BeginRequest += this.OnBegin;
}
private void OnBegin(object sender, EventArgs e)
{
HttpApplication app = (HttpApplication)sender;
HttpContext context = app.Context;
byte[] buffer = new byte[context.Request.InputStream.Length];
context.Request.InputStream.Read(buffer, 0, buffer.Length);
context.Request.InputStream.Position = 0;
string soapMessage = Encoding.ASCII.GetString(buffer);
// Do something with soapMessage
}
public void Dispose()
{
throw new NotImplementedException();
}
}
Да, вы можете сделать это с помощью SoapExtensions. Вот хорошая статья, в которой описывается этот процесс.
Я предполагаю, что вы хотите зарегистрировать запрос SOAP для трассировки; возможно, у вас есть потребитель ваших услуг, который говорит вам, что отправляет вам хороший протокол SOAP, но вы им не верите, да?
В этом случае вам следует (временно) включить ведение журнала трассировки для вашей службы .
Если вы пытаетесь вести журнал общего назначения, не беспокойтесь о пакете SOAP, поскольку он тяжелый; ваши журналы быстро раздуваются. Просто запишите важные данные, например, «Добавить называется, X = foo, Y = bar».