zoukankan      html  css  js  c++  java
  • MVC之Global.asax解析

    大家看到上面的代码了,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详细介绍
    
    

     

  • 相关阅读:
    正点原子的串口助手XCOM V2.0编码问题
    切图设计工具软件或平台
    Notepad++插件
    emWin调用GUI_PNG_Draw方法显示PNG图片
    C语言-结构体冒号(:)位域
    Keil报错:error: #130: expected a "{"
    Doxygen简明注释语法
    Ubuntu连接不上Xshell
    Springboot注解的作用
    idea常用快捷键
  • 原文地址:https://www.cnblogs.com/licin/p/6543735.html
Copyright © 2011-2022 走看看