溫馨提示×

c# jwtbuilder如何實現安全認證

c#
小樊
99
2024-12-12 23:13:10
欄目: 編程語言

在C#中,使用JWT(JSON Web Token)進行安全認證是一個常見的需求。為了實現這一目標,你可以使用一些流行的庫,如System.IdentityModel.Tokens.JwtMicrosoft.IdentityModel.Tokens。以下是一個簡單的示例,展示了如何使用這些庫來創建和驗證JWT令牌。

1. 安裝必要的NuGet包

首先,你需要安裝以下NuGet包:

Install-Package System.IdentityModel.Tokens.Jwt
Install-Package Microsoft.IdentityModel.Tokens

2. 創建JWT令牌

以下是一個示例代碼,展示了如何使用System.IdentityModel.Tokens.Jwt創建一個JWT令牌:

using System;
using System.IdentityModel.Tokens.Jwt;
using System.Security.Claims;
using System.Text;
using Microsoft.IdentityModel.Tokens;

public class JwtTokenUtil
{
    private const string SecretKey = "你的密鑰"; // 用于簽名和驗證JWT的密鑰
    private const string Issuer = "你的發行者"; // JWT的發行者
    private const string Audience = "你的受眾"; // JWT的受眾

    public static string CreateJwtToken(Claim[] claims, int expirationMinutes = 30)
    {
        var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(SecretKey));
        var signinCredentials = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);

        var jwtToken = new JwtSecurityToken(
            issuer: Issuer,
            audience: Audience,
            claims: claims,
            expires: DateTime.UtcNow.AddMinutes(expirationMinutes),
            signingCredentials: signinCredentials
        );

        return new JwtSecurityTokenHandler().WriteToken(jwtToken);
    }
}

3. 驗證JWT令牌

以下是一個示例代碼,展示了如何使用Microsoft.IdentityModel.Tokens驗證JWT令牌:

using System;
using System.IdentityModel.Tokens.Jwt;
using System.Security.Claims;
using System.Threading.Tasks;
using Microsoft.IdentityModel.Tokens;

public class JwtTokenValidator
{
    private const string SecretKey = "你的密鑰"; // 用于簽名和驗證JWT的密鑰
    private const string Issuer = "你的發行者"; // JWT的發行者
    private const string Audience = "你的受眾"; // JWT的受眾

    public async Task<ClaimsPrincipal> ValidateJwtTokenAsync(string token)
    {
        var validationParameters = new TokenValidationParameters
        {
            ValidateIssuer = true,
            ValidIssuer = Issuer,
            ValidateAudience = true,
            ValidAudience = Audience,
            ValidateIssuerSigningKey = true,
            IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(SecretKey)),
            ValidateLifetime = true,
            ClockSkew = TimeSpan.Zero
        };

        var jwtSecurityTokenHandler = new JwtSecurityTokenHandler();
        var principal = await jwtSecurityTokenHandler.ValidateTokenAsync(token, validationParameters, out SecurityToken validatedToken);

        return principal;
    }
}

4. 使用示例

以下是如何使用上述類的示例:

class Program
{
    static void Main(string[] args)
    {
        // 創建JWT令牌
        var claims = new Claim[]
        {
            new Claim(ClaimTypes.Name, "John Doe"),
            new Claim(ClaimTypes.Email, "john.doe@example.com")
        };
        var token = JwtTokenUtil.CreateJwtToken(claims);
        Console.WriteLine("Generated JWT Token: " + token);

        // 驗證JWT令牌
        var validator = new JwtTokenValidator();
        var principal = validator.ValidateJwtTokenAsync(token).Result;
        Console.WriteLine("Validated Principal: " + principal.FindFirstValue(ClaimTypes.Name));
    }
}

總結

通過上述步驟,你可以在C#中使用JWT進行安全認證。確保你的密鑰是安全的,并且不要在代碼中硬編碼敏感信息。在實際應用中,你可能需要根據具體需求調整代碼,例如添加更多的驗證參數或處理異常情況。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女