Autofac在MVC4中牛刀小试
Autofac是传说中速度最快的一套.NET高效的依赖注入框架。Autofac的介绍与使用请去参考Autofac全面解析系列(版本:3.5)。 这里介绍的已经挺详细的啦。
下面我就先来说说MVC4中使用Autofac吧,至于工厂模式与依赖注入的区别的话,这个我简单的解释一下,也只是我的个人观点。使用依赖注入最主要的就是为了解耦,当然工厂模式也可以实现实现大部分的解耦,这个是毋庸置疑的。工厂模式实现方式是向客户端提供一个接口,使客户端不要指定具体产品对象,创建多个产品族的产品对象。将具体实例的创建延迟到对应实现的子类中。但是当我们每次要去拿这个接口的时候就要通过这个工厂来拿了,那么就是说虽然我们排除了对实现接口的具体的方法的依赖,但是我们对工厂模式产生接口的方式产生了依赖。那么依赖注入就可以解决这个依赖了。我们在使用接口的时候可以完全的不需要考虑去取这个接口然后再继续使用接口。我们只要直接拿接口来用就可以了。这就是我个人对工厂模式和依赖注入的解释了,是不是把你们给搞混淆了。
下面我就在MVC4中使用下Autofac吧。首先我们要先去NuGet下载一个Autofac MVC4的东西
点击安装。
将AuthoryManage.AutofacRegister 也引入Autofac包
导入成功之后,我先在AuthoryManage.InterfaceRepository这个类库中添加一个接口,

using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace AuthoryManage.InterfaceRepository { public interface IBaseRepository { string GetData(); } }
然后在AuthoryManage.Repository中分别加入下面这些类
下面是代码:

public class BaseRepository :IBaseRepository{ public string GetData() { return "这里是MsSql"; } }

public class BaseRepository : IBaseRepository { public string GetData() { return "这里是MySql"; } }

public class BaseRepository : IBaseRepository { public string GetData() { return "这里是Oracle"; } }
记得添加对AuthoryManage.InterfaceRepository的引用。
接下来写下Service层的代码
public interface IBaseService { string GetData(); }

public interface IBaseService { string GetData(); }
最值得注意的Service实现类代码,请看:

public class BaseService:IBaseService { private readonly IBaseRepository _repository; public BaseService(IBaseRepository repository) { this._repository = repository; } public string GetData() { return _repository.GetData(); } }
这是建好之后的Service层结构
也要记得引用对应DLL,那么接下来就看看控制器这边怎么写吧。
我就简单先建立一个Home控制器吧。并添加对service的引用。

public class HomeController : Controller { // // GET: /Home/ private IBaseService _service; public HomeController(IBaseService service) { this._service = service; } public ActionResult Index() { ViewBag.SSSS = _service.GetData(); return View(); } }
视图代码如下:

@{ ViewBag.Title = "Index"; } <h2>@ViewBag.SSSS</h2>
接下来就去Global中实现我们的注入:

using Autofac; using System; using System.Collections.Generic; using System.Linq; using System.Reflection; using Autofac.Integration.Mvc; using System.Web; using System.Web.Http; using System.Web.Mvc; using System.Web.Optimization; using System.Web.Routing; namespace AuthoryManage.Web { // 注意: 有关启用 IIS6 或 IIS7 经典模式的说明, // 请访问 http://go.microsoft.com/?LinkId=9394801 public class MvcApplication : System.Web.HttpApplication { protected void Application_Start() { AreaRegistration.RegisterAllAreas(); WebApiConfig.Register(GlobalConfiguration.Configuration); FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); RouteConfig.RegisterRoutes(RouteTable.Routes); BundleConfig.RegisterBundles(BundleTable.Bundles); var builder = new ContainerBuilder(); var assembly = Assembly.GetExecutingAssembly(); var repository = System.Reflection.Assembly.Load("AuthoryManage.MsSqlRepository"); builder.RegisterAssemblyTypes(repository, repository) .AsImplementedInterfaces(); var service = System.Reflection.Assembly.Load("AuthoryManage.Service"); builder.RegisterAssemblyTypes(service, service) .AsImplementedInterfaces(); builder.RegisterControllers(typeof(MvcApplication).Assembly); //容器 var container = builder.Build(); //注入改为Autofac注入 DependencyResolver.SetResolver(new AutofacDependencyResolver(container)); } } }
要记住,在反射程序集的时候你要引用相对应的程序集。然后我们在运行一下程序来看下界面效果:
我们把global.asax里面的代码更改下,改成对Oracle的程序集注册,

using Autofac; using System; using System.Collections.Generic; using System.Linq; using System.Reflection; using Autofac.Integration.Mvc; using System.Web; using System.Web.Http; using System.Web.Mvc; using System.Web.Optimization; using System.Web.Routing; namespace AuthoryManage.Web { // 注意: 有关启用 IIS6 或 IIS7 经典模式的说明, // 请访问 http://go.microsoft.com/?LinkId=9394801 public class MvcApplication : System.Web.HttpApplication { protected void Application_Start() { AreaRegistration.RegisterAllAreas(); WebApiConfig.Register(GlobalConfiguration.Configuration); FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); RouteConfig.RegisterRoutes(RouteTable.Routes); BundleConfig.RegisterBundles(BundleTable.Bundles); var builder = new ContainerBuilder(); var assembly = Assembly.GetExecutingAssembly(); var repository = System.Reflection.Assembly.Load("AuthoryManage.OracleRepository"); builder.RegisterAssemblyTypes(repository, repository) .AsImplementedInterfaces(); var service = System.Reflection.Assembly.Load("AuthoryManage.Service"); builder.RegisterAssemblyTypes(service, service) .AsImplementedInterfaces(); builder.RegisterControllers(typeof(MvcApplication).Assembly); //容器 var container = builder.Build(); //注入改为Autofac注入 DependencyResolver.SetResolver(new AutofacDependencyResolver(container)); } } }
看下运行效果:
需要注意的是我们需要引用下AuthoryManage.OracleRepository这个dll引用,那么就是说我实现的方法更改了 我UI层也要去改动对应的引用。
作者:yjq
欢迎任何形式的转载,但请务必注明出处。
.netcore相关功能需要定制的可以找我。有丰富的并发处理,性能优化经验。单点登录,限流,熔断,读写分离等功能均可定制。也可以帮忙系统优化处理,系统诊断,请联系博主(备注添加原因)。微信:yjq425527169 QQ:425527169
本篇文章如有些许帮助请点击推荐让更多需要帮助的人可以看到,请支持原创,请大方打赏(右边点击打赏)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?