Wie verwende ich Property Injection mit AutoFac?

In einer Konsolenanwendung verwende ich Log4Net und in der Main-Methode erhalte ich das Logger-Objekt. Jetzt möchte ich dieses Protokollobjekt in allen meinen Klassen verfügbar machen, indem ich alle Klassen von einer BaseClass erben lasse, die eine ILog-Eigenschaft hat und von Property Injection anstelle von Constructor Injection festgelegt werden soll.

Ich verwende einen AutoFac-IoC-Container. Wie füge ich mein Log-Objekt in die Log-Eigenschaft jeder Klasse ein?

Was ist der beste / einfachste Weg, um dies zu erreichen?

Gibt es eine Möglichkeit, Typen automatisch aufzulösen?

Unten ist meine Testanwendung:

namespace ConsoleApplication1
{
    class Program
    {
        static ILog Log;
        static IContainer Container;

        static void Main(string[] args)
        {                
           InitializeLogger();

           InitializeAutoFac();

            // the below works but could it be done automatically (without specifying the name of each class)?
           Product.Log = Container.Resolve<ILog>();

           // tried below but didn't inject ILog object into the Product
           Container.Resolve<Product>();

           RunTest();

            Console.ReadLine();
        }

        private static void RunTest()
        {
            var product = new Product();
            product.Do();
        }

        private static void InitializeAutoFac()
        {
            var builder = new ContainerBuilder();

            builder.Register(c => Log).As<ILog>();

            builder.RegisterType<Product>().PropertiesAutowired();

            Container = builder.Build();            
        }

        private static void InitializeLogger()
        {
            log4net.Config.XmlConfigurator.Configure();

            Log = LogManager.GetLogger("LoggerName");
        }
    }

    public class Product
    {
        public static ILog Log { get; set; }

        public void Do()
        {
            // this throws exception because Log is not set   
            Log.Debug("some Debug");  
        }
    }
}

Antworten auf die Frage(5)

Ihre Antwort auf die Frage