Autofac - 属性注入

属性注入不同于通过构造函数方式传入参数. 这里是通过注入的方式, 在类创建完毕之后, 资源释放之前, 给属性赋值.

这里, 我重新弄一些类来演示这一篇吧.

public class ClassA
{
    private readonly ClassB b;

    public ClassA(ClassB b)
    {
        this.b = b;
    }

    public void Show()
    {
        Console.WriteLine("I am ClassA‘s instance !");
    }
}

public class ClassB
{
    public ClassA A { get; set; }

    public void Show()
    {
        Console.WriteLine("I am ClassB‘s instance !");
    }

}

public class ClassC
{   public string Name { get; set; }
    public ClassD D { get; set; }

    public void Show()
    {
        Console.WriteLine("I am ClassC‘s instance !" + Name);
    }
}

public class ClassD
{
    public void Show()
    {
        Console.WriteLine("I am ClassD‘s instance !");
    }
}

1. 一般方法

var builder = new ContainerBuilder();

builder.Register(n => new ClassC { D = n.Resolve<ClassD>(), Name = "Sniper"  });
builder.RegisterType<ClassD>();

var container = builder.Build();

var c = container.Resolve<ClassC>();
c.Show();
c.D.Show();

这种方法, 不止可以注入属性, 还可以给字段赋值

2. 反射的方式

var builder = new ContainerBuilder();

builder.RegisterType<ClassD>();
var s = builder.RegisterType<ClassC>().PropertiesAutowired();

var container = builder.Build();

var c = container.Resolve<ClassC>();
c.Show();
c.D.Show();

这里需要注意一点, 由于ClassC中有ClassD格式的属性, 所以ClassD也必须要注册一下. 为什么呢? 来看一下源码

PropertiesAutowired()方法里面, 主要就是调用上图中的方法. 会通过反射的方式获取属性, 然后也是通过Resolve的方式来获取属性的值.

注:

  仔细观察ClassA和ClassB, 可以发现, 他们循环依赖了, 那么如果我要得到ClassB, 怎么办? 尝试下第一种方法, 你会发现, 我去, 报错了.

  尝试下第二种方法, 还是报错. 那怎么办呢?

var builder = new ContainerBuilder();

builder.RegisterType<ClassB>().PropertiesAutowired(PropertyWiringOptions.AllowCircularDependencies).SingleInstance();
builder.Register(n=>new ClassA(n.Resolve<ClassB>()));

var container = builder.Build();

var b = container.Resolve<ClassB>();
b.Show();
b.A.Show();

还是通过反射的方式, 只不过要注意一下, 传入参数和SingleInstance, 不加, 都会报错的.

3. 通过名称

var builder = new ContainerBuilder();

var s = builder.RegisterType<ClassC>().WithProperty("D", new ClassD());

var container = builder.Build();

var c = container.Resolve<ClassC>();
c.Show();
c.D.Show();

通过属性名称, 直接new一个实例给他

4. OnActivating/OnActivated 方式

此方法的执行时机, 是构造函数创建结束之后, 资源释放之前, 所以在此期间也可以实现

var builder = new ContainerBuilder();

builder.RegisterType<ClassC>().OnActivating(e => e.Instance.D = e.Context.Resolve<ClassD>());
builder.RegisterType<ClassD>();

var container = builder.Build();

var c = container.Resolve<ClassC>();
c.Show();
c.D.Show();

这里的 OnActivating 也可换成 OnActivated . 实现这里的场景, 是能得到一样的结果的.

参考:

   AutoFac使用方法总结

  Autofac 组件、服务、自动装配 《第二篇》

  Autofac文档

时间: 2024-12-19 21:59:36

Autofac - 属性注入的相关文章

MVC autofac 属性注入

Global文件 public class MvcApplication : System.Web.HttpApplication { private static IContainer Container { get; set; } protected void Application_Start() { AreaRegistration.RegisterAllAreas(); FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);

ASP.NET Core中使用Autofac进行属性注入

一些无关紧要的废话: 作为一名双修程序员(自封的),喜欢那种使用Spring的注解形式进行依赖注入或者Unity的特性形式进行依赖注入,当然,形式大同小异,但结果都是一样的,通过属性进行依赖注入. ASP.NET Core中使用了自带的Dependency Injection作为了默认的IOC容器,当然有先天的优势,很多还是喜欢切换到Autofac作为IOC容器,Unity在.Net Core中还是有很大的优势的,但据我所知,Unity5已经由微软转交到基金会了,而且本身文档很少,翻译文档以及研

Autofac 的属性注入,IOC的坑

Autofac 是一款优秀的IOC的开源工具,完美的适配.Net特性,但是有时候我们想通过属性注入的方式来获取我们注入的对象,对不起,有时候你还真是获取不到,这因为什么呢? 1.你对Autofac 不太了解,在这个浮躁的社会,没有人会认真的了解每个开源项目,只要求能用就行 2.没有时间了解,你是一个很忙的人,工作很忙,应酬很忙 3.刚开始使用Autofac 还没来得及深入了解就要做项目. 不管是什么原因,总之我们注入的属性就是无法直接由autofac 自动注入,或者说我们希望由Autofac自动

Autofac 的属性注入方式

介绍 该篇文章通过一个简单的 ASP.NET MVC 项目进行介绍如何使用 autofac 及 autofac 的 MVC 模块进行依赖注入.注入方式通过构造函数.在编写 aufofac 的依赖注入代码之前先准备一些基础类. 基础类 public class UserInfo { public int Id { get; set; } public string Name { get; set; } } public interface IRepository<T> { void Add( T

ASP.NET Core中使用IOC三部曲(二.采用Autofac来替换IOC容器,并实现属性注入)

前言 本文主要是详解一下在ASP.NET Core中,自带的IOC容器相关的使用方式和注入类型的生命周期. 这里就不详细的赘述IOC是什么 以及DI是什么了.. emm..不懂的可以自行百度. 目录 ASP.NET Core中使用IOC三部曲(一.使用ASP.NET Core自带的IOC容器) ASP.NET Core中使用IOC三部曲(二.采用Autofac来替换IOC容器,并实现属性注入) ASP.NET Core中使用IOC三部曲(三.采用替换后的Autofac来实现AOP拦截) 正文 上

ASP.NETCore 3.0 Autofac替换及控制器属性注入及全局容器使用

1.Autofac基础使用 参考: https://www.cnblogs.com/li150dan/p/10071079.html 2.ASP.NETCore 3.0 Autofac 容器替换 需要引用:Autofac, Autofac.Extensions.DependencyInjection 在Program.cs 使用AutofacServiceProviderFactory进行容器替换. public static IHostBuilder CreateHostBuilder(str

Autofac 依赖注入 ASP.NET MVC5 插件机制中插件的简单实现

一.前言 由于项目业务复杂,创建了多个插件并把他们放在了不同的项目中,项目使用AutoFac做的IOC:但是主项目可以注入,插件注入失败, 没有为该对象定义无参数的构造函数.下面就一步一步注入插件项目. 二.新建带有插件的项目 参考: ASP.NET MVC5 插件化机制简单实现 项目结构如下图: 三.建立DomainServices类库 新建一个ITestService接口,代码如下: namespace DomainServices { public interface ITestServi

ASP.NET MVC Autofac依赖注入的一点小心得(包含特性注入)

前言 IOC的重要性 大家都清楚..便利也都知道..新的ASP.NET Core也大量使用了这种手法.. 一直憋着没写ASP.NET Core的文章..还是怕误导大家.. 今天这篇也不是讲Core的 前面写了C#开发移动应用系列  就第一篇和最后一篇上了最多推荐 - -  也许大家确实不看好吧.. 算了..废话不多说.开始今天的东西吧.. 本篇文章不讲为何我们要用IOC..只讲Autofac使用中的一些小心得 正文 1.基本注入 首先我们要构造一个容器,代码如下: //第一步: 构造一个Auto

在netcore中实现字段和属性注入

简单来说,使用Ioc模式需要两个步骤,第一是把服务注册到容器中,第二是从容器中获取服务,我们一个一个讨论并演化.这里不会考虑使用如Autofac等第三方的容器来代替默认容器,只是提供一些简单实用的小方法用于简化应用层的开发. 将服务注入到容器 asp.netcore官方给出的在容器中注册服务方法是,要在Startup类的ConfigureServices方法中添加服务,如下所示: public void ConfigureServices(IServiceCollection services)