ASP.NET Core MVC 项目 MinimalApi 鉴权授权

目录

一:引用Microsoft.AspNetCore.Authentication.JwtBearer

二:添加JWTTokenOptions类

三:修改Program.cs文件

四:配置appsettings.json文件

五:扩展IAuthorizeDate

六:修改OrderMinimalApi


一:引用Microsoft.AspNetCore.Authentication.JwtBearer

当前项目右键管理NuGet包。

搜索Microsoft.AspNetCore.Authentication.JwtBearer,选择6.0版本的进行安装。

搜索Microsoft.AspNetCore.Authorization进行安装。

二:添加JWTTokenOptions类

namespace Study_ASP.NET_Core_MVC.WebApi.Utility
{
    public class JWTTokenOptions
    {
        public string Audience { get; set; }
        public string SecurityKey { get; set; }
        public string Issuer { get; set; }
    }
}

三:修改Program.cs文件

using Microsoft.AspNetCore.Authentication.JwtBearer;
using Microsoft.IdentityModel.Tokens;
using Study_ASP.Net_Core_MVC.Services;
using Study_ASP.NET_Core_MVC.Interfaces;
using Study_ASP.NET_Core_MVC.MinimalApi;
using Study_ASP.NET_Core_MVC.MinimalApi.Utility;
using System.Text;

//表示整个应用程序,调用CreateBuilder方法创建一个WebApplicationBuilder对象
var builder = WebApplication.CreateBuilder(args);

//向管道容器添加注册中间件
//添加注册Swagger中间件
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();


//配置JWT鉴权
JWTTokenOptions tokenOptions = new JWTTokenOptions();
builder.Configuration.Bind("JWTTokenOptions", tokenOptions);
builder.Services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme).AddJwtBearer(options =>
{
    options.TokenValidationParameters = new TokenValidationParameters
    {
        //JWT默认属性  
        //是否验证Issuer
        ValidateIssuer = true,
        //是否验证Audience
        ValidateAudience = true,
        //似乎否验证失效时间  
        ValidateLifetime = true,
        //是否验证SecurityKey
        ValidateIssuerSigningKey = true,
        //与签发JWT设置一致
        ValidAudience = tokenOptions.Audience,
        //与签发JWT设置一致
        ValidIssuer = tokenOptions.Issuer,
        //获取SecurityKey
        IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(tokenOptions.SecurityKey))
    };
});
//配置JWT授权
builder.Services.AddAuthorization();
//注册Interfaces服务中间件
builder.Services.AddTransient<IPhone, ApplePhone>();

//初始化管道
var app = builder.Build();

//配置HTTP请求管道判断开发者模式
if (app.Environment.IsDevelopment())
{
    app.UseSwagger();
    app.UseSwaggerUI();
}
//向管道添加用于将HTTP请求重定向到HTTPS的中间件
app.UseHttpsRedirection();
//向管道添加用于身份鉴权授权中间件
app.UseAuthentication();
app.UseAuthorization();
//注册OrderMinimalApi中间件
app.OrderMinimalApiExtension();
//注册ProductMinimalApi中间件
app.ProductMinimalApiExtension();

//向管道添加启动应用程序中间件
app.Run();

四:配置appsettings.json文件

{
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft.AspNetCore": "Warning"
    }
  },
  "AllowedHosts": "*",
  "JWTTokenOptions": {
    "Audience": "http://localhost:5200",
    "Issuer": "http://localhost:5200",
    "SecurityKey": "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDI2a2EJ7m872v0afyoSDJT2o1+SitIeJSWtLJU8/Wz2m7gStexajkeD+Lka6DSTy8gt9UwfgVQo6uKjVLG5Ex7PiGOODVqAEghBuS7JzIYU5RvI543nNDAPfnJsas96mSA7L/mD7RTE2drj6hf3oZjJpMPZUQI/B1Qjb5H3K3PNwIDAQAB"
  }
}

五:扩展IAuthorizeDate

using Microsoft.AspNetCore.Authorization;

namespace Study_ASP.NET_Core_MVC.MinimalApi.Utility
{
    public class CustomAuthorizeData: IAuthorizeData
    {
        public string? Policy { get; set; }
        public string? Roles { get; set; }
        public string? AuthenticationSchemes { get; set; }
    }
}

六:修改OrderMinimalApi

using Microsoft.AspNetCore.Authentication.JwtBearer;
using Study_ASP.NET_Core_MVC.Interfaces;
using Study_ASP.NET_Core_MVC.MinimalApi.Utility;

