使用OWIN自托管開發ASP.NET Web API的系列


本教程說明如何使用OWIN自托管Web API框架,在控制台應用程序中托管ASP.NET Web API。

.NET開放Web界面(OWIN)定義了.NET Web服務器和Web應用程序之間的抽象。OWIN將Web應用程序與服務器分離,這使OWIN成為在IIS之外以自己的進程自托管Web應用程序的理想選擇。

本教程中使用的軟件版本

 注意

您可以在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"]

參考資料

https://docs.microsoft.com/en-us/aspnet/web-api/overview/hosting-aspnet-web-api/use-owin-to-self-host-web-api

描述

4月中旬開發一個小項目,App和客戶端進行數據交互,為了脫離IIS(因為IIS安裝太麻煩,有的客戶電腦配置太低),因此我們定初步目標是采用Stock通信進行數據交互,進行一兩天發現Stock開發太慢;最后網上找到使用OWIN自托管Web API框架,在控制台應用程序中托管ASP.NET Web API。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM