如何在OWIN中间件中捕获SecurityTokenExpiredException?

我有一个带有OWIN的Web API,它使用JwtBearerAuthenticationOptions (.Net Framework4.5.2)来验证身份验证令牌。

在遵循Rui Figueiredo的this excellent article以便向API添加刷新令牌功能时,我似乎在OWIN中没有JwtBearerEvents。例如,这段代码适用于我在ASP.NET核心中(在ConfigureServices中):

services.AddAuthentication(x =>
{
    x.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
    x.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
})
.AddJwtBearer(x =>
{
    x.RequireHttpsMetadata = false;
    x.SaveToken = true;
    x.TokenValidationParameters = GetDefaultValidationParameters();
    x.Events = new JwtBearerEvents
    {
        OnAuthenticationFailed = context =>
        {
            if (context.Exception.GetType() == typeof(SecurityTokenExpiredException))
            {
                context.Response.Headers.Add("Token-Expired", "true");
            }
            return Task.CompletedTask;
        }
    };
});

似乎不能掌握如何使用OWIN管道来实现同样的效果。我尝试过的是在ConfigureAuth中插入一个中间件:

private static void ConfigureAuth(IAppBuilder pApp)
{
    pApp.Use(async (context, next) =>
    {
        try
        {
            await next.Invoke();
        }
        catch (SecurityTokenExpiredException)
        {
            context.Response.Headers.Add("Token - Expired", new[] { "true" });
            throw;
        }
    });
    var issuer = "issuer";
    var audience = "all";
    var key = Encoding.ASCII.GetBytes("MySecretKey");
    pApp.UseJwtBearerAuthentication(
        new JwtBearerAuthenticationOptions
        {
            AuthenticationMode = Microsoft.Owin.Security.AuthenticationMode.Active,
            AllowedAudiences = new[] { audience },
            IssuerSecurityKeyProviders = new IIssuerSecurityKeyProvider[]
            {
                new SymmetricKeyIssuerSecurityKeyProvider(issuer, key)
            },
            TokenValidationParameters = tokenValidationParameters,
            TokenHandler = new CustomJWTTokenHandler()
        });
}

变更为:
基本控制器中添加了一个自定义授权属性,即:

public class CustomAuthorization : AuthorizeAttribute
{
    protected override void HandleUnauthorizedRequest(HttpActionContext actionContext)
    {
        base.HandleUnauthorizedRequest(actionContext);
        var ctx = actionContext;
        var token = ctx.Request.Headers.Authorization.Parameter;
        var handler = new CustomJWTTokenHandler();
        if (ctx.Response.StatusCode == HttpStatusCode.Unauthorized && handler.TokenHasExpired(token))
        {
            ctx.Response.Headers.Add("Token-Expired", "true");
        }
    }
}

并在我的CustomJWTTokenHandler类中实现了一个过期检查,如下所示:

public bool TokenHasExpired(string tokenString)
{
    var token = ReadToken(tokenString);
    var hasExpired = token.ValidTo < DateTime.UtcNow;
    return hasExpired;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OWIN(Open Web Interface for .NET)是一个开放的、标准的.NET Web应用程序接口,它允许应用程序自由地选择它们的Web服务器。OWIN 可以与几乎所有 Web 服务器集成,包括 IIS、Apache、Nginx 等。 要在 WinForms 应用程序使用 OWIN,您需要按照以下步骤操作: 1. 添加 Microsoft.Owin.Host.HttpListener 包。可以使用 NuGet 包管理器来添加该包。 2. 创建一个 OWIN 启动类。这个类必须包含一个名为 Configuration 的方法,它将接收一个 IAppBuilder 对象作为参数。在此方法,您可以配置 OWIN 中间件和 Web API。 3. 在您的 WinForms 应用程序创建一个 HttpListener 对象,并将它传递给 OWIN。这样就可以在您的应用程序运行 OWIN 服务器了。 下面是一个简单的示例,演示如何在 WinForms 应用程序使用 OWIN: ```csharp using System; using System.Net; using System.Threading.Tasks; using System.Windows.Forms; using Microsoft.Owin.Hosting; namespace WinFormsOWIN { public partial class Form1 : Form { private IDisposable _webApp; public Form1() { InitializeComponent(); } private void btnStart_Click(object sender, EventArgs e) { // 启动 OWIN 服务器 _webApp = WebApp.Start<Startup>("http://localhost:8080"); MessageBox.Show("OWIN 服务器已启动"); } private void btnStop_Click(object sender, EventArgs e) { // 停止 OWIN 服务器 _webApp?.Dispose(); MessageBox.Show("OWIN 服务器已停止"); } } public class Startup { public void Configuration(IAppBuilder app) { // 配置 OWIN 中间件和 Web API app.UseWelcomePage("/"); app.Run(context => { context.Response.ContentType = "text/plain"; return context.Response.WriteAsync("Hello, OWIN!"); }); } } } ``` 在此示例,我们创建了一个名为 Form1 的 WinForms 窗体,并添加了两个按钮:btnStart 和 btnStop。当用户单击 btnStart 按钮时,我们将启动 OWIN 服务器,并将其绑定到 http://localhost:8080。当用户单击 btnStop 按钮时,我们将关闭 OWIN 服务器。 在 Startup 类,我们配置了一个简单的 OWIN 中间件来响应根路径(/)的请求,并返回 "Hello, OWIN!"。您可以根据需要添加其他中间件和 Web API。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值