Custom Lifetime Validation With AspNet.Security.OpenIdConnect.Server (ASP.NET vNext)

前端 未结 1 2015
隐瞒了意图╮
隐瞒了意图╮ 2021-01-25 06:46

I am using Visual Studio 2015 Enterprise Update 1 and ASP.NET vNext rc1-update1 to issue and consume JWT tokens as described here.

In our implementation we want to contr

1条回答
  •  太阳男子
    2021-01-25 07:26

    Edit: this bug was fixed in ASP.NET Core RC2. The workaround described in this answer is no longer needed.


    It's a known bug. Sadly, the workaround you could use in beta8 no longer works in RC1.

    Your only option is to write a middleware catching the exception to prevent the server from returning a 500 response. Of course, it's ugly and will potentially hide important exceptions, but it's the only known workaround that works with RC1.

    Here's an example (make sure to register it before the JWT bearer middleware):

    app.Use(next => async context => {
        try {
            await next(context);
        }
    
        catch {
            // If the headers have already been sent, you can't replace the status code.
            // In this case, throw an exception to close the connection.
            if (context.Response.HasStarted) {
                throw;
            }
    
            context.Response.StatusCode = 401;
        }
    });
    

    0 讨论(0)
提交回复
热议问题