ASP.NETCore项目中是否有更好的使用Windows身份验证联合JWTWebToken构建身份验证服务的方法?
创始人
2024-09-18 11:30:39
0

在ASP.NET Core项目中,可以使用Microsoft.AspNetCore.Authentication.JwtBearer扩展来处理JWT Token,同时使用Windows身份验证。

首先安装必要的包:

dotnet add package Microsoft.AspNetCore.Authentication.JwtBearer
dotnet add package Microsoft.AspNetCore.Authentication.Negotiate

接下来,在Startup.cs文件中进行以下配置:

public void ConfigureServices(IServiceCollection services)
{
    // ......省略其他配置

    // 配置 JWT Token 验证
    services.AddAuthentication(options =>
    {
        options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
        options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
    })
    .AddJwtBearer(options =>
    {
        options.RequireHttpsMetadata = false;  // 注意:仅用于测试/开发环境
        options.TokenValidationParameters = new TokenValidationParameters
        {
            ValidateIssuer = true,
            ValidateAudience = true,
            ValidateLifetime = true,
            ValidateIssuerSigningKey = true,
            ValidIssuer = Configuration["Jwt:Issuer"],
            ValidAudience = Configuration["Jwt:Audience"],
            IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(Configuration["Jwt:SecretKey"]))
        };
    })
    .AddNegotiate();  // 启用 Windows 身份验证
}

其中,JwtBearerDefaults.AuthenticationScheme指定了JWT Token的验证方式,AddJwtBearer方法用于配置JWT验证的参数。在上述方法中,我们启用了以下几个验证项:

  • ValidateIssuer:验证颁发JWT Token的Issuer;
  • ValidateAudience:验证JWT Token的Audience;
  • ValidateLifetime:验证JWT Token是否过期;
  • ValidateIssuerSigningKey:验证JWT Token使用的签名密钥。

此外,还需要指定JWT Token的Issuer、Audience和秘钥等信息,这些信息可以在appsettings.json文件中进行配置。

在控制器中,可以使用[Authorize]特性来保护需要权限认证的API接口:

[Authorize(AuthenticationSchemes = JwtBearerDefaults.AuthenticationScheme + "," + NegotiateDefaults.AuthenticationScheme)]
public class SomeController : Controller
{
    // ......省略其他接口

    [HttpGet("some-protected-api")]
    public IActionResult SomeProtectedApi()
    {
        return Ok("这是一个需要权限认证的API接口");
    }
}

在API调用时,需要在HTTP Header中携带JWT Token,例如:

GET /

相关内容

热门资讯

透视揭露!wepoker辅助脚... 透视揭露!wepoker辅助脚本,wepoker私人局透视-确实是真的有辅助神器(哔哩哔哩)1、下载...
透视科普!wpk透视是真的假的... 透视科普!wpk透视是真的假的,wpk软件是正规的吗-真是存在有辅助软件(哔哩哔哩)1、金币登录送、...
透视解密!wepoker辅助真... 透视解密!wepoker辅助真的假的,We poker辅助器下载-真是真的有辅助神器(哔哩哔哩)亲,...
透视推荐!hhpoker辅助软... 透视推荐!hhpoker辅助软件,hhpoker德州有挂吗-果然是有辅助神器(哔哩哔哩)1、模拟器是...
透视科普!wpk透视是真的假的... 透视科普!wpk透视是真的假的,wpk辅助器是真的吗-真是是真的有辅助攻略(哔哩哔哩)1、有没有辅助...
透视曝光!wepoker可以透... 透视曝光!wepoker可以透视码,wejoker内置辅助-本来有辅助教程(哔哩哔哩)1、该软件可以...
透视揭露!wepoker破解工... 透视揭露!wepoker破解工具,wepoker怎么设置盖牌-本来一直总是有辅助方法(哔哩哔哩)1、...
透视有挂!有哪些免费的wpk作... 透视有挂!有哪些免费的wpk作弊码,wpk辅助器是真的吗-果然一直总是有辅助脚本(哔哩哔哩)1、公共...
透视关于!德扑圈透视挂,德普之... 透视关于!德扑圈透视挂,德普之星透视辅助-好像是真的有辅助软件(哔哩哔哩)脚本下载中分为三种模型:挂...
透视解密!德普辅助器怎么用,德... 透视解密!德普辅助器怎么用,德普之星透视-好像是有辅助app(哔哩哔哩)1、完成辅助器v3.3的残局...