Visual Studio 2014

开发 ASP.NET vNext 初步总结(使用Visual Studio 2014 CTP1)

2014-06-06 18:04 by 梁逸晨, 2149 阅读, 29 评论, 收藏编辑

新特性:

vNext又称MVC 6.0,不再需要依赖System.Web,占用的内存大大减少(从前无论是多么简单的一个请求,System.Web本身就要占用31KB内存)。 
可以self-host模式运行,网站不再需要依赖IIS而运行,由此从此可以快速向客户演示开发进度,以及更好地支持真正跨平台(Linux、Mac、Unix)。 
Web Api、Web Pages与MVC完全融为一体,统称MVC 6.0。在过去,输出JSON,既可以使用MVC自带的return JSON,也可以使用Web Api,这样分而治之的场面给整个社区都带来不良影响(JSON仅是其中一个例子,其它很多功能都是一样),现在,Web Api 完全融入了vNext,重复的轮子在这里终于得到终结。 
支持Poco形式的Controller,代码更加干净。 
云优化技术,也就是说在开发阶段,系统本身并不真正加载某个组件,而是在运行时才查询合适版本的组件,由此带来的好处是在Azure云主机、Mono主机和Windows主机上可以依赖最合适当前环境的某个组件Dll。 
内置了依赖注入框架 
使用Roslyn编译器,生成的代码更高效 
 
与1~5.x的差异

1:Project.json代替了从前的Web.config: 

  • 项目包的依赖项在dependencies节点中定义。 
  • configurations节点保存的是项目设置信息。 
  • commands节点保存的是self-host配置参数,例如本地绑定端口号。 
  • 自定义节点,例如自定义一个Data节点,在它的作用域中再定义一个DefaultConnectionString来记录数据库连接字符串。 

2:Startup.cs代替了Global.asax 
 
3:Views文件夹中不再需要专门的Web.config 

当你添加某个引用(例如Entity Framework)的时候,需要网络实时加载,所以如果遇到“找不到某某类库”的错误时,不要担心,过一会就好了。但是,有可能在某个良辰吉日里,你无论等多久都没用,因为我们身在天朝,你懂的。 
 
================================================ 
 
MVC的基本概念不变,依然是从前的 RouteTable、Controller、View、Action、Razor、Model 
 

下面的教程中涉及到加载包,以及各个包的版本号,例如"0.1-alpha-build-0403",也许你看到这篇文章的时候,版本号已经不适用了,最简单的解决办法是创建一个现成的ASP.NET vNext Web Application(注意不是空项目),它会加载当前可用的常用包,对照里面的对应包的版本号。


如果需要输出静态文件,例如 .html、.jpg,需要加载专门的处理流程,它们保存在Microsoft.AspNet.StaticFiles中。 

下面我们开始构建一个vNext站点: 

创建一个ASP.NET vNext 空项目

 

Visual Studio 2014

之后得到的目录结构,比从前简单多了:

Visual Studio 2014

 

首先配置project.json,在dependencies节点添加:

"Microsoft.AspNet.StaticFiles": "0.1-alpha-build-0403" //支持静态文件输出 
保存后,注意左下角的状态变化:
 
Visual Studio 2014
恢复操作时基于网络的,只有等待它恢复完毕后,才算是加载完成,如果你发现没有这两个步骤出现,请试试你懂的方法,nuget服务器在美国,我只能告诉你到这了。

 
配置Startup.cs: 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
using  System;
using  Microsoft.AspNet.Builder;
using  Microsoft.AspNet.StaticFiles;
using  Microsoft.Framework.DependencyInjection;
using  Microsoft.AspNet.Routing;
  
  
namespace  vNextTry
{
     public  class  Startup
     {
         public  void  Configure(IBuilder app)
         {
             app.UseStaticFiles();  //支持静态文件输出
  
             app.UseServices(services =>
             {
                 services.AddMvc();  //加载MVC模块
             });
  
             app.UseMvc(routes => //加载路由配置
             {
                 routes.MapRoute(
                     name: "Default" ,
                     template: "{controller}/{action}/{id?}" ,
                     defaults: new  { controller = "Home" , action = "Index"  });
             });
         }
     }
}

