Dieses Beispiele benötigen .NET Core 3.1. Prüfe vorher in der Eingabeaufforderung, ob diese Version auch installiert ist:
...>dotnet --version
3.1.100
Falls nicht, führe ein Visual Studio Update aus. Die Version 16.4 aktualisiert auf .NET Core 3.1. Wenn du kein Visual Studio verwendest (und nur dann), lade die neueste Version der .NET Core SDK von https://dotnet.microsoft.com/download.
Um eine REST API mit ASP.NET Core zu erstellen, wird in Visual Studio 2019 mittels Create a new project die Vorlage ASP.NET Core Web Application gewählt. Nach der Vergabe eines Namens wird in den Projekteinstellungen der Punkt API gewählt. Die Checkbox bei Configure for HTTPS kann auch angehakt bleiben. Es wird dann beim ersten Start ein Zertifikat generiert und eingetragen:
Wenn du auf Linux, macOS oder in der Konsole von Windows arbeiten möchtest, kannst du ein API Projekt auch in der Eingabeaufforderung anlegen. Dafür erstelle zuerst ein Verzeichnis mit dem Projektnamen und erstelle danach die Applikation darin.
md GetRoutesDemo
cd GetRoutesDemo
dotnet new webapi
Es wird eine .csproj Datei angelegt, die mit Visual Studio oder Visual Studio Code geöffnet werden kann. Sie hat folgenden Aufbau:
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
<TargetFramework>netcoreapp3.1</TargetFramework>
</PropertyGroup>
</Project>
Der Eintrag TargetFramework zeigt die SDK Version an. Um das Projekt kompilieren oder ausführen zu können, muss diese SDK Version am System installiert sein.
Im Ordner der Projektdatei kann einfach auf der Konsole mit dotnet run der Server gestartet werden. Er zeigt den Port und das Netzwerkinterface aus der Konfiguration an.
Im Browser kann die Demoroute aus dem Template unter http://localhost:5000/weatherforecast oder https://localhost:5001/weatherforecast angezeigt werden.
...\GetRoutesDemo>dotnet run
info: Microsoft.Hosting.Lifetime[0]
Now listening on: https://localhost:5001
info: Microsoft.Hosting.Lifetime[0]
Now listening on: http://localhost:5000
info: Microsoft.Hosting.Lifetime[0]
Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
Hosting environment: Development
info: Microsoft.Hosting.Lifetime[0]
Content root path: C:\Users\Michael\Desktop\GetRoutesDemo
Der Server hört standardmäßig auf die Ports 5000 und 5001. Um das zu ändern, ersetze die Datei Properties/launchSettings.json durch folgenden Inhalt. Falls die Ports bei dir schon belegt sind, können sie natürlich durch andere Werte ersetzt werden.
Wenn der Server von Visual Studio aus gestartet wird, wird auch das Property launchUrl ausgelesen. Es gibt die Adresse an, die beim Öffnen des Browsers nach dem Serverstart erscheint.
{
"$schema": "http://json.schemastore.org/launchsettings.json",
"profiles": {
"GetRoutesDemo": {
"commandName": "Project",
"launchBrowser": true,
"launchUrl": "api/pupil",
"applicationUrl": "https://localhost:443;http://localhost:80",
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
}
}
}
Über die Methode CreateHostBuilder() in Program.cs kann ebenfalls der Port und das Logging konfiguriert werden:
public static IHostBuilder CreateHostBuilder(string[] args)
{
return Host.CreateDefaultBuilder(args)
.ConfigureLogging(logging =>
{
logging
.ClearProviders()
.AddConsole();
})
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder
.UseUrls("http://*:80;https://*.443")
.UseStartup<Startup>();
});
}
Durch ConfigureLogging() kann der Logger nun in jeder Klasse über Dependency Injection geholt und benutzt werden.
public class MyController : ControllerBase
{
...
private readonly ILogger<MyController> _logger;
public UserController(ILogger<MyController> logger)
{
...
_logger = logger;
}
public string MyMethod()
{
_logger.LogInformation("Info");
_logger.LogWarning("Warning");
_logger.LogError("Error");
}
...
}
Die Projektdatei muss vom Typ Microsoft.NET.Sdk.Web sein:
<Project Sdk="Microsoft.NET.Sdk.Web">
...
</Project>
Danach kann folgendes Programm in Program.cs einfach mit dotnet run ausgeführt werden. Im Browser erscheint dann unter der Adresse http://localhost/sayhello/User der Text Hello User.
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Routing;
using Microsoft.Extensions.Hosting;
using System;
namespace MinimalWebserver
{
class Program
{
static void Main(string[] args)
{
Host
.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder
.UseUrls("http://*:80;https://*.443")
.Configure(app =>
{
app.UseRouting();
app.UseEndpoints(route =>
{
route.MapGet("/", context => context.Response.WriteAsync("ASP.NET Core"));
route.MapGet("/sayhello/{name}", context => context.Response.WriteAsync($"Hello {context.GetRouteValue("name")}"));
});
});
})
.Build()
.Run();
}
}
}
Weitere Informationen: