本教程說明如何使用OWIN自托管Web API框架,在控制台應用程式中托管ASP.NET Web API。 .NET開放Web界面(OWIN)定義了.NET Web伺服器和Web應用程式之間的抽象。OWIN將Web應用程式與伺服器分離,這使OWIN成為在IIS之外以自己的進程自托管Web應用程式的理 ...
本教程說明如何使用OWIN自托管Web API框架,在控制台應用程式中托管ASP.NET Web API。
.NET開放Web界面(OWIN)定義了.NET Web伺服器和Web應用程式之間的抽象。OWIN將Web應用程式與伺服器分離,這使OWIN成為在IIS之外以自己的進程自托管Web應用程式的理想選擇。
本教程中使用的軟體版本
- Visual Studio 2017
- Web API 5.2.7
註意
您可以在github.com/aspnet/samples中找到本教程的完整源代碼。
創建一個控制台應用程式
在文件菜單上, 新建,然後選擇項目。在“ 已安裝 ”的Visual C#下,選擇“ Windows桌面”,然後選擇“ 控制台應用程式(.Net Framework)”。將項目命名為“ OwinSelfhostSample”,然後選擇“ 確定”。
添加Web API和OWIN包
從“ 工具”菜單中,選擇“ NuGet軟體包管理器”,然後選擇“ 軟體包管理器控制台”。在“程式包管理器控制台”視窗中,輸入以下命令:
Install-Package Microsoft.AspNet.WebApi.OwinSelfHost
這將安裝WebAPI OWIN自托管軟體包和所有必需的OWIN軟體包。
配置Web API以進行自我托管
在解決方案資源管理器中,右鍵單擊該項目,然後選擇“ 添加 / 類”以添加新的類。給班級命名Startup
。
用以下內容替換此文件中的所有樣板代碼:
using Owin; using System.Web.Http; namespace OwinSelfhostSample { public class Startup { // This code configures Web API. The Startup class is specified as a type // parameter in the WebApp.Start method. public void Configuration(IAppBuilder appBuilder) { // Configure Web API for self-host. HttpConfiguration config = new HttpConfiguration(); config.Routes.MapHttpRoute( name: "DefaultApi", routeTemplate: "api/{controller}/{id}", defaults: new { id = RouteParameter.Optional } ); appBuilder.UseWebApi(config); } } }
添加Web API控制器
接下來,添加一個Web API控制器類。在解決方案資源管理器中,右鍵單擊該項目,然後選擇“ 添加 / 類”以添加新的類。給班級命名ValuesController
。
用以下內容替換此文件中的所有樣板代碼:
using System.Collections.Generic; using System.Web.Http; namespace OwinSelfhostSample { public class ValuesController : ApiController { // GET api/values public IEnumerable<string> Get() { return new string[] { "value1", "value2" }; } // GET api/values/5 public string Get(int id) { return "value"; } // POST api/values public void Post([FromBody]string value) { } // PUT api/values/5 public void Put(int id, [FromBody]string value) { } // DELETE api/values/5 public void Delete(int id) { } } }
啟動OWIN主機並向HttpClient發出請求
用以下內容替換Program.cs文件中的所有樣板代碼:
using Microsoft.Owin.Hosting; using System; using System.Net.Http; namespace OwinSelfhostSample { public class Program { static void Main() { string baseAddress = "http://localhost:9000/"; // Start OWIN host using (WebApp.Start<Startup>(url: baseAddress)) { // Create HttpClient and make a request to api/values HttpClient client = new HttpClient(); var response = client.GetAsync(baseAddress + "api/values").Result; Console.WriteLine(response); Console.WriteLine(response.Content.ReadAsStringAsync().Result); Console.ReadLine(); } } } }
運行應用程式
若要運行該應用程式,請在Visual Studio中按F5。輸出應如下所示:
StatusCode: 200, ReasonPhrase: 'OK', Version: 1.1, Content: System.Net.Http.StreamContent, Headers:
{
Date: Mon, 04 May 2020 07:35:10 GMT
Server: Microsoft-HTTPAPI/2.0
Content-Length: 19
Content-Type: application/json; charset=utf-8
}
["value1","value2"]
參考資料
描述
4月中旬開發一個小項目,App和客戶端進行數據交互,為了脫離IIS(因為IIS安裝太麻煩,有的客戶電腦配置太低),因此我們定初步目標是採用Stock通信進行數據交互,進行一兩天發現Stock開發太慢;最後網上找到使用OWIN自托管Web API框架,在控制台應用程式中托管ASP.NET Web API。