コンソールアプリケーションでは、Log4Netを使用しています。メインメソッドでは、ロガーオブジェクトを取得しています。さて、私はすべてのクラスがILogプロパティを持ち、コンストラクタインジェクションではなくプロパティインジェクションによって設定されるはずのBaseClassから継承するようにして、このログオブジェクトをすべてのクラスで利用できるようにしたいと思います。AutoFacでProperty Injectionを使用するには?
私はすべてのクラスのログプロパティに自分のログオブジェクトを挿入するには、AutoFac IoCコンテナを使用していますか?
これを達成する最も簡単な方法は何ですか?
タイプを自動的に解決する方法はありますか?
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");
}
}
}
をあなたはまた、あなたのクラスのそれぞれにロガーの静的インスタンスを作成することができます。こうすることで、各ロガーにはクラスが定義されたクラスの名前が自動的に付けられます。 – alex
'Product'のIlogから' static'を削除します –
私もインスタンスであることを試みましたが助けませんでした。 –