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
- Visual Studio 2017
- Internetowy interfejs API 5.2.7
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.
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.
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 Startup
nazwę .
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 ValuesController
nazwę .
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"]
Dodatkowe zasoby
Hostowanie ASP.NET internetowego interfejsu API w roli procesu roboczego platformy Azure