Heim Backend-Entwicklung C#.Net-Tutorial So verwenden Sie Berechtigungskontrolle und Authentifizierung in C#

So verwenden Sie Berechtigungskontrolle und Authentifizierung in C#

Oct 09, 2023 am 11:01 AM
身份验证 权限控制 c#

So verwenden Sie Berechtigungskontrolle und Authentifizierung in C#

Für die Verwendung der Berechtigungskontrolle und Authentifizierung in C# sind bestimmte Codebeispiele erforderlich.

Im heutigen Internetzeitalter haben Fragen der Informationssicherheit zunehmende Aufmerksamkeit erhalten. Um die Sicherheit von Systemen und Daten zu schützen, sind Berechtigungskontrolle und Authentifizierung zu einem wesentlichen Bestandteil von Entwicklern geworden. Als häufig verwendete Programmiersprache bietet C# eine Fülle von Funktionen und Klassenbibliotheken, die uns bei der Implementierung der Berechtigungskontrolle und Authentifizierung unterstützen.

Berechtigungskontrolle bezieht sich auf die Beschränkung des Zugriffs eines Benutzers auf bestimmte Ressourcen basierend auf der Identität, Rolle, Berechtigungen usw. des Benutzers. Eine gängige Methode zur Implementierung der Berechtigungskontrolle ist die Verwendung eines Rollen- und Berechtigungsverwaltungssystems. Im Folgenden stellen wir anhand eines konkreten Beispiels vor, wie die Berechtigungskontrolle in C# verwendet wird.

Zuerst müssen wir eine Datenbanktabelle mit Rollen und Berechtigungen erstellen. Die Tabellenstruktur kann je nach Bedarf gestaltet werden. Hier vereinfachen wir sie in zwei Tabellen, nämlich die Rollen- und Berechtigungstabellen. In der Rollentabelle werden Rolleninformationen und in der Berechtigungstabelle Berechtigungsinformationen gespeichert. Die Tabellenstruktur ist wie folgt:

CREATE TABLE Role (
    Id INT PRIMARY KEY,
    Name VARCHAR(50) NOT NULL
)

CREATE TABLE Permission (
    Id INT PRIMARY KEY,
    Name VARCHAR(50) NOT NULL,
    RoleId INT,
    FOREIGN KEY(RoleId) REFERENCES Role(Id)
)
Nach dem Login kopieren

Als nächstes definieren Sie die Entitätsklassen von Rollen und Berechtigungen in C#:

public class Role
{
    public int Id { get; set; }
    public string Name { get; set; }
}

public class Permission
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int RoleId { get; set; }
}
Nach dem Login kopieren

Dann müssen wir die Logik der Berechtigungsüberprüfung in den Code schreiben. Im Allgemeinen können wir Berechtigungen am Eingang des Systems beurteilen, beispielsweise im Konstruktor des Controllers. Das Folgende ist ein einfaches Beispiel für die Berechtigungsüberprüfung:

public class HomeController : Controller
{
    private readonly IPermissionService _permissionService;

    public HomeController(IPermissionService permissionService)
    {
        _permissionService = permissionService;
    }

    public IActionResult Index()
    {
        if(!_permissionService.HasPermission(User.Identity.Name, "HomePageAccess"))
        {
            return Unauthorized();
        }
        
        return View();
    }
}
Nach dem Login kopieren

Im obigen Beispiel greifen wir über die IPermissionService-Schnittstelle auf den Berechtigungsüberprüfungsdienst zu. Bei der Implementierung des Dienstes können wir die Datenbank abfragen, um festzustellen, ob der Benutzer über die entsprechenden Berechtigungen verfügt. Hier vereinfachen wir es, um direkt eine Methode zum Bestimmen von Berechtigungen zu verwenden:

public interface IPermissionService
{
    bool HasPermission(string username, string permissionName);
}

public class PermissionService : IPermissionService
{
    public bool HasPermission(string username, string permissionName)
    {
        // 根据用户名和权限名查询数据库,判断用户是否有权限
        // 这里省略具体的数据库查询过程
        
        // 假设用户有权限
        return true;
    }
}
Nach dem Login kopieren

Durch das obige Codebeispiel können wir eine einfache Berechtigungskontrollfunktion implementieren. Wenn ein Benutzer auf die Homepage (Index) zugreift, ermittelt das System, ob der Benutzer über die HomePageAccess-Berechtigung verfügt, und gibt andernfalls 401 Unauthorized zurück.

Darüber hinaus ist neben der Berechtigungskontrolle auch die Identitätsprüfung der Schlüssel zur Gewährleistung der Systemsicherheit. In C# können Sie die in ASP.NET Core bereitgestellte Authentifizierungsfunktion verwenden, um Benutzer zu authentifizieren. Das Folgende ist ein Authentifizierungsbeispiel mit ASP.NET Core:

public class AccountController : Controller
{
    private readonly UserManager<ApplicationUser> _userManager;
    private readonly SignInManager<ApplicationUser> _signInManager;

    public AccountController(UserManager<ApplicationUser> userManager, SignInManager<ApplicationUser> signInManager)
    {
        _userManager = userManager;
        _signInManager = signInManager;
    }

    public IActionResult Login()
    {
        return View();
    }

    [HttpPost]
    public async Task<IActionResult> Login(LoginViewModel model)
    {
        if (ModelState.IsValid)
        {
            var result = await _signInManager.PasswordSignInAsync(model.Username, model.Password, model.RememberMe, lockoutOnFailure: true);
            
            if (result.Succeeded)
            {
                return RedirectToAction("Index", "Home");
            }
            else if (result.IsLockedOut)
            {
                ModelState.AddModelError(string.Empty, "账户被锁定,请稍后再试。");
            }
            else
            {
                ModelState.AddModelError(string.Empty, "用户名或密码错误。");
            }
        }

        return View();
    }
}
Nach dem Login kopieren

Im obigen Beispiel verwenden wir den von ASP.NET Core bereitgestellten UserManager und SignInManager, um den Benutzer zu authentifizieren. In der Anmeldeaktion (Login) überprüfen wir den Benutzernamen und das Passwort des Benutzers, indem wir die Methode PasswordSignInAsync aufrufen.

Zusammenfassend lässt sich sagen, dass C# eine Fülle von Funktionen und Klassenbibliotheken bietet, die uns bei der Implementierung der Berechtigungskontrolle und Authentifizierung unterstützen. Durch die rationelle Nutzung des Rollen- und Berechtigungsverwaltungssystems in Kombination mit der von ASP.NET Core bereitgestellten Authentifizierungsfunktion können wir einen wirksamen Schutz für das System und die Daten bieten und die Sicherheit des Systems gewährleisten. Natürlich muss die spezifische Implementierungsmethode an den tatsächlichen Bedarf und den Projektumfang angepasst werden.

Das obige ist der detaillierte Inhalt vonSo verwenden Sie Berechtigungskontrolle und Authentifizierung in C#. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Active Directory mit C# Active Directory mit C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Active Directory mit C#. Hier besprechen wir die Einführung und die Funktionsweise von Active Directory in C# sowie die Syntax und das Beispiel.

Zufallszahlengenerator in C# Zufallszahlengenerator in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zum Zufallszahlengenerator in C#. Hier besprechen wir die Funktionsweise des Zufallszahlengenerators, das Konzept von Pseudozufallszahlen und sicheren Zahlen.

C#-Serialisierung C#-Serialisierung Sep 03, 2024 pm 03:30 PM

Leitfaden zur C#-Serialisierung. Hier besprechen wir die Einführung, die Schritte des C#-Serialisierungsobjekts, die Funktionsweise bzw. das Beispiel.

C#-Datenrasteransicht C#-Datenrasteransicht Sep 03, 2024 pm 03:32 PM

Leitfaden zur C#-Datenrasteransicht. Hier diskutieren wir die Beispiele, wie eine Datenrasteransicht aus der SQL-Datenbank oder einer Excel-Datei geladen und exportiert werden kann.

Muster in C# Muster in C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Mustern in C#. Hier besprechen wir die Einführung und die drei wichtigsten Arten von Mustern in C# zusammen mit ihren Beispielen und der Code-Implementierung.

Primzahlen in C# Primzahlen in C# Sep 03, 2024 pm 03:35 PM

Leitfaden zu Primzahlen in C#. Hier besprechen wir die Einführung und Beispiele von Primzahlen in C# sowie die Codeimplementierung.

Fakultät in C# Fakultät in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zur Fakultät in C#. Hier diskutieren wir die Einführung in die Fakultät in C# zusammen mit verschiedenen Beispielen und Code-Implementierungen.

Der Unterschied zwischen Multithreading und asynchronem C# Der Unterschied zwischen Multithreading und asynchronem C# Apr 03, 2025 pm 02:57 PM

Der Unterschied zwischen Multithreading und Asynchron besteht darin, dass Multithreading gleichzeitig mehrere Threads ausführt, während asynchron Operationen ausführt, ohne den aktuellen Thread zu blockieren. Multithreading wird für rechenintensive Aufgaben verwendet, während asynchron für die Benutzerinteraktion verwendet wird. Der Vorteil des Multi-Threading besteht darin, die Rechenleistung zu verbessern, während der Vorteil von Asynchron nicht darin besteht, UI-Threads zu blockieren. Die Auswahl von Multithreading oder Asynchron ist von der Art der Aufgabe abhängt: Berechnungsintensive Aufgaben verwenden Multithreading, Aufgaben, die mit externen Ressourcen interagieren und die UI-Reaktionsfähigkeit asynchron verwenden müssen.

See all articles