janvier
2009
Suite au très bon article de lutecefalco sur log4net (pour ceux qui ne l’ont pas encore lu, allez voir ici : http://lutecefalco.developpez.com/tutoriels/dotnet/log4net/introduction/), j’ai décidé de virer NLog, que j’utilisais sur Sharepoint depuis quelque mois, et de me remettre a utiliser Log4Net dans Sharepoint.
Apres un peu de tâtonnements, la méthode de base est la suivante:
1- ajouter la dll log4net dans le répertoire _app_bin de sharepoint
2- Mettre a jour le fichier web.config de Sharepoint, en ajoutant les infos suivantes :
<configSections>
…
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
…
</configSections>
<log4net configSource="log4net.config"/>
Dans cet exemple, la configuration de log4net est deferee dans un fichier de config secondaire (les Web.Config de sharepoint sont assez longs comme ça )
3- Modifier le global.asax de la façon suivante:
<%@ Assembly Name="Microsoft.SharePoint"%>
<%@ Application Language="C#" Inherits="Microsoft.SharePoint.ApplicationRuntime.SPHttpApplication" %>
<%@ Assembly Name="log4net, version=1.2.10.0, Culture=neutral, PublicKeyToken=1b44e1d426115821" %>
<%@ Import Namespace="log4net.Config" %>
<script runat="server">
void Application_Start(Object sender, EventArgs e){
// Configure log4Net, to take its configuration from the web.config
file.XmlConfigurator.Configure();
}
</script>
Et voila, un joli log4net tout propre…
Pour faire encore mieux, on peut faire une petite bibliothèque de log « maison », qui va appeler log4net, de façon a garder une certaine indépendance par rapport au framework de log utilise.
Pour cela, on va créer une simple classe LogFactory, qu’on va stocker dans un projet Utils (par exemple), qui va nous donner:
namespace Utils {
using System;
using System.Collections.Generic;
using System.Text;
using log4net;public static class LogFactory {
private static readonly ILog logger = LogManager.GetLogger(typeof(LogFactory));public static void ConfigureLogger(){
log4net.Config.XmlConfigurator.Configure();
}
public static void LogDebug(string message) {
if (logger.IsDebugEnabled) {
logger.Debug(message);
}
}
/// On passe sur les autres surcharges…
}
}
On va ensuite stocker cette classe de log dans le GAC, l’ajouter aux assemblys déclarées dans le web.config de sharepoint
<add assembly="Utils, Version=1.0.0.0, Culture=neutral, PublicKeyToken=6653be5adb0ecc4d" />
Et notre global.asax ressemblera désormais a ça :
<%@ Assembly Name="Microsoft.SharePoint"%>
<%@ Application Language="C#" Inherits="Microsoft.SharePoint.ApplicationRuntime.SPHttpApplication" %>
<%@ Import Namespace="Utils" %><script runat="server">
void Application_Start(Object sender, EventArgs e){
// Configure log4Net, to take its configuration from the web.config
LogFactory.ConfigureLogger();
}</script>
Voila, vous, je ne sais pas, mais moi, ça me plaît bien
Articles récents
Archives
- janvier 2014
- septembre 2013
- août 2013
- mai 2013
- avril 2013
- janvier 2013
- août 2012
- juin 2012
- mai 2012
- avril 2012
- mars 2012
- novembre 2011
- septembre 2011
- août 2011
- juillet 2011
- juin 2011
- mai 2011
- avril 2011
- février 2011
- janvier 2011
- novembre 2010
- octobre 2010
- septembre 2010
- août 2010
- juillet 2010
- juin 2010
- mai 2010
- avril 2010
- mars 2010
- février 2010
- janvier 2010
- décembre 2009
- novembre 2009
- octobre 2009
- septembre 2009
- août 2009
- juillet 2009
- juin 2009
- mai 2009
- avril 2009
- mars 2009
- février 2009
- janvier 2009