Arbeitsschritte/ASP.NET Core MVC/CMS/Arbeitsschritte
Eine neue .slnx Solution erstellen
Eine Solution (.slnx) ist eine Projektmappe in Visual Studio Code, die mehrere Projekte und deren Abhängigkeiten zusammenfasst. Sie dient als Container für die Organisation, Verwaltung und das Builden von Softwareprojekten.
mkdir MeinCMS
cd MeinCMS
echo '<Solution />' > MeinCms.slnx
Projekte hinzufügen
Projekt erstellen
dotnet new mvc --auth Individual -o mvc
Projekt zur .slnx hinzufügen
dotnet sln MeinCms.slnx add mvc/mvc.csproj
Projekt zu Services anlegen
dotnet new classlib -o Services
dotnet sln MeinCms.slnx add Services/Services.csproj
dotnet add mvc/mvc.csproj reference Services/Services.csproj
.gitignore Datei erstellen
nano .gitignore
Geben Sie Folgendes ein
mvc/bin
mvc/obj
Services/bin
Services/obj
mvc/app.app
mvc/appsettings.Development.json
mvc/appsettings.json
publish/
Konsole
Geben Sie Folgendes in die Konsole ein
cp mvc/appsettings.Development.json mvc/_appsettings.Development.json
cp mvc/appsettings.json mvc/_appsettings.json
Starten Sie Visual Studio Code
Starten Sie Visual Studio Code und gehen Sie mit der Maus auf die rechte Seite bei Program.cs. Löschen Sie die folgende Zeile:
app.MapControllerRoute(
name: "default",
pattern: "{controller=Home}/{action=Index}/{id?}")
.WithStaticAssets();
Und ergänzen Sie die Zeile, die Sie gelöscht haben
app.MapControllerRoute(
name: "default",
pattern: "{*slug}",
defaults: new { controller = "Page", action = "Index" })
.WithStaticAssets();
Datenbank erstellen
Um eine PostgreSQL-Datenbank für Ihr Projekt zu erstellen, führen Sie folgende Befehle in der Konsole aus:
sudo -u postgres -i
createdb -E UTF8 -O thorsten mvc
psql -d mvc -c "GRANT ALL PRIVILEGES ON DATABASE mvc TO thorsten
exit
Die beiden Befehle installieren NuGet-Pakete, die für die Verwendung von Entity Framework Core mit PostgreSQL benötigt werden:
cd mvc
dotnet add package Npgsql.EntityFrameworkCore.PostgreSQL
dotnet add package Microsoft.EntityFrameworkCore.Design
Passen Sie anschließend die Verbindungszeichenfolge in Ihrer appsettings.json an: Löschen Sie folgende Zeile
"ConnectionStrings": {
"DefaultConnection": "DataSource=app.db;Cache=Shared"
},
Wo Sie die Zeile gelöscht haben, ersetzen Sie sie durch folgende Zeile
"ConnectionStrings": {
"DefaultConnection": "Host=localhost;Database=meincmsdb;Username=meincmsuser;Password=IhrPasswort"
},
Gehen Sie zu Program.cs und löschen Sie die folgende Zeile
var connectionString = builder.Configuration.GetConnectionString("DefaultConnection") ?? throw new InvalidOperationException("Connection string 'DefaultConnection' not found.");
builder.Services.AddDbContext<ApplicationDbContext>(options =>
options.UseSqlite(connectionString));
Ersetzen Sie die folgende Zeile
var connectionString = builder.Configuration.GetConnectionString("DefaultConnection") ?? throw new InvalidOperationException("Connection string 'DefaultConnection' not found.");
builder.Services.AddDbContext<ApplicationDbContext>(options =>
options.UseNpgsql(connectionString));
Ersetzen Sie die Zeile
builder.Services.AddDbContext<ApplicationDbContext>(options =>
options.UseNpgsql(builder.Configuration.GetConnectionString("DefaultConnection")));
Entwicklung Rechner
Achtung: Diese Befehle und Einstellungen sind ausschließlich für Entwicklungsumgebungen gedacht und sollten nicht auf Produktionsservern verwendet werden.
dotnet user-secrets init
dotnet user-secrets set "ConnectionStrings:DefaultConnection" "Host=localhost;Database=MeineDatenbank;Username=postgres;Password=GEHEIMES_PASSWORT"
Datenbank Migration
dotnet ef migrations add thorsten
dotnet ef database update
Identity hinzufügen
Um ASP.NET Core Identity zu Ihrem Projekt hinzuzufügen, installieren Sie zunächst das erforderliche NuGet-Paket für die Codegenerierung und führen dann den Identity-Scaffolding-Befehl aus. Dadurch werden die benötigten Dateien und Konfigurationen für die Benutzerverwaltung (Registrierung, Anmeldung, Rollen usw.) generiert.
Führen Sie dazu folgende Befehle in der Konsole aus:
dotnet add package Microsoft.VisualStudio.Web.CodeGeneration.Design
dotnet aspnet-codegenerator identity -dc ApplicationDbContext
Test-Controller erstellen
Um zu testen, ob alles funktioniert, erstellen Sie einen Test-Controller: Datei: /Controllers/PageController
using Microsoft.AspNetCore.Mvc;
namespace mvc.Controllers
{
public class PageController : Controller
{
// GET: PageController
public ActionResult Index(string slute)
{
ViewBag.slute = slute;
return View();
}
}
}
Test-Views erstellen
Jetzt testen wir die View, sonst läuft der Test im Browser nicht. Datei: /Views/Page/Index.cshtml
<h1>@ViewBag.slute</h1>
Ich habe heute die Zeile in Program.cs gelöscht, weil sie schlecht wartbar war.
app.MapControllerRoute(
name: "default",
pattern: "{*slug}",
defaults: new { controller = "Page", action = "Index" })
.WithStaticAssets();
Zeile hinzufügen:
app.MapControllers()
.WithStaticAssets();