大家看到上面的代码了,Application_Start大家都知道这是应用程序启动入口。
AreaRegistration.RegisterAllAreas是什么呢?
我们先看看微软官方的注解:
我们明白这个含义了,接下来需要完全了解这个含义,我们看看下面代码
public class FlowManageAreaRegistration : AreaRegistration { public override string AreaName { get { return "FlowManage"; } } public override void RegisterArea(AreaRegistrationContext context) { context.MapRoute( "FlowManage_default", "FlowManage/{controller}/{action}/{id}", new { action = "Index", id = UrlParameter.Optional } ); } }
是不是感觉像路由表呀,它继承了AreaRegistration 类,重写了RegisterArea注册区域的方法,重写了区域的名称AreaName;
MapRoute我就不说了,这就是表映射。我们看看它的具体实现
看红色标注部分,该控制器位于FlowManager之下,因此路由表才有了"FlowManage/{controller}/{action}/{id}"这样的配置,这样配置区域的控制器就完成了。
接下来,我们看看FilterConfig.RegisterGlobalFilters,这个就是配置了过滤器,或者说FilterConfig被应用程序调用了。其他2个就不说了。
ModelBinders.Binders.Add(typeof(JObject), new JobjectModelBinder());这个是什么呢,
先说说JobjectModelBinder,然后我们看看下面的方法,首先该类继承了IModelBinder,IModelBinder是一个接口,
该接口中定义了BindModel方法,那么下面的方法来源就有了,它是为了实现这个接口的方法的。我们看看这个方法的参数
controllerContext和bindingContext 2个对象一个是控制器上下文,一个是数据模型绑定上下文,我们可以从controllerContext对象中获取到请求信息,
下面方法里面做的事件是什么呢,当然就是绑定了。把请求信息绑定到JObject,JObject顾名思义就是JSONObject,
public class JobjectModelBinder :IModelBinder { public object BindModel(ControllerContext controllerContext, ModelBindingContext bindingContext) { //todo:需要判断前端是否是FormData var obj = new JObject(); var request = controllerContext.HttpContext.Request; foreach (var key in request.Form.AllKeys) { obj[key] = request.Form[key]; } return obj; } }
说了这么多,现在我们知道,我们定义了一个类,实现了接口,绑定了请求到JObject对象,目前网上没有调用的描述,我这里稍微提一下:
JobjectModelBinder通过这个对象,调用方法后返回JObject对象
看你怎么用了。
现在我们看看这个:
再看看里面写了什么
public static class AutofacExt { private static IContainer _container; public static void InitAutofac() { var builder = new ContainerBuilder(); //注册数据库基础操作和工作单元 builder.RegisterGeneric(typeof(BaseRepository<>)).As(typeof(IRepository<>)); builder.RegisterType(typeof (UnitWork)).As(typeof (IUnitWork)); //注册WebConfig中的配置 builder.RegisterModule(new ConfigurationSettingsReader("autofac")); //注册app层 builder.RegisterAssemblyTypes(Assembly.GetAssembly(typeof (UserManagerApp))); //注册领域服务 builder.RegisterAssemblyTypes(Assembly.GetAssembly(typeof(AuthoriseService))) .Where(u =>u.Namespace== "OpenAuth.Domain.Service"); // Register your MVC controllers. builder.RegisterControllers(typeof(MvcApplication).Assembly); // OPTIONAL: Register model binders that require DI. builder.RegisterModelBinders(Assembly.GetExecutingAssembly()); builder.RegisterModelBinderProvider(); // OPTIONAL: Register web abstractions like HttpContextBase. builder.RegisterModule<AutofacWebTypesModule>(); // OPTIONAL: Enable property injection in view pages. builder.RegisterSource(new ViewRegistrationSource()); // OPTIONAL: Enable property injection into action filters. builder.RegisterFilterProvider(); // Set the dependency resolver to be Autofac. _container = builder.Build(); DependencyResolver.SetResolver(new AutofacDependencyResolver(_container)); } /// <summary> /// 从容器中获取对象 /// </summary> /// <typeparam name="T"></typeparam> public static T GetFromFac<T>() { return _container.Resolve<T>(); // return (T)DependencyResolver.Current.GetService(typeof(T)); } }
这个里面的我自己还没看懂,看懂再补充
上面的内容经过MSDN论坛以及博客园各位指点终于找到说明的含义了
AutofacExt使用了ioc容器AutoFac解耦。有关AutoFac可以查看AutoFac详细介绍