namespace Study_ASP.NET_Core_MVC.MinimalApi
{
    public static class OrderMinimalApi
    {
        public static void OrderMinimalApiExtension(this WebApplication app)
        {
            //向管道添加MapGet请求数据中间件返回新数据
            //上下文注入、参数注入、Service服务注入
            app.MapGet("/CreateOrder", (HttpContext context, int Id, IPhone iPhone) =>
            {
                //获取上下文
                var QueryText = context.Request.Query;
                //获取参数
                var OrderId = Id;
                //获取Service服务
                var iPhone1 = iPhone;
                //返回数据
                return new
                {
                    Id = 123,
                    Name = "VinCente",
                    Age = 28
                };
            }).WithTags("Order").RequireAuthorization(new CustomAuthorizeData()
            {
                AuthenticationSchemes = JwtBearerDefaults.AuthenticationScheme
            });
            //向管道添加MapPost请求数据中间件返回新增操作成功
            app.MapPost("/AddOrder", () =>
            {
                return new
                {
                    Success = true,
                    Message = "新增操作成功"
                };
            }).WithTags("Order");
            //向管道添加MapPut请求数据中间件返回修改操作成功
            app.MapPut("/UpdateOrder", () =>
            {
                return new
                {
                    Success = true,
                    Message = "修改操作成功"
                };
            }).WithTags("Order");
            //向管道添加MapDelete请求数据中间件返回删除操作成功
            app.MapDelete("/DeleteOrder", () =>
            {
                return new
                {
                    Success = true,
                    Message = "删除操作成功"
                };
            }).WithTags("Order");
        }
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: ASP.NET Core MVC 是微软推出的一个用于开发 web 应用程序的框架。它基于 ASP.NET Core 技术,提供了一组强大的工具和技术,用于构建高性能、可扩展、可靠的 web 应用程序。ASP.NET Core MVC 具有模型-视图-控制器(MVC)设计模式,可以让开发人员快速构建高质量的 web 应用程序。 ### 回答2: ASP.NET Core MVC项目是一种现代化、高效率、跨平台的Web应用程序框架。它是建立在.Net Core平台之上,兼具ASP.NET MVC的优势与.Net Core的优势,可以轻松快捷地构建出高性能、稳定可靠、易于维护的Web应用程序。 ASP.NET Core MVC项目具有以下几个特点: 1. 跨平台: ASP.NET Core MVC项目可以运行在Windows、Linux和Mac OS等不同的操作系统上,且可以通过基于Docker容器的方式在不同的环境中快速的运行和部署。 2. 高效率: ASP.NET Core MVC项目可以使用配置简单、易于使用的路由机制,使得开发人员可以快速地创建出易于维护和扩展的Web应用程序。 另外,它还引入了TagHelpers、ViewComponents和可重用的View模块化组件等开发人员喜爱的实用功能。 3. 开放式架构: ASP.NET Core MVC项目可以与其它第三方框架和第三方库结合,在实现业务需求的同时减少重复性劳动,提高开发效率。 4. 集成式部署: 我们可以使用IIS,Nginx或Apache来部署ASP.NET Core MVC项目。此外,ASP.NET Core MVC还提供了一些特殊的扩展方案,例如部署到云端(如Azure)等。 ASP.NET Core MVC项目是给开发人员使用的,因为它具有良好的可拓展性,可以为客户或企业提供快速而稳定的Web应用程序解决方案。此外,ASP.NET Core MVC项目不仅适用于中小型项目,也适用于大型项目。 它支持各种Web应用和API。 ### 回答3: ASP.NET Core MVC项目是基于 .NET Core 构建的的一种Web应用程序开发框架,是微软为开发一系列新技术而推出的一个全新的开发平台,可用于开发跨平台Web应用程序、Web API和微服务。 ASP.NET Core MVC提供了丰富的特性和功能,包括路由、视图、模型绑定、过滤器、控制器等。在不同于传统的ASP.NET Web应用框架中,ASP.NET Core MVC允许开发者通过配置等方式更加灵活地控制框架的行为,提高了框架的可扩展性和可维护性,同时更加便于与中间件、云等其他技术集成。因此,ASP.NET Core MVC具备了更高的性能、更好的可扩展性和更丰富的工具。 ASP.NET Core MVC还提供了一个简单易用的依赖注入系统,可以用于管理应用程序中各个部分之间的依赖关系,并且还支持多种不同的IoC容器,如Autofac、Unity和Simple Injector等。此外,它也支持不同的数据存储方式,如ORM工具Entity Framework Core、MongoDB和Redis等。 总而言之,ASP.NET Core MVC项目提供了先进而强大的开发工具,使得开发者可以更加高效地构建出安全可靠、性能优异、高度可扩展的Web应用程序。同时,它也是一种不断发展和完善的技术,具备更多的优势将在其未来的发展中得以充分展现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Vin Cente

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值