zoukankan      html  css  js  c++  java
  • .NET轻量级MVC框架:Nancy入门教程(二)——Nancy和MVC的简单对比

      在上一篇的.NET轻量级MVC框架:Nancy入门教程(一)——初识Nancy中,简单介绍了Nancy,并写了一个Hello,world。看到大家的评论,都在问Nancy的优势在哪里?和微软的MVC比有什么不同,哪个更好?Nancy是否可以脱离IIS等等,那么今天就拿MVC和Nancy做个简单的对比吧!首先说一点,我对MVC研究并不深入,如有没说到或说错的地方,还请大家补充和纠正。

    下面纠正一个问题,Nancy官网并没有明确的说Nancy是一个MVC框架,官方的定义是:Nancy是一个用于构建基于HTTP 的Web服务的框架。我题目中所写的轻量级MVC框架有些不妥之处,但是可以让大家快速的对Nancy有个大致的了解。不过,说实话,Nancy和asp.net在一起,实在是太像MVC了。

    今天主要讲理论的东西,不写代码,文章中所提到的配置,只是为了帮助理解,详细配置和操作内容还请参考官方帮助文档。

     一、Hosting Of Nancy

     1、Hosting Nancy with asp.net

    方案一:整站都使用Nancy

      在ASP.NET中,Nancy通过设置web.config,使用HTTP handler来处理请求。如果你在Visual Studio中使用了Nancy的模板来创建,就会自动生成webconfig配置,否则就要添加如下配置到webconfig中:

    <system.web>
      <compilation debug="true" targetFramework="4.0" />
      <httpHandlers>
        <add verb="*" type="Nancy.Hosting.Aspnet.NancyHttpRequestHandler" path="*"/>
      </httpHandlers>
    </system.web>
    
    <system.webServer>
      <modules runAllManagedModulesForAllRequests="true"/>
      <validation validateIntegratedModeConfiguration="false"/>
      <handlers>
        <add name="Nancy" verb="*" type="Nancy.Hosting.Aspnet.NancyHttpRequestHandler" path="*"/>
      </handlers>
    </system.webServer>

    并且还要确定你添加了Nancy和Nancy.Hosting.Aspnet 两个dll的引用。

    方案二:网站中一部分使用Nancy

    除了使用Nancy搭建整个网站,我们还可以在已存在的网站中使用Nancy来处理某些特定路径的请求。例如我们要处理nancypath下面的所有请求,我们只需要修改上面的配置NancyHttpRequestHandler的path为path="nancypath/*",并且你也要在项目中添加指定路径的文件夹,并在文件夹内放入如下Web.config:

    <?xml version="1.0"?>
    <configuration>
      <system.web>
        <httpHandlers>
          <add verb="*" type="Nancy.Hosting.Aspnet.NancyHttpRequestHandler" path="*"/>
        </httpHandlers>
      </system.web>
    </configuration>

    除此之外,再修改webconfig中的<location>节点配置。

    方案三:在MVC中使用Nancy

    是的,你没有看错,Nancy和MVC一起使用,如果要在MVC中使用Nancy,需要修改Global.asax.cs文件,添加如下内容:

    routes.IgnoreRoute("nancy/{*pathInfo}");

    这个时候,所有访问nancy目录的请求,就都会被Nancy处理了,接下来,我们就可以这样写代码了,例如:

    public class Home : NancyModule
    {
       public Home()
       {
          Get["/nancy/products"] = x => "The products!";
       }
    }

     这部分详细内容参考:https://github.com/NancyFx/Nancy/wiki/Hosting-Nancy-with-asp.net

    2.Hosting Nancy with wcf

      如果你想搭建一个轻量级的HTTP服务而又不想使用IIS,Nancy是一个很好的选择,你可以按照下面的操作来实现:

    首先,安装Nancy.Hosting.Wcf,Nugget代码如下:

    PM> Install-Package Nancy.Hosting.Wcf

    然后,编写代码,如下:

    var host = new WebServiceHost(new NancyWcfGenericService(),
                                  new Uri("http://localhost:1234/base/"));
    host.AddServiceEndpoint(typeof (NancyWcfGenericService), new WebHttpBinding(), "");
    host.Open();
    
    // Nancy will now handle requests to http://localhost:1234/base/

     然后,Nancy就会侦听本地的1234端口,处理HTTP请求。

     这部分详细内容参考:https://github.com/NancyFx/Nancy/wiki/Hosting-Nancy-with-wcf

    除此之外,Nancy还有以下Host方式:

    Hosting-nancy-with-azure              参考:https://github.com/NancyFx/Nancy/wiki/Hosting-nancy-with-azure

    Hosting-nancy-with-owin               参考:https://github.com/NancyFx/Nancy/wiki/Hosting-nancy-with-owin

    Hosting-Nancy-with-Umbraco        参考:https://github.com/NancyFx/Nancy/wiki/Hosting-Nancy-with-Umbraco

    Hosting-Nancy-with-Nginx-on-Ubuntu     参考:https://github.com/NancyFx/Nancy/wiki/Hosting-Nancy-with-Nginx-on-Ubuntu

    Hosting-Nancy-with-FastCgi         参考:https://github.com/NancyFx/Nancy/wiki/Hosting-Nancy-with-FastCgi

    Self-Hosting-Nancy              参考:https://github.com/NancyFx/Nancy/wiki/Self-Hosting-Nancy

     二、MVC和Nancy中的路由对比

     1、Nancy中的路由机制

    在上一篇的博文中,我们都知道Nancy中的所有路由都定义在module中的构造方法中,我们上次定义了一个无参路由,如下:

    public class HelloModule : NancyModule
    {
        public HelloModule()
        {
            Get["/"] = parameters => "Hello World";
        }
    }

    Nancy中有参路由可以这样定义:

    public class ProductsModule : NancyModule
    {
        public ProductsModule()
        {
            Get["/products/{id}"] = _ =>
            {
                //do something
            };
        }
    }

    或者定义成异步的,如下:

    public class ProductsModule : NancyModule
    {
        public ProductsModule()
        {
            Get["/products/{id}", runAsync: true] = async (_, token) =>
            {
                //do something long and tedious
            };
        }
    }

    Nancy中支持的method有:DELETEGETHEADOPTIONSPOSTPUT and PATCH

    当然,Nancy中还支持路由参数约束,例如我们要求参数必须为int类型,我们可以这样定义:

    Get["/intConstraint/{value:int}"] = _ => "Value " + _.value + " is an integer.";

    除了int类型,Nancy还支持以下类型的约束:

    感觉还不够?Nancy还提供了自定义参数约束,比如我们要求参数是一个email,我们可以先定义如下类:

    public class EmailRouteSegmentConstraint : RouteSegmentConstraintBase<string>
    {
        public override string Name
        {
            get { return "email"; }
        }
    
        protected override bool TryMatch(string constraint, string segment, out string matchedValue)
        {
            if (segment.Contains("@"))
            {
                matchedValue = segment;
                return true;
            }
    
            matchedValue = null;
            return false;
        }
    }

    然后,定义路由如下:

    Get["/profile/{value:email}"] = _ => "Value " + _.value + " is an e-mail address.";

    下面是Nancy中路由常用的几种写法:

     当然,Nancy的路由机制非常强大、非常灵活,那么当一个地址可以匹配多个路由时,Nancy会选择哪一个呢?其实,Nancy中有一套路由的权重机制来解决路由冲突,这个到后面说路由的时候会详细说的。

    2、MVC中的路由机制

    我们都知道MVC中的路由配置都在 Global.asax.cs中,当一个ASP.NET MVC应用程序第一次运行时, Application_Start()方法被调用。这个方法,又调用RegisterRoutes()方法,RegisterRoutes()方法创建了路由表。

    MVC中的默认路由如下:

    public static void RegisterRoutes(RouteCollection routes) 
    { 
        routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); 
     
        routes.MapRoute( 
            "Default", // 路由名称 
            "{controller}/{action}/{id}", // 带有参数的 URL 
            new { controller = "Home", action = "Index", id = UrlParameter.Optional } // 参数默认值 (UrlParameter.Optional-可选的意思)
        ); 
      }

    NVC中无参路由定义如下:

    routes.MapRoute
    (
        "Home", 
        "{controller}/{action}/{id}"
    );

    MVC中带命名空间的路由定义如下:

     routes.MapRoute(
          "AdminControllers", // 路由名称
          "{controller}/{id}-{action}", // 带有参数的 URL
          new { controller = "Home", action = "Index", id = UrlParameter.Optional }, // 参数默认值
          new string[] { "Admin.Controllers" }//命名空间
      );

    MVC中带约束的路由定义如下:

    routes.MapRoute(
        "RuleControllers",
        "{controller}/{action}-{Year}-{Month}-{Day}}",
        new { controller = "Home", action = "Index", Year = "2014", Month = "12", Day = "08" },
        new { Year = @"^d{4}", Month = @"d{2}" } //4位数 2位数
    );

    MVC全局路由:

      routes.MapRoute(
            "All", // 路由名称
            "{*Vauler}", // 带有参数的 URL
            new { controller = "Home", action = "Index", id = UrlParameter.Optional } // 参数默认值
        );

    综上所述,MVC和Nancy的路由机制从功能上来说不相上下,MVC有的Nancy也有。不过,相比之下,Nancy中的路由更加简单、灵活,毕竟MVC中的路由对于新手来说不是那么容易掌握的。

     三、MVC和Nancy中的视图的对比

       当然,视图这块大家还是比较关注的。下面简单对比MVC和Nancy所支持的视图:

                                           MVC                                                                             Nancy                                             
                                               WebForm                                                                   支持                               支持
                                               Razor                                支持                               支持

     这里我们看到MVC和nancy都支持WebForm和Razor视图。并且,Nancy在Razor视图中也支持Model的绑定和部分视图,在Nancy中的部分视图中,也可以使用Modle绑定。

      

     四、关于跨平台

      虽然微软刚刚宣布开源不久,但是在这之前,asp.net就可以通过Mono实现跨平台了。当然MVC和Nancy也可以通过Mono来实现跨平台。

    到这里,对在上一篇中所提到的问题,相信大家心中已经有答案了吧~~ 

     作者:雲霏霏

    QQ交流群:243633526

     博客地址:http://www.cnblogs.com/yunfeifei/

     声明:本博客原创文字只代表本人工作中在某一时间内总结的观点或结论,与本人所在单位没有直接利益关系。非商业,未授权,贴子请以现状保留,转载时必须保留此段声明,且在文章页面明显位置给出原文连接。

    如果大家感觉我的博文对大家有帮助,请推荐支持一把,给我写作的动力。

  • 相关阅读:
    获取地址栏的key-value形式的值(包括重复的key值)形成对象--重复的变成数组形式
    vue---定时循环setInterval
    动画效果----webkit-animation-----动画背景变化transition:background-color 1s linear;
    background-clip--背景是否填充
    box-sizing盒子的大小,修改文字种类而保持字体大小不变font-size-adjust,----块级和内联display---盒子阴影box-shadow---对盒子中容纳不下的内容的显示overflow
    地图api学习第一天
    文字添加阴影
    css循环样式: nth-child(n)
    es6语法
    将中国标准时间--转换为yyyy-MM-dd 时分秒
  • 原文地址:https://www.cnblogs.com/yunfeifei/p/4149953.html
Copyright © 2011-2022 走看看