.NET Core JWT

å¨è¿éæå¥å¾çæè¿°

标准中注册的声明:

iss:jwt签发者
sub:jwt所面向的用户
aud:接收jwt的一方
exp:jwt的过期时间,这个过期时间必须要大于签发时间
nbf:定义在什么时间之前,该jwt都是不可用的
iat:jwt的签发时间
jti:jwt的唯一身份标识,主要用来作为一次性的token,从而回避重放攻击。

以上是转发别的博客

1.导入jwt包

2.staup 设置 

//启用api认证
            services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme).AddJwtBearer(
                option =>
                {
                    var secretByte = Encoding.UTF8.GetBytes(_configuration["Authentication:SecretKey"]);
                    option.TokenValidationParameters = new TokenValidationParameters()
                    {
                        //只有我们的接口后端的发出的接口才能访问
                        ValidateIssuer = true,
                        ValidIssuer = _configuration["Authentication:Issuer"],
                        //验证token的持有者
                        ValidateAudience = true,
                        ValidAudience = _configuration["Authentication:Audience"],
                        //验证token是否过期
                        ValidateLifetime = true,
                        //token私钥传入进来进行加密
                        IssuerSigningKey = new SymmetricSecurityKey(secretByte)
                    };
                }
            );

 app.UseAuthentication();//认证
 app.UseAuthorization();//授权

3.配置appsetting.json 

 

4. 在控制器编码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using FakeXiecheng.API.Dtos;
using Microsoft.IdentityModel.Tokens;
using System.Security.Claims;
using System.IdentityModel.Tokens.Jwt;
using Microsoft.Extensions.Configuration;
using System.Text;

namespace FakeXiecheng.API.Controllers
{
    [Route("auth")]
    [ApiController]
    public class AuthenticateController : ControllerBase
    {
        //读取json的
        private readonly IConfiguration _configuration;
        public AuthenticateController(IConfiguration configuration)
        {
            _configuration = configuration;
        }
        //任何人都可以访问
        [AllowAnonymous]
        [HttpPost("login")]
        public IActionResult Login([FromBody] LoginDto loginDto)
        {
            //1. 验证用户名密码
            //2. 创建jwt
            //header
            var singingAlgorithm = SecurityAlgorithms.HmacSha256;
            //payload
            var claims = new[] { 
            //sub
            new Claim(JwtRegisteredClaimNames.Sub,"fake_user_id")
            };
            //signiture
            var secretByte = Encoding.UTF8.GetBytes(_configuration["Authentication:SecretKey"]);
            var signingkey = new SymmetricSecurityKey(secretByte);
            var singingCredentials = new SigningCredentials(signingkey,singingAlgorithm);
            var token = new JwtSecurityToken(
                issuer:_configuration["Authentication:Issuer"],
                audience: _configuration["Authentication:Audience"],
                claims,
                notBefore:DateTime.UtcNow,
                expires:DateTime.UtcNow.AddDays(1),
                singingCredentials
                );
            //输出token字符串
          var tokenStr = new JwtSecurityTokenHandler().WriteToken(token);
            //3.返回200 OK +jwt
            return Ok(tokenStr);
           
        }
    }
}

5. 在需要验证的控制器加上

[Authorize(AuthenticationSchemes = "Bearer")]

验证 jwt是否成功,在该控制的方法上请求看返回的结果是否成功、

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值