.Net Core (6.0) 使用 JWT鉴权

本文介绍了如何在.NET中使用Nuget包实现JWT(JSONWebTokens)的生成、加密、解密以及鉴权过程,涉及信息实体、HMACSHA256算法和JsonNet序列化等技术。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、Nuget安装包

2、准备一个信息实体

/// <summary>
/// 信息实体
/// </summary>
class JwtEntity
{
    /// <summary>
    /// id
    /// </summary>
    public string Id { get; set; } = string.Empty;
    /// <summary>
    /// 名称
    /// </summary>
    public string Name { get; set; } = string.Empty;
    /// <summary>
    /// 值
    /// </summary>
    public string Value { get; set; } = string.Empty;
}

3、获取加密后的串

private const string secretKey = "sfdkjskdlfnnierljewlkssjsffd";

/// <summary>
/// 获取字符串
/// </summary>
/// <returns></returns>
public IActionResult GetJwtString()
{
    JwtEntity jwtEntity = new JwtEntity()
    {
        Id = "3",
        Name = "TestName",
        Value = "TestValue"
    };

    byte[] key = Encoding.UTF8.GetBytes(secretKey);
    IJwtAlgorithm algorithm = new HMACSHA256Algorithm();//加密方式
    IJsonSerializer serializer = new JsonNetSerializer();//序列化
    IBase64UrlEncoder urlEncoder = new JwtBase64UrlEncoder();//base64加解密
    IJwtEncoder encoder = new JwtEncoder(algorithm, serializer, urlEncoder);
    string token = encoder.Encode(jwtEntity, key);//生成令牌

    return Ok(token);
}

4、解密字符串的注解

/// <summary>
/// 鉴权注解
/// </summary>
class JwtAuthorityAttribute : Attribute, IAuthorizationFilter
{
    private const string secretKey = "sfdkjskdlfnnierljewlkssjsffd";

    public void OnAuthorization(AuthorizationFilterContext context)
    {
        var httpcontext = context.HttpContext;
        var authHeader = from t in httpcontext.Request.Headers where t.Key == "Authorization" select t.Value.FirstOrDefault();

        string token = authHeader.FirstOrDefault<string>() ?? string.Empty;
        byte[] key = Encoding.UTF8.GetBytes(secretKey);
        IJsonSerializer serializer = new JsonNetSerializer();//序列化
        IDateTimeProvider provider = new UtcDateTimeProvider();
        IJwtValidator validator = new JwtValidator(serializer, provider);
        IBase64UrlEncoder urlEncoder = new JwtBase64UrlEncoder();//base64加解密
        IJwtAlgorithm algorithm = new HMACSHA256Algorithm();//加密方式
        IJwtDecoder decoder = new JwtDecoder(serializer, validator, urlEncoder, algorithm);

        //解密
        JwtEntity jwtEntity = decoder.DecodeToObject<JwtEntity>(token, key, verify: true);

        if (jwtEntity != null)
        {
            //通过
        }
        else
        {
            //不通过
            context.Result = new EmptyResult();
        }
    }

5、将注解放到需要鉴权的方法或者类上,访问此方法将会进入鉴权逻辑

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值