suchen
HeimBackend-EntwicklungC++Wie implementiert man die JWT-Authentifizierung in der ASP.NET-Web-API ohne OWIN-Middleware?

How to Implement JWT Authentication in ASP.NET Web API Without OWIN Middleware?

Implementierung der JWT-Authentifizierung in der ASP.NET-Web-API ohne OWIN-Middleware

In diesem Artikel wird beschrieben, wie die JWT-Authentifizierung in der alten Version der ASP.NET-Web-API ohne OWIN-Middleware implementiert wird. Das Kernprinzip besteht darin, JWT-Tokens auszustellen und diese zu validieren, wenn eine Anfrage eingeht.

Token-Generierungsendpunkt

Stellt einen Token-Endpunkt bereit, über den Benutzer ein JWT-Token erhalten können, z. B. mithilfe einer einfachen Implementierung einer Controller-Aktion:

public class TokenController : ApiController
{
    [AllowAnonymous]
    public string Get(string username, string password)
    {
        if (CheckUser(username, password))
        {
            return JwtManager.GenerateToken(username);
        }

        throw new HttpResponseException(HttpStatusCode.Unauthorized);
    }

    private bool CheckUser(string username, string password)
    {
        // 应在数据库中进行检查
        return true; //  此处应替换为实际的用户验证逻辑
    }
}

Verwenden Sie System.IdentityModel.Tokens.Jwt, um Token zu generieren

Generieren Sie Token mit dem NuGet-Paket System.IdentityModel.Tokens.Jwt und dem symmetrischen Schlüssel HMACSHA256:

/// <summary>
/// 使用以下代码生成对称密钥
///     var hmac = new HMACSHA256();
///     var key = Convert.ToBase64String(hmac.Key);
/// </summary>
private const string Secret = "db3OIsj+BXE9NZDy0t8W3TcNekrF+2d/1sFnWG4HnV8TZY30iTOdtVWJG8abWvB1GlOgJuQZdcF2Luqm/hccMw==";

public static string GenerateToken(string username, int expireMinutes = 20)
{
    var symmetricKey = Convert.FromBase64String(Secret);
    var tokenHandler = new JwtSecurityTokenHandler();

    var now = DateTime.UtcNow;
    var tokenDescriptor = new SecurityTokenDescriptor
    {
        Subject = new ClaimsIdentity(new[]
        {
            new Claim(ClaimTypes.Name, username)
        }),

        Expires = now.AddMinutes(expireMinutes),

        SigningCredentials = new SigningCredentials(
            new SymmetricSecurityKey(symmetricKey),
            SecurityAlgorithms.HmacSha256Signature)
    };

    var stoken = tokenHandler.CreateToken(tokenDescriptor);
    var token = tokenHandler.WriteToken(stoken);

    return token;
}

Authentifizierungsfilter für JWT-Überprüfung verwenden

Erstellen Sie für die JWT-Validierung einen benutzerdefinierten Authentifizierungsfilter, der von IAuthenticationFilter geerbt wurde:

public class ValueController : ApiController
{
    [JwtAuthentication] // 自定义过滤器属性
    public string Get()
    {
        return "value";
    }
}

Implementieren Sie im Authentifizierungsfilter die Verifizierungslogik und geben Sie ClaimsPrincipal zurück:

protected Task<IPrincipal> AuthenticateJwtToken(string token)
{
    string username;

    if (ValidateToken(token, out username))
    {
        // 基于用户名,从数据库获取更多信息以构建本地标识
        var claims = new List<Claim>
        {
            new Claim(ClaimTypes.Name, username)
            // 根据需要添加更多声明:角色等
        };

        var identity = new ClaimsIdentity(claims, "Jwt");
        IPrincipal user = new ClaimsPrincipal(identity);

        return Task.FromResult(user);
    }

    return Task.FromResult<IPrincipal>(null);
}

JWT-Verifizierung mithilfe der JWT-Bibliothek

Um das JWT-Token zu überprüfen und ClaimsPrincipal zu erhalten, können Sie die JWT-Bibliothek verwenden:

public static ClaimsPrincipal GetPrincipal(string token)
{
    try
    {
        var tokenHandler = new JwtSecurityTokenHandler();
        var jwtToken = tokenHandler.ReadToken(token) as JwtSecurityToken;

        if (jwtToken == null)
            return null;

        var symmetricKey = Convert.FromBase64String(Secret);

        var validationParameters = new TokenValidationParameters()
        {
            RequireExpirationTime = true,
            ValidateIssuer = false,
            ValidateAudience = false,
            IssuerSigningKey = new SymmetricSecurityKey(symmetricKey)
        };

        SecurityToken securityToken;
        var principal = tokenHandler.ValidateToken(token, validationParameters, out securityToken);

        return principal;
    }
    catch (Exception)
    {
        // 应写入日志
        return null;
    }
}

Autorisierung

Um anonyme Anfragen zu verhindern, fügen Sie die folgende globale Konfiguration hinzu:

config.Filters.Add(new AuthorizeAttribute());

Postman-Test

Anfordern eines Tokens mit Postman:

<code>GET http://localhost:{port}/api/token?username=cuong&password=1</code>

Verwenden Sie das erhaltene JWT-Token im Header der Autorisierungsanfrage:

<code>GET http://localhost:{port}/api/value

Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1bmlxdWVfbmFtZSI6ImN1b25nIiwibmJmIjoxNDc3NTY1MjU4LCJleHAiOjE0Nzc1NjY0NTgsImlhdCI6MTQ3NzU2NTI1OH0.dSwwufd4-gztkLpttZsZ1255oEzpWCJkayR_4yvNL1s</code>

Bitte beachten Sie, dass die CheckUser Methoden und Fehlerbehandlungsteile im Code entsprechend den tatsächlichen Anwendungen verbessert werden müssen. Secret Schlüssel sollten außerdem an einem sichereren Ort gespeichert werden, anstatt direkt im Code fest codiert zu werden. Dies ist nur ein vereinfachtes Beispiel. In tatsächlichen Anwendungen müssen umfassendere Sicherheits- und Fehlerbehandlungsmechanismen berücksichtigt werden.

Das obige ist der detaillierte Inhalt vonWie implementiert man die JWT-Authentifizierung in der ASP.NET-Web-API ohne OWIN-Middleware?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
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
C# vs. c Leistung: Benchmarking und ÜberlegungenC# vs. c Leistung: Benchmarking und ÜberlegungenApr 25, 2025 am 12:25 AM

Die Leistungsunterschiede zwischen C# und C spiegeln sich hauptsächlich in der Ausführungsgeschwindigkeit und des Ressourcenmanagements wider: 1) C ist normalerweise besser in numerischen Berechnungen und Saitenoperationen funktioniert, da sie näher an Hardware liegt und keinen zusätzlichen Aufwand wie Müllsammlung aufweist. 2) C# ist in der Multi-Thread-Programmierung prägnanter, aber seine Leistung ist bei C etwas unterlegen; 3) Welche Sprache zu wählen, sollte anhand der Projektanforderungen und dem Teamtechnologie -Stack ermittelt werden.

C: Stirbend oder einfach weiterentwickelt?C: Stirbend oder einfach weiterentwickelt?Apr 24, 2025 am 12:13 AM

C isnotdying;

C in der modernen Welt: Anwendungen und BranchenC in der modernen Welt: Anwendungen und BranchenApr 23, 2025 am 12:10 AM

C ist in der modernen Welt weit verbreitet und wichtig. 1) In der Spielentwicklung wird C häufig für seine hohe Leistung und Polymorphismus wie Uneralengine und Unity verwendet. 2) In Finanzhandelssystemen machen Cs niedriger Latenz und hoher Durchsatz die erste Wahl, die für den Hochfrequenzhandel und die Echtzeitdatenanalyse geeignet ist.

C XML -Bibliotheken: Vergleich und KontrastoptionenC XML -Bibliotheken: Vergleich und KontrastoptionenApr 22, 2025 am 12:05 AM

Es gibt vier häufig verwendete XML-Bibliotheken in C: TinyXML-2, Pugixml, Xerces-C und RapidXML. 1.Tinyxml-2 eignet sich für Umgebungen mit begrenzten Ressourcen, leichten, aber begrenzten Funktionen. 2. Pugixml ist schnell und unterstützt die XPath -Abfrage, geeignet für komplexe XML -Strukturen. 3.xerces-c ist leistungsstark, unterstützt die DOM- und SAX-Auflösung und ist für die komplexe Verarbeitung geeignet. 4..

C und XML: Erforschen der Beziehung und UnterstützungC und XML: Erforschen der Beziehung und UnterstützungApr 21, 2025 am 12:02 AM

C interagiert mit XML über Bibliotheken von Drittanbietern (wie Tinyxml, Pugixml, Xerces-C). 1) Verwenden Sie die Bibliothek, um XML-Dateien zu analysieren und in C-verarbeitbare Datenstrukturen umzuwandeln. 2) Konvertieren Sie beim Generieren von XML die C -Datenstruktur in das XML -Format. 3) In praktischen Anwendungen wird XML häufig für Konfigurationsdateien und Datenaustausch verwendet, um die Entwicklungseffizienz zu verbessern.

C# gegen C: Verständnis der wichtigsten Unterschiede und ÄhnlichkeitenC# gegen C: Verständnis der wichtigsten Unterschiede und ÄhnlichkeitenApr 20, 2025 am 12:03 AM

Die Hauptunterschiede zwischen C# und c sind Syntax-, Leistungs- und Anwendungsszenarien. 1) Die C# -Syntax ist prägnanter, unterstützt die Müllsammlung und eignet sich für .NET Framework -Entwicklung. 2) C hat eine höhere Leistung und erfordert eine manuelle Speicherverwaltung, die häufig bei der Systemprogrammierung und der Spieleentwicklung verwendet wird.

C# gegen C: Geschichte, Evolution und ZukunftsaussichtenC# gegen C: Geschichte, Evolution und ZukunftsaussichtenApr 19, 2025 am 12:07 AM

Die Geschichte und Entwicklung von C# und C sind einzigartig, und auch die Zukunftsaussichten sind unterschiedlich. 1.C wurde 1983 von Bjarnestrustrup erfunden, um eine objektorientierte Programmierung in die C-Sprache einzuführen. Sein Evolutionsprozess umfasst mehrere Standardisierungen, z. B. C 11 Einführung von Auto-Keywords und Lambda-Ausdrücken, C 20 Einführung von Konzepten und Coroutinen und sich in Zukunft auf Leistung und Programme auf Systemebene konzentrieren. 2.C# wurde von Microsoft im Jahr 2000 veröffentlicht. Durch die Kombination der Vorteile von C und Java konzentriert sich seine Entwicklung auf Einfachheit und Produktivität. Zum Beispiel führte C#2.0 Generics und C#5.0 ein, die eine asynchrone Programmierung eingeführt haben, die sich in Zukunft auf die Produktivität und das Cloud -Computing der Entwickler konzentrieren.

C# gegen C: Lernkurven und EntwicklererfahrungC# gegen C: Lernkurven und EntwicklererfahrungApr 18, 2025 am 12:13 AM

Es gibt signifikante Unterschiede in den Lernkurven von C# und C- und Entwicklererfahrung. 1) Die Lernkurve von C# ist relativ flach und für rasche Entwicklung und Anwendungen auf Unternehmensebene geeignet. 2) Die Lernkurve von C ist steil und für Steuerszenarien mit hoher Leistung und niedrigem Level geeignet.

See all articles

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

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

SublimeText3 Englische Version

SublimeText3 Englische Version

Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

SAP NetWeaver Server-Adapter für Eclipse

SAP NetWeaver Server-Adapter für Eclipse

Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor