legongju.com
我们一直在努力
2025-01-12 22:49 | 星期天

如何在C#中生成和使用token

在C#中生成和使用token通常涉及到身份验证和授权

  1. 安装System.IdentityModel.Tokens.Jwt和Microsoft.IdentityModel.Tokens包。在.NET项目中,打开NuGet包管理器控制台并运行以下命令:
Install-Package System.IdentityModel.Tokens.Jwt
Install-Package Microsoft.IdentityModel.Tokens
  1. 创建一个方法来生成token。首先,需要创建一个RSA(非对称加密)密钥对。可以使用以下代码生成密钥对并将其保存为XML字符串:
using System.Security.Cryptography;

private static string GenerateKeyPair()
{
    using (var rsa = new RSACryptoServiceProvider(2048))
    {
        return rsa.ToXmlString(true);
    }
}
  1. 使用以下代码生成token:
using System;
using System.IdentityModel.Tokens.Jwt;
using System.Security.Claims;
using Microsoft.IdentityModel.Tokens;

public static string GenerateToken(string keyPair, string issuer, string audience, int expirationMinutes)
{
    var securityKey = new RsaSecurityKey(new RSACryptoServiceProvider().FromXmlString(keyPair));
    var signingCredentials = new SigningCredentials(securityKey, SecurityAlgorithms.RsaSha256Signature);

    var claims = new[]
    {
        new Claim(JwtRegisteredClaimNames.Sub, "your_subject"),
        new Claim(JwtRegisteredClaimNames.Jti, Guid.NewGuid().ToString())
    };

    var jwt = new JwtSecurityToken(
        issuer: issuer,
        audience: audience,
        claims: claims,
        notBefore: DateTime.UtcNow,
        expires: DateTime.UtcNow.AddMinutes(expirationMinutes),
        signingCredentials: signingCredentials);

    return new JwtSecurityTokenHandler().WriteToken(jwt);
}
  1. 验证和解析token:
public static ClaimsPrincipal ValidateToken(string token, string keyPair, string issuer, string audience)
{
    var validationParameters = new TokenValidationParameters
    {
        ValidateIssuer = true,
        ValidIssuer = issuer,
        ValidateAudience = true,
        ValidAudience = audience,
        ValidateIssuerSigningKey = true,
        IssuerSigningKey = new RsaSecurityKey(new RSACryptoServiceProvider().FromXmlString(keyPair))
    };

    var jwtSecurityTokenHandler = new JwtSecurityTokenHandler();
    var principal = jwtSecurityTokenHandler.ValidateToken(token, validationParameters, out _);

    return principal;
}
  1. 在你的应用程序中使用这些方法。例如,在ASP.NET Core Web API中,可以在登录方法中生成token,并在需要身份验证的API方法中验证token。

生成token:

var keyPair = GenerateKeyPair();
var token = GenerateToken(keyPair, "issuer", "audience", 60);

验证token:

var principal = ValidateToken(token, keyPair, "issuer", "audience");
if (principal != null)
{
    // Token is valid, proceed with the authorized operation
}
else
{
    // Token is invalid, deny access
}

注意:在实际应用中,不要在内存中存储密钥对,而是将其安全地存储在配置文件或环境变量中。此外,确保在生产环境中使用更长的过期时间。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/104962.html

相关推荐

  • c++ hashmap用法是什么

    c++ hashmap用法是什么

    在C++中,hash_map 是一个非标准的容器,它提供了基于哈希表的键值对存储。然而,需要注意的是,自从C++11起,hash_map已经被废弃,并在C++17中被移除。取而代之...

  • C#中token是什么及其作用

    C#中token是什么及其作用

    在C#中,token通常指的是一个代表特定字符串或数据的标识符 身份验证和授权:在许多Web应用程序和API中,使用令牌(如JWT,JSON Web Token)进行身份验证和授权。...

  • 在C#中如何对token进行加密

    在C#中如何对token进行加密

    在C#中,对token进行加密通常使用的是对称加密算法,如AES(Advanced Encryption Standard)。以下是一个使用AES加密和解密token的示例:
    首先,需要引入Sy...

  • C#中token传递方式有哪些

    C#中token传递方式有哪些

    在C#中,token传递方式主要有以下几种: 查询字符串(Query String):将token作为URL的一部分,通过查询字符串传递。这种方式简单易用,但不太安全,因为URL可能...

  • 如何在C#中使用数据绑定进行数据校验

    如何在C#中使用数据绑定进行数据校验

    在C#中,数据绑定和数据校验通常与Windows Forms或WPF应用程序一起使用 创建一个数据模型类,该类将表示要绑定的数据。在这个例子中,我们将创建一个Person类: ...

  • C#中数据绑定与事件处理的结合

    C#中数据绑定与事件处理的结合

    在C#中,数据绑定和事件处理是两个不同的概念,但它们经常一起使用以实现更复杂的功能。数据绑定是将数据源(如数据库、对象或集合)与用户界面(UI)元素(如文...

  • 在C#中如何实现双向数据绑定

    在C#中如何实现双向数据绑定

    在C#中,双向数据绑定通常在WPF(Windows Presentation Foundation)或UWP(Universal Windows Platform)应用程序中使用 首先,创建一个Model类,它将作为数据源...

  • C#中数据绑定性能优化方法

    C#中数据绑定性能优化方法

    在C#中,数据绑定性能优化是一个重要的话题,因为它可以直接影响到应用程序的响应速度和用户体验。以下是一些建议和技巧,可以帮助你优化C#中的数据绑定性能: 使...