网站建设 ipv6,宁波手机建站模板,哪里可以做外贸网站,陕西个人证书查询网1. 前言关于IoC模式#xff08;控制反转#xff09;和DI技术#xff08;依赖注入#xff09;#xff0c;我们已经见过很多的探讨#xff0c;这里就不再赘述了。比如说必看的Martin Fowler《IoC 容器和 Dependency Injection 模式》#xff0c;相关资料链接都附于文章末尾… 1. 前言关于IoC模式控制反转和DI技术依赖注入我们已经见过很多的探讨这里就不再赘述了。比如说必看的Martin Fowler《IoC 容器和 Dependency Injection 模式》相关资料链接都附于文章末尾。其中我非常赞同Artech的说法控制更多地体现为一种流程的控制而依赖注入技术让我们的应用程序实现了松散耦合。ASP.NET Core本身已经集成了一个轻量级的IOC容器开发者只需要定义好接口后在Startup.cs的ConfigureServices方法里使用对应生命周期的绑定方法即可常见方法如下services.AddTransientIApplicationService,ApplicationServiceservices.AddScopedIApplicationService,ApplicationServiceservices.AddSingletonIApplicationService,ApplicationService对于上述的三种DI注入方式官方也给出了详细的解释我来简单翻译一下TransientTransient 服务在每次请求时被创建它最好被用于轻量级无状态服务如我们的Repository和ApplicationService服务ScopedScoped 服务在每次请求时被创建生命周期横贯整次请求Singleton顾名思义Singleton单例 服务在第一次请求时被创建或者当我们在ConfigureServices中指定创建某一实例并运行方法其后的每次请求将沿用已创建服务。如果开发者的应用需要单例服务情景请设计成允许服务容器来对服务生命周期进行操作而不是手动实现单例设计模式然后由开发者在自定义类中进行操作。在这之后我们便可以将服务通过构造函数注入或者是属性注入的方式注入到ControllerView(通过使用inject)甚至是Filter中以前使用Unity将依赖注入到Filter真是一种痛苦。话不多说先来体验一把TipsStartup.cs是什么详见ASP.NET Core 介绍和项目解读2. ASP.NET Core 中的DI方式大多项目举例依赖注入的生命周期演示时都会采取可变Guid来作为返回显示此次示例也会这样处理。我们先定义一个IGuidAppService接口里面定义基接口和三种注入模式的接口 public interface IGuidAppService{ Guid GuidItem(); } public interface IGuidTransientAppService : IGuidAppService { } public interface IGuidScopedAppService : IGuidAppService { } public interface IGuidSingletonAppService : IGuidAppService { }同样的在GuidAppService中定义其实现类。这里为了直观显示每次请求的返回值采取如下代码 public class GuidAppServiceBase : IGuidAppService { private readonly Guid _item; public GuidAppServiceBase() { _item Guid.NewGuid(); } public Guid GuidItem() { return _item; } } public class GuidTransientAppService : GuidAppServiceBase, IGuidTransientAppService { } public class GuidScopedAppService : GuidAppServiceBase, IGuidScopedAppService { } public class GuidSingletonAppService : GuidAppServiceBase, IGuidSingletonAppService { }最后是Controller和View视图的代码 # Controller public class HomeController : Controller { private readonly IGuidTransientAppService _guidTransientAppService; //#构造函数注入 //private IGuidTransientAppService _guidTransientAppService { get; } #属性注入 private readonly IGuidScopedAppService _guidScopedAppService; private readonly IGuidSingletonAppService _guidSingletonAppService; public HomeController(IGuidTransientAppService guidTransientAppService, IGuidScopedAppService guidScopedAppService, IGuidSingletonAppService guidSingletonAppService) { _guidTransientAppService guidTransientAppService; _guidScopedAppService guidScopedAppService; _guidSingletonAppService guidSingletonAppService; } public IActionResult Index() { ViewBag.TransientItem _guidTransientAppService.GuidItem(); ViewBag.ScopedItem _guidScopedAppService.GuidItem(); ViewBag.SingletonItem _guidSingletonAppService.GuidItem(); return View(); } } # Index View div classrow div h2GuidItem Shows/h2 h3TransientItem: ViewBag.TransientItem/h3 h3ScopedItem: ViewBag.ScopedItem/h3 h3SingletonItem: ViewBag.SingletonItem/h3 /div /div之后我们打开两个浏览器分别刷新数次也只会发现“TransientItem”和“ScopedItem”的数值不断变化“SingletonItem”栏的数值是不会有任何变化的这就体现出单例模式的作用了示例图如下但是这好像还不够要知道我们的Scoped的解读是“生命周期横贯整次请求”但是现在演示起来和Transient好像没有什么区别因为两个页面每次浏览器请求仍然是独立的并不包含于一次中所以我们采用以下代码来演示下同一请求源# 新建GuidItemPartial.cshtml视图复制如下代码使用inject注入依赖
using DependencyInjection.IApplicationServiceinject IGuidTransientAppService TransientAppService
inject IGuidScopedAppService GuidScopedAppServic
inject IGuidSingletonAppService GuidSingletonAppServicediv classrow div h2GuidItem Shows/h2 h3TransientItem: TransientAppService.GuidItem()/h3 h3ScopedItem: GuidScopedAppServic.GuidItem()/h3 h3SingletonItem: GuidSingletonAppService.GuidItem()/h3 /div/div# 原先的index视图 { ViewData[Title] Home Page; } Html.Partial(GuidItemPartial) Html.Partial(GuidItemPartial)依然是 CtrlF5 调试运行可以发现“ScopedItem”在同一请求源中是不会发生变化的但是“TransientItem”依然不断变化理论仍然是支持的3. Autofac实现和自定义实现扩展方法除了ASP.NETCore自带的IOC容器外我们还可以使用其他成熟的DI框架如AutofacStructureMap等笔者只用过UnityNinject和CastleCastle也是使用ABP时自带的。3.1 安装Autofac首先在project.json的dependency节点中加入Autofac.Extensions.DependencyInjection引用目前最新版本是4.0.0-rc3-3093.2 创建容器并注册依赖在Startup.cs中创建一个public IContainer ApplicationContainer { get; private set; }对象并把ConfigureServices返回类型改为IServiceProvider然后复制以下代码进去也可以实现相关功能var builder new ContainerBuilder();//注意以下写法
builder.RegisterTypeGuidTransientAppService().AsIGuidTransientAppService();
builder.RegisterTypeGuidScopedAppService().AsIGuidScopedAppService().InstancePerLifetimeScope(); builder.RegisterTypeGuidSingletonAppService().AsIGuidSingletonAppService().SingleInstance(); builder.Populate(services); this.ApplicationContainer builder.Build();return new AutofacServiceProvider(this.ApplicationContainer);值得注意的几点:创建Autofac容器时不要忘了将ConfigureServices的返回值修改为IServiceProvider对应ASP.NET Core提及的不同的生命周期Autofac也定义了对应的扩展方法如InstancePerLifetimeScope等默认为Transient模式包括EntityFramwork等Context也是该种模式Autofac Core不支持从View中注入但是可以和ASP.NET Core自带IOC容器配合使用Autofac Core版本和传统的ASP.NET MVC项目版本的区别4. 参考链接IoC 容器和 Dependency Injection 模式控制反转—维基百科DependencyInjection-GitHubASP.NET Core中的依赖注入4: 构造函数的选择与服务生命周期管理Dependency Injectionf!原文地址http://www.cnblogs.com/wangpd/p/7568451.html.NET社区新闻深度好文微信中搜索dotNET跨平台或扫描二维码关注