利用记事本创建一个ASP.NET Core RC2 MVC应用
步驟一、安裝最新的.NET Core SDK
我們可以根據自身的操作系統環境從https://github.com/dotnet/cli上下載.NET Core最新的SDK,這個SDK包含.NET Core Runtime和一些有用工具(比如命令行)。如果你已經安裝了老舊的版本,我個人建議你先將其卸載。
目前的版本為1.0.0-preview1-002702,我們可以執行dotnet –version命令確認是否是這個版本。
步驟二、定義源代碼和配置
我們創建一個目錄(假設為C:\HelloWorld)來存放MVC應用所有的源文件。下圖展現了定義在這個目錄下的所有文件。
定義NuGet.xml
我們在NuGet.xml文件中定義應用程序使用的NuGet包所在的站點地址(https://www.myget.org/F/aspnetvnext/api/v3/index.json)。
? 1: <?xml version="1.0" encoding="utf-8"?> ? 2: <configuration> ? 3: <packageSources> ? 4: <add key="RC2" value="https://www.myget.org/F/aspnetvnext/api/v3/index.json" /> ? 5: </packageSources> ? 6: </configuration>定義Project.json
定義在Project.json文件中的所有配置如下所示,我們會發現它與RC1中的Project.json不太一樣。RC2中,我們可以向定義普通依賴一樣來選擇運行時(Microsoft.NETCore.App),或者說運行時本質已經成為了一個一般意義上的以來。除了這個針對運行時的依賴,我們還添加了兩個依賴,它們分別是“Microsoft.AspNetCore.Mvc”和“Microsoft.AspNetCore.Server.Kestrel”,前者定義了ASP.NET Core MVC的核心框架,后者則提供了一個針對Kestrel的Server (ASP.NET Core管道中的Server專門負責請求的監聽、接收和回復)。我們在“framework”節點添加了一個名為“netcoreapp1.0”的框架,之前的名稱叫做“dnxcore50”。
? 1: { ? 2: "version": "1.0.0-*", ? 3: "buildOptions": { ? 4: "emitEntryPoint": true ? 5: }, ? 6: "dependencies": { ? 7: "Microsoft.NETCore.App": { ? 8: "type": "platform", ? 9: "version": "1.0.0-rc2-3002702" ?10: }, ?11: "Microsoft.AspNetCore.Mvc":"1.0.0-rc2-final", ?12: "Microsoft.AspNetCore.Server.Kestrel":"1.0.0-rc2-final" ?13: }, ?14: "frameworks": { ?15: "netcoreapp1.0": { ?16: "imports": "dnxcore50" ?17: } ?18: } ?19: }定義入口程序
啟動應用的入口程序定義在Program.cs。如下面的代碼片段所示,我們在這個文件中定義了一個Program類型,并在Main方法中編寫了啟動MVC應用的代碼。具體來說,我們創建了一個WebHostBuilder對象通過調用擴展方法UseKestrel為構建的HTTP消息處理管道注冊了一個Kestrel服務器。在調用UseStartup方法將Startup設置為啟動類型之后,我們調用Build方法創建了一個WebHost對象。我們最終調用Run方法啟動WebHost,進而啟動了我們的MVC應用。
? 1: using Microsoft.AspNetCore.Hosting; ? 2: using Microsoft.AspNetCore.Builder; ? 3:? ? 4: public class Program ? 5: { ? 6: public static void Main(string[] args) ? 7: { ? 8: new WebHostBuilder() ? 9: .UseKestrel() ?10: .UseStartup<Startup>() ?11: .Build() ?12: .Run(); ?13: } ?14: }定義初始化類型
ASP.NET Core應用啟動的時候會先執行一段初始化操作來構建一個完整的HTTP消息處理管道,這些初始化操作定義在Startup.cs。上面調用WebHostBuilder的UseStartup方法指定的類型Startup就定義在這個文件中。如下面的代碼片段所示,我們在ConfigureServices方法中注冊了與MVC相關的服務,并利用Configure方法將實現MVC框架的中間件注冊到消息處理管道中。
? 1: using Microsoft.AspNetCore.Builder; ? 2: using Microsoft.Extensions.DependencyInjection; ? 3:? ? 4: public class Startup ? 5: { ? 6: public void ConfigureServices(IServiceCollection services) ? 7: { ? 8: services.AddMvc(); ? 9: } ?10:? ?11: public void Configure(IApplicationBuilder app) ?12: { ?13: app.UseMvc(); ?14: } ?15: }定義Controller
我們在HomeController中定義了MVC應用中唯一的一個Controller,并按照如下的形式定義了一個唯一的Action方法。這個Action方法返回一個簡單的字符串“Hello World”,并映射為應用的根地址(“/”)
? 1: using Microsoft.AspNetCore.Mvc; ? 2: public class HomeController : Controller ? 3: { ? 4: [HttpGet("/")] ? 5: public string Index() ? 6: { ? 7: return "Hello World"; ? 8: } ? 9: }
步驟三、運行程序
RC2提供了一個非常強大的命令行(dotnet),包括恢復NuGet包以及編譯執行.NET應用的相關操作都可以通過它來完成
恢復NuGet包
我們打開命令行工具并切換到應用所在的目錄,執行dotnet restore命令恢復在project.json中使用的NuGet包。
編譯執行程序
我們直接執行dotnet build命令對整個應用實施編譯,然后執行dotnet run命令啟動我們的MVC應用。
向HomeController發起請求
當程序啟動后,Kestrel服務器會利用5000端口對HTTP請求實施監聽。由于定義在HomeController的Action方法Index被映射為應用根地址,所以我們利用瀏覽器向該地址發送請求會得到這個Action方法的響應結果。
原文地址:http://www.cnblogs.com/artech/p/hello-asp-net-core-rc2-mvc.html
.NET社區新聞,深度好文,微信中搜索dotNET跨平臺或掃描二維碼關注
總結
以上是生活随笔為你收集整理的利用记事本创建一个ASP.NET Core RC2 MVC应用的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C#读书雷达 | TW洞见
- 下一篇: 发布在即!.NET Core 1.0 R