zoukankan      html  css  js  c++  java
  • Oxite分析之结构浅析

    change set:46759
    download:http://oxite.codeplex.com/SourceControl/ListDownloadableCommits.aspx

    约定:
    1、为了消除歧义,整个Oxite项目在这里统称为Oxite解决方案;而Oxite解决方案下有一个Oxite项目。
    2、Module称之为模块

    一、从模块的角度浅析Oxite解决方案结构

    Oxite解决方案从某种角度上可以看成是一系列模块(Module)的集合。
    OxiteSite项目是一个站点程序项目。Oxite解决方案是一个应用了ASP.NET MVC 模式的解决方案,而OxiteSite项目就相当于MVC中的View(而Model和Controller则分布于各个模块中,详见(二))。
    Oxite项目中提供了一些基础架构用于支持模块的热插拔,而且内置了一些模块(具体是哪些模块,这里不详解)。
    Modules解决方案目录下是一些扩展模块,如,Oxite.Blog,Oxite.CMS等等。

    图1从“模块的角度”大致表现Oxite解决方案的结构。

    (图1:Oxite解决方案结构图,箭头表示包含关系) 

     Oxite001

    上图将AspNetCache、Core等模块表现出来,是为了说明Oxite项目下的这些模块,与Modules解决方案目录下的各个项目模块处于相对平等的位置。区别在于AspNetCache、Core等模块比较核心,就将其“内置”于Oxite项目中而已。如果需要,可以将这些模块独立成类似于Oxite.Blogs等的项目。需要说明的是,这些核心的模块虽然内置实现了,Oxite也允许对这些模块进行替换的。

    二、从ASP.NET MVC的角度浅析Oxite解决方案结构

    Oxite最初设计成为学习ASP.NET MVC的项目,这也是我们进行分析和学习的一部分重要的原因。
    从Oxite解决方案的文件结构上看,我们很容易看出OxiteSite项目应该就是MVC的View部分。而Model和Controller部分呢?
    Oxite中,Model和Controller位于(或者说分散于)各个模块之中。
     
    图2从“MVC的角度”大致表现Oxite解决方案的结构。

    (图2:Oxite解决方案结构图,箭头表示依赖关系) 

    Oxite002

    Cntroller通过IService(以依赖注入的方式配置)获取Model数据;
    Model数据与LinqToSql的Model通过IRespository(以依赖注入的方式配置)进行存取转换。
    Controller对数据库和数据访问方式是没有任何依赖的,这就意味着实现不同的Repository就可以达到获取不同的数据访问方式或数据库。

    Controller和Model数据和分于不同的模块之中。具体的某一模块,如Core模块,Model对应的是Site实体;Controller对应SiteController(还有其他Controller这里就不说了);IService对应的是ISiteService,具体类为SiteService;IRepository对应的是ISiteRepository,具体类为SqlServerRepository。

    另外还有两点需要声明的是:
    1、结构图中所用标识、符号如有不恰当还望指正,因为我没怎么画过图,以上图是用Word画出的;
    2、Model在这里的理解是实体,并理解为ASP.NET MVC中的M。有关资料将这里的Model和Service(即业务逻辑层)合并理解为ASP.NET MVC的M,希望明白的朋友多指教。

  • 相关阅读:
    比较.NET程序集(DLL或EXE)是否相同
    [转] JavaScript数组去重(12种方法)
    [转] js网络请求跨域问题汇总(携带cookie)
    [转] JS中arr.forEach()如何跳出循环
    [转] vue前端异常监控sentry实践
    [转] vue父组件触发子组件事件
    [转] vue 自定义组件使用v-model
    [转] Nginx配置性能优化
    [转] linux 查找文本过滤grep正则表达式命令详解用法
    [转] Nginx配置中的location、root、alias
  • 原文地址:https://www.cnblogs.com/alby/p/oxite.html
Copyright © 2011-2022 走看看