ASP.NET 5 理解和入門
使用自定義配置文件
首先,目前只有VS 2015支持開發最新的ASP.NET 5 程序,所以我們首先需要下載安裝其最新的RC版本.
https://www.visualstudio.com/en-us/downloads/visual-studio-2015-downloads-vs.aspx
安裝完畢以后,打開并建立新的Web application項目:
然后在后一個界面中選擇ASP.NET 5 Empty模板:
這里提2個注意點:
建立項目完成以后,我們可以看到如下項目結構:
其中global.json記錄了解決方案的一些配置,PRoject_Readme.html則是一個介紹頁面.
比較重要的文件或者文件夾是以下3個:
l Startup.cs : 啟動類
l project.json: 項目配置文件
l wwwroot : 整個WebApp的靜態文件目錄(由于最小模板沒有加載靜態文件中間件,所以該目錄內容暫時無效,這個稍后說明)
ASP.NET 5的啟動類只有一個,這里再也沒有Global.asax,RouteConfig等耳熟能詳的啟動文件,而只剩下這個Startup.cs是ASP.NET 5的唯一入口。
一般情況下Startup類會包含3個主要函數: 構造函數,ConfigureServices和Configure
在最小模板下,我們僅僅看到后面2個函數,沒有構造函數,雖然不是必須的,但構造函數在讀取初始化參數的環境下也是非常重要的,這個我們以后再介紹.
我們可以這樣來理解這3個函數的作用:
構造函數: 加載各種配置文件和配置信息.
ConfigureServices: 加載各種基于依賴注入(Dependency Injection)的服務,這里提下,在ASP.NET 5中,依賴注入技術得到了充分的使用,大大優化了代碼的結構.
Configure: 加載各種需要的中間件(Middleware),這個概念和Owin中間件概念是一致的,和原來IIS中的HttpModule非常的類似.
ASP.NET 5 內置標準的Config文件只有一個: project.json. 其他配置文件都是自定義并自行裝載的。當然,在Solution目錄有一個global.json文件,但這個和ASP.NET 5主體項目關系不大。另外在project.json之下,還隱藏了一個project.lock.json,其本質內容是記載了大量.NET運行環境(DNX)內置的組件信息,這個文件是由VS自行管理的,所以這個文件我們目前也先略過。
關于.NET運行環境(DNX)是VS 2015以后為適應多平臺運行環境所提出的全新的概念,這個概念對理解ASP.NET編譯和運行環境至關重要,不過此內容不在本文的討論范圍以內,如果要深入理解,請通過我上一篇博文ASP.NET 5 (vNext) 理解和概述 中提供的超鏈來進一步學習.
那么我們開始進入project.json
"webroot": "wwwroot",
"version": "1.0.0-*",
前者定義了WebApp靜態文件的根目錄,一般不需要修改;后者定義了整個項目的版本號.
"dependencies": {
"Microsoft.AspNet.Server.IIS": "1.0.0-beta4",
"Microsoft.AspNet.Server.WebListener": "1.0.0-beta4"
},
除了.Net運行環境DNX內置組件外,項目所需加載的外部組件,目前只有2個Server組件: IIS和控制臺,這2個組件可以讓當前的WebApp運行在IIS或者控制臺程序.
這里稍微提下,可以通過這個配置段落的智能感知快速的給當前項目加入組件,這個牛逼的特性我們下面詳細介紹.
"commands": {
"web": "Microsoft.AspNet.Hosting --server Microsoft.AspNet.Server.WebListener --server.urls http://localhost:5000"
},
這里定義項目內部內置的各種命令,由于控制臺Server模式必須由一個命令啟動,所以在此定義了一個web命令行.通過啟動這個命令就能啟動控制臺Server模式.一般來說,VS提供了啟動這個命令內在機制,但我們要理解,ASP.NET其實是通過DNX環境的核心命令dnx.exe來運行外部命令的,關于這個命令我感覺目前整合的并不完美,而且這個命令存在于一個非常詭異的地方,關于這部分內容我們再后面的博文在進一步討論.
"frameworks": {
"dnx451": { },
"dnxcore50": { }
},
定義該項目可以運行的.Net Framework版本,默認同時支持4.5.1和5.0 Core版本,去掉任何一個都是可以的,當然要注意5.0還沒有最終Release,還需要注意有些組件可能在5.0 Core版本上會有兼容問題,這個時候就必須進行取舍.
"publishExclude" 和 "exclude"主要影響發布和編譯時的內容選擇.對主功能影響不大.
好,下面我們來運行下看看是什么效果,選擇web方式(控制臺Server)運行,會彈出一個控制臺程序:
然后用瀏覽器訪問http://localhost:5000 (這個URL和project.json中web command的參數配置相吻合),可以看到 一個有“Hello World”的頁面.
為什么最小模板下會有這個頁面,我們可以看到其實在Startup的Configure函數中有這樣一段代碼:
public void Configure(IApplicationBuilder app) { app.Run(async (context) => { await context.Response.WriteAsync("Hello World!"); }); }
這里用Lambda表達式實現了一個非常小型的中間件,當然這塊代碼沒有什么特別意義,可以去除.
正如我上一篇文章所有,ASP.NET 5的組件必需通過Nuget進行管理,但實際操作中,卻可以有2種方式。
通過Nuget安裝,這個用過VS2013的同學都應該非常熟悉了,當然VS2015界面略有不同,而且更加準確,功能更完整,大家具體看一下就了解了.
而我想特別推薦的是第二種方式,在project.json文件的dependencies小節,直接使用智能感知進行添加.
當然首先我們要引入StaticFile組件,利用直接修改project.json的方式,可以進行快速的添加:
"dependencies": {
"Microsoft.AspNet.Server.IIS": "1.0.0-beta4",
"Microsoft.AspNet.Server.WebListener": "1.0.0-beta4",
//Static Files
"Microsoft.AspNet.StaticFiles": "1.0.0-beta4"
},
修改并保存之后,VS會自動把這個組件加載到當前項目的所有Framework中:
下面我們來加載靜態文件的中間件,我們知道,所有中間件是通過Startup的Configure函數來加載的,我們把這個函數原有的代碼替換為如下代碼.
public void Configure(IApplicationBuilder app) { //加載靜態文件中間件 app.UseStaticFiles(); }
根據前面的說明我們知道靜態文件中間件會把根目錄默認設定為wwwroot,下面我們再這個目錄下建立一個index.html,里面放入任何內容.
這時候再次啟動整個項目(web方式)通過http://localhost:5000/index.html 就可以訪問到這個頁面. (反之,如果你沒有添加app.UseStaticFiles();這個頁面是訪問不到的)
下面我們稍微擴充下,如果我們想把index.html設置為我們的默認文檔,我們應該如何去做,其實很簡單,在StaticFiles組件中,還提供了另外一個中間件來實現這個功能,我們回到Configure函數再加入如下代碼即可:
public void Configure(IApplicationBuilder app) { //設定靜態文件的默認文檔 app.UseDefaultFiles(new DefaultFilesOptions() { DefaultFileNames = new string[] { "index.html" } }); //加載靜態文件中間件 app.UseStaticFiles(); }
這個時候需要引入
using Microsoft.AspNet.StaticFiles;
另外UserDefaultFIles必須在UserStaticFiles之前運行.
然后重新啟動項目,會發現直接訪問 http://localhost:5000 就能看到index.html頁面.
當然StaticFiles中間件僅僅是一個起步,一個真正有意義的Web Application還需要更多的內容,下面我會依次介紹在ASP.NET 5項目中如何加入MVC 6, WebApi 2, Entity Framework 7, MS Identity 3的實現方法. 敬請期待.
新聞熱點
疑難解答