Как отслеживать запросы ScriptService WebService?

У меня есть SoapExtension, который предназначен для регистрации всех запросов и ответов SOAP. Он прекрасно работает для вызовов из приложения, использующего MS Soap Toolkit (OnBase Workflow). Но это не работает для вызовов, сделанных $ .ajax () на html-странице. Вот пример:

<code>$.ajax({
    type: "POST",
    url: url,
    data: data,
    contentType: "application/json; charset=utf-8",
    dataType: "json"
});
</code>

Он вызывает ASP.NET 3.5 WebService, помеченный атрибутами WebService и ScriptService:

<code>[WebService(Namespace = XmlSerializationService.DefaultNamespace)]
[ScriptService]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class DepartmentAssigneeService : WebService
{
    private readonly DepartmentAssigneeController _controller = new DepartmentAssigneeController();

    /// <summary>
    /// Fetches the role items.
    /// </summary>
    /// <returns></returns>
    [WebMethod]
    [SoapLog]
    public ListItem[] FetchDepartmentItems()
    {
        return CreateListItems(_controller.FetchDepartments());
    }
}
</code>

А вот основы для SoapExtension и SoapExtensionAttribute:

<code>public class LoggingSoapExtension : SoapExtension, IDisposable { /*...*/ }

[AttributeUsage(AttributeTargets.Method)]
public sealed class SoapLogAttribute : SoapExtensionAttribute { /*...*/ }
</code>

Я что-то упустил, что позволило бы LoggingSoapExtension выполнять запросы $ .ajax ()?

Update

@Chris Brandsma

It might be because you are requesting Json results instead of XML via your web service (dataType: "json"). So the ScriptService attribute is being activated, but you are not sending SOAP messages.

Это отвечает, почему SoapExtension не работает. Есть предложения по отслеживанию с помощью ScriptService? Единственное, что приходит на ум, - это базовый класс ScriptService, который предоставляет метод для регистрации запроса. Но тогда мне придется вызывать этот метод в каждом WebMethod в каждом ScriptService WebService (у меня их немало). Я хотел бы использовать что-то такое же чистое и простое, как атрибут SoapExtension, если это возможно.

Ответы на вопрос(3)

Ваш ответ на вопрос