Używanie interfejsu OWIN do Self-Host ASP.NET internetowego interfejsu API

W tym samouczku pokazano, jak hostować ASP.NET internetowy interfejs API w aplikacji konsolowej przy użyciu protokołu OWIN do samodzielnego hostowania struktury internetowego interfejsu API.

Open Web Interface for .NET (OWIN) definiuje abstrakcję między serwerami internetowymi platformy .NET i aplikacjami internetowymi. OWIN oddziela aplikację internetową od serwera, co sprawia, że OWIN idealnie nadaje się do samodzielnego hostowania aplikacji internetowej we własnym procesie poza usługami IIS.

Wersje oprogramowania używane w samouczku

Uwaga

Pełny kod źródłowy tego samouczka znajduje się w github.com/aspnet/samples.

Tworzenie aplikacji konsolowej

W menu Plik wybierz pozycję Nowy, a następnie wybierz pozycję Projekt. W obszarze Zainstalowane w obszarze Visual C# wybierz pozycję Windows Desktop , a następnie wybierz pozycję Aplikacja konsolowa (.Net Framework). Nadaj projektowi nazwę "OwinSelfhostSample" i wybierz przycisk OK.

Zrzut ekranu przedstawiający okno dialogowe

Dodawanie pakietów internetowego interfejsu API i OWIN

W menu Narzędzia wybierz pozycję Menedżer pakietów NuGet, a następnie wybierz pozycję Konsola Menedżera pakietów. W oknie Konsola menedżera pakietów wprowadź następujące polecenie:

Install-Package Microsoft.AspNet.WebApi.OwinSelfHost

Spowoduje to zainstalowanie pakietu OWIN selfhost interfejsu WebAPI i wszystkich wymaganych pakietów OWIN.

Zrzut ekranu przedstawiający konsolę menedżera pakietów z informacjami o licencjonowaniu, a następnie P M > na końcu, sygnalizując, gdzie należy wpisać polecenie.

Konfigurowanie internetowego interfejsu API dla własnego hosta

W Eksplorator rozwiązań kliknij prawym przyciskiem myszy projekt i wybierz polecenie Dodaj / klasę, aby dodać nową klasę. Nadaj klasie Startupnazwę .

Zrzut ekranu przedstawiający menu okna dialogowego Eksploratora rozwiązań z instrukcjami, które należy wykonać w celu dodania klasy do projektu.

Zastąp cały kod kotła w tym pliku następującym kodem:

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); 
        } 
    } 
}

Dodawanie kontrolera internetowego interfejsu API

Następnie dodaj klasę kontrolera internetowego interfejsu API. W Eksplorator rozwiązań kliknij prawym przyciskiem myszy projekt i wybierz polecenie Dodaj / klasę, aby dodać nową klasę. Nadaj klasie ValuesControllernazwę .

Zastąp cały kod kotła w tym pliku następującym kodem:

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) 
        { 
        } 
    } 
}

Uruchamianie hosta OWIN i wysyłanie żądania za pomocą klienta HttpClient

Zastąp cały kod boilerplate w pliku Program.cs następującym kodem:

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(); 
            } 
        } 
    } 
 }

Uruchamianie aplikacji

Aby uruchomić aplikację, naciśnij klawisz F5 w programie Visual Studio. Dane wyjściowe powinny wyglądać następująco:

StatusCode: 200, ReasonPhrase: 'OK', Version: 1.1, Content: System.Net.Http.StreamContent, Headers: 
{ 
  Date: Tue, 09 Jul 2013 18:10:15 GMT 
  Server: Microsoft-HTTPAPI/2.0 
  Content-Length: 19 
  Content-Type: application/json; charset=utf-8 
} 
["value1","value2"]

Zrzut ekranu konsoli przedstawiający kod stanu i informacje dotyczące aplikacji podczas jej działania.

Dodatkowe zasoby

Omówienie projektu Katana

Hostowanie ASP.NET internetowego interfejsu API w roli procesu roboczego platformy Azure