У меня есть SoapExtension, которое предназначено для регистрации всех запросов и ответов SOAP. Он отлично подходит для вызовов из приложения с помощью MS Soap Toolkit (OnBase Workflow). Но это не работает для вызовов, сделанных $.ajax() на странице html. Вот пример:
$.ajax({
    type: "POST",
    url: url,
    data: data,
    contentType: "application/json; charset=utf-8",
    dataType: "json"
});
Это вызов ASP.NET 3.5 WebService с атрибутами WebService и ScriptService:
[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());
    }
}
И вот основы для SoapExtension и SoapExtensionAttribute:
public class LoggingSoapExtension : SoapExtension, IDisposable { /*...*/ }
[AttributeUsage(AttributeTargets.Method)]
public sealed class SoapLogAttribute : SoapExtensionAttribute { /*...*/ }
Мне не хватает чего-то, что позволит LoggingSoapExtension выполнять запросы $.ajax()?
Обновление
@Крис Брандсма
Возможно, это потому, что вы запрашиваете результаты Json вместо XML через ваш веб-сервис (dataType: "json" ). Поэтому атрибут ScriptService активируется, но вы не отправляете сообщения SOAP.
Это объясняет, почему SoapExtension не работает. Любые предложения для отслеживания с помощью ScriptService? Единственное, что приходит на ум - это базовый класс ScriptService, который предоставляет метод для регистрации запроса. Но тогда мне придется вызвать этот метод в каждом WebMethod в каждом ScriptService WebService (у меня их довольно много). Я бы хотел использовать что-то чистое и простое как атрибут SoapExtension, если это возможно.