添加一个传统Controller

Visual Studio 2014

1
2
3
4
5
6
7
8
9
using  Microsoft.AspNet.Mvc;
   
public  class  HomeController : Controller
{
     public  ActionResult Index()
     {
         return  View();
     }
}

添加一个Poco Controller:

1
2
3
4
5
6
7
8
public  class  JsonData //不需要继承自任何类
{
     public  dynamic Index()
     {
         //就这样以非常干净简洁的方式输出JSON: {"id":1,"name":"i'm haha"}
         return  new  { id = 1, name = "i'm haha"  };  
     }
}

添加一个View
注意放置在Views/{controller名}/{这里是Index}.cshtml,母版页就不做了,Model、RenderBody等方法都和从前一样:

<!DOCTYPE html> 

<html> 

<head> 

  <meta charset="utf-8" /> 

  <title>vNext</title> 

</head> 

<body>

  <p>I'm vNext Index Page</p> 

</body> 

</html> 

一切就此完成。现在就可以运行测试看看。

Visual Studio 2014

 

以self-host模式运行应用程序
self-host是MVC6的最大特点,我们的应用程序不再需要配置巨大的IIS,使得在客户机上快速演示应用程序不再困难。
通过设置project.json配置self-host(注意5001,那就是绑定的端口): 

dependencies节点添加:"Microsoft.AspNet.Server.WebListener": "0.1-alpha-build-0520"

"commands": { 
    "web": "Microsoft.AspNet.Hosting server=Microsoft.AspNet.Server.WebListener server.urls=http://localhost:5001" 


然后保存、发布到输出目录(注意一定要先保存,等待nuget恢复加载包

然后运行输出目录下的web.cmd,即可开启服务。

Visual Studio 2014

以IIS模式运行应用程序: 
目前只能发布到安装了开发环境的本机IIS,但是根据它的运行逻辑,原则上也可以配置某些参数,让程序在远程服务器上运行,目前还没尝试,就不说了。
如是是64位系统,可能会遇到找不到KRE-svr50-x64.0.1-alpha-build-0446的问题,目前微软只提供了32位版本,我们只有把应用程序池设置为32位模式运行就可以解决了。

Visual Studio 2014

Visual Studio 2014

使用Web Api:
变得更简单了: 
1:在Startup.cs中配置路由:
app.UseMvc(routes => 

    routes.MapRoute("ApiRoute", "{controller}/{id?}"); 
}); 
 
2:在controller中:

using Microsoft.AspNet.Mvc; 

 

public class ValuesController : Controller 

{ 

    // GET /values 

    public string Get() 

    { 

        return "Values"; 

    } 

 

    // GET /values/1 

    public string Get(int id) 

    { 

        return "Value " + id.ToString(); 

    } 

  

    // POST /values 

    public ActionResult Post() 

    { 

        return new HttpStatusCodeResult(201); 

    } 

}

  

就这样,不再需要加载任何包或DLL,不需要配置任何专有Config,API已经完全融合到MVC6中,访问 localhost:端口号/api类名 

 

总体使用结论

如果使用Visual Studio进行调试的过程中出现所有页面都“无法访问”,检查IIS Express的当前服务端口是否弹出IE窗口的端口一致,如果不一直,把Visual Studio关掉(并且检查系统进程,确保不再存在相关进程),重新打开Visual Studio就可以了。

因为包的加载涉及到运行时从nuget.org加载,所以某些把App放置在国内主机商的朋友们要做好心理准备。

为了不久的将来vNext运行于*nix系统,现在就应该注意一些事项:  

  1. 严格遵守单词的大小写,特别是涉及到路径的字符串,vNext是为“真正全平台”打造的,否则将来你的程序在*nix系统(内核级就区分字母大小写)中运行会出错。 
  2. 依然是*nix系统的问题,请不要再使用GB2312等奇葩编码,应该全局(源代码文件本身、Razor文件本身、Response.Encoding、Meta--CharSet、ConnectionString)统一使用UTF8,否则乱码百出找不到原因。 
 
 
分类:  开发
标签:  asp.netmvcvNext

你可能感兴趣的:(mvc,asp.net,vNext)