Я пытаюсь использовать log4net с ASP.NET MVC, и я не могу ничего с ним поделать. Я создал конфигурацию, которая находится в моем корневом веб-проекте:
<log4net>
<root>
<level value="INFO" />
<appender-ref ref="RollingLogFileAppender"/>
</root>
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="C:\DWSApplicationFiles\AppLogs\app.log" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="100KB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%d [%t]%-5p %c [%x] - %m%n" />
</layout>
</appender>
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="C:\DWSApplicationFiles\AppLogs\app.log" />
<appendToFile value="false" />
<datePattern value="-dddd" />
<rollingStyle value="Date" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%d [%t]%-5p %c [%x] - %m%n" />
</layout>
</appender>
</log4net>
Прежде, чем меня спросят: да, приложение имеет разрешение на запись в каталог. Я протестировал это, и приложение имеет разрешение на этот каталог.
Вот где я пытаюсь использовать log4net:
public class HomeController : Controller
{
readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
public ActionResult Index()
{
log.Error("In Index ");
return View();
}
}
Когда я запускаю приложение и перехожу к этому контроллеру, log4net ничего не делает; он не создает файлы в этом каталоге или что-то еще.
Я включил внутреннюю отладку для log4net, и я не получаю ошибок вывода в консоли. Все, что я вижу из log4net:
log4net: сборка log4net [log4net, Version = 1.2.10.0, Culture = нейтраль, PublicKeyToken = 1b44e1d426115821]. Загружен из [C:\Users\twaldron.BULLFROGSPAS\AppData\Local\Temp\Temporary ASP.NET Files\root\7642c99a\60feb7f2\assembly\dl3\17247033\008dfd6d_e2d0ca01\log4net.DLL]. (.NET Runtime [2.0.50727.4952] в Microsoft Windows NT 6.1.7600.0)
log4net: DefaultRepositorySelector: defaultRepositoryType [log4net.Repository.Hierarchy.Hierarchy]
log4net: DefaultRepositorySelector: создание репозитория для сборки [Bullfrog.DWS.Web, Version = 1.0.0.0, Culture = neutral, PublicKeyToken = null]
log4net: DefaultRepositorySelector: Assembly [Bullfrog.DWS.Web, Version = 1.0.0.0, Culture = neutral, PublicKeyToken = null] Загружен из [C:\Users\twaldron.BULLFROGSPAS\AppData\Local\Temp\Temporary ASP.NET Files\root\7642c99a\60feb7f2\assembly\dl3\2960c79f\b876bb2d_aca7cb01\Bullfrog.DWS.Web.DLL]
log4net: DefaultRepositorySelector: Assembly [Bullfrog.DWS.Web, Version = 1.0.0.0, Culture = neutral, PublicKeyToken = null] не указан указанный репозиторий.
log4net: DefaultRepositorySelector: Assembly [Bullfrog.DWS.Web, Version = 1.0.0.0, Culture = neutral, PublicKeyToken = null] с использованием репозитория [log4net-default-repository] и типа репозитория [log4net.Repository.Hierarchy.Hierarchy]
log4net: DefaultRepositorySelector: создание репозитория [log4net-default-repository] с использованием типа [log4net.Repository.Hierarchy.Hierarchy] 'WebDev.WebServer20.EXE' (Managed (v2.0.50727)): Загружена "Анонимно размещенная структура динамических методов"