У меня есть проект, использующий NLog. Это отлично работает для записи в локальный файл, но когда я пытаюсь настроить таргетинг сообщений журнала на WebServer, ничего не происходит.
Соответствующая часть nlog.config:
<targets>
<target xsi:type="WebService" name="ws" url="http://localhost:8088/api" protocol="HttpPost" encoding="UTF-8" >
<parameter name="Message" type="System.String" layout="${message}" />
</target>
</targets>
<rules>
<logger name="QS.WebLogger" minLevel="Info" writeTo="ws" final="true" />
</rules>
А затем в моем коде:
var loggerFactory = new LoggerFactory().AddNLog();
loggerFactory.ConfigureNLog("nlog.config");
var log = loggerFactory.CreateLogger<QS.WebLogger>();;
log.LogError("error message");
Я пробовал несколько способов вызвать LogError, но независимо от того, что я пытаюсь, он переходит в LogError без выдачи ошибки, но я никогда не вижу никаких попыток вызвать веб-службу в Fiddler. NLog, похоже, понимает, что он должен регистрироваться в веб-службе, поскольку он учитывает final = "true" и не будет регистрировать эти сообщения для других целей в дальнейшем.
Во внутреннем журнале NLog появляется следующее сообщение: Warn Type load exception. Исключение: System.TypeLoadException: не удалось загрузить тип «System.Web.IHttpModule» из сборки «System.Web, версия = 4.0.0.0, культура = нейтральный, PublicKeyToken = b03f5f7f11d50a3a». Я считаю, что это связано с тем, что проект представляет собой .NET Core, но можно было бы ожидать, что все будет по-прежнему работать (в противном случае это была бы ошибка, а не предупреждение).
В примерах, которые я могу найти, используется EventLogInfo NLog, который я не могу использовать, потому что NLog находится за Microsoft ILogger, который не знает, что такое EventLogInfo.
Как мне заставить его отправлять сообщение вместо того, чтобы молча проглатывать сообщение журнала?