c# - 使用授权 header 重定向到操作

标签 c# asp.net-core asp.net-core-mvc jwt

我有一个简单的“门”方法,它确定用户的 jwt token 是否有效,然后将他重定向到某个操作

我有两个端点需要授权,

  • 其中一个只是用来判断token是否ok(否则返回401,是则OK)

  • 第二个是需要有效 token 的保护区

我的问题是第一个端点返回该 token 是好的,但第二个端点返回 401

因为“解决方法”是:返回 View 而不是操作

我意识到我忘记了授权 header ,但是

how to add headers to redirect to action?

return redirect to action 而不是 View 很重要,因为 View 浏览器显示旧 url,在这种情况下是 localhost/Gate 而不是 localhost/授权

public async Task<IActionResult> Gate()
{
    var token = ExtractToken();

    HttpClient client = new HttpClient();
    client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
    client.DefaultRequestHeaders.Add("Authorization", $"Bearer {token}");
    var get = client.GetAsync($"https://localhost:12345/TokenValidator").Result;

    switch (get.StatusCode)
    {
        case HttpStatusCode.Unauthorized:
            return RedirectToAction("Unauthorized");
        case HttpStatusCode.OK:
            return RedirectToAction("Authorized"); // it enters this case
        default:
            return RedirectToAction("Index");
    }
}

[Route("TokenValidator")]
[Authorize]
public IActionResult TokenValidator()
{
    return new OkObjectResult("OK");
}

[Route("Authorized")]
[Authorize]
public IActionResult Authorized()
{
    return View();
}

最佳答案

感谢 Jean-François Fabre 删除了我的评论。

有时,未解决帖子中的旧评论有助于恢复辩论。

有兴趣的可以看答案

在 Startup.cs 中(配置) 添加代码:

    app.UseSession();
    app.Use(async (context, next) =>
    {
        var JWToken = context.Session.GetString("JWToken");
        if (!string.IsNullOrEmpty(JWToken))
        {
            context.Request.Headers.Add("Authorization", "Bearer " + JWToken);
        }
        await next();
    });

在 View 中, token 验证后:

HttpContext.Session.SetString("JWToken", post.AccessToken);

然后就可以正常进行了。

我使用 RedirectToAction:

return RedirectToAction(actionName: "Default", controllerName: "Usuario");

拥抱

关于c# - 使用授权 header 重定向到操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52217395/

相关文章:

c# - 如何在javascript中访问动态创建的对象?

asp.net-core - dotnet 包在 .net 核心 mvc 应用程序中不起作用

asp.net-mvc - 如何在 AspNet5/Mvc6 中检测 dnx451 Web 应用程序关闭?

c# - 使用 ReactJS SPA 在 .net Core 中进行身份验证

c# - 如何在 highcharts 工具提示文本框中添加千位分隔符

c# - 通过 PowerShell 调用 user32.dll "SetWindowCompositionAttribute"

c# - 使用具有不同类型详细信息的主从 View

c# - 从不同项目访问 appsettings.json

c# - 在 ASP.NET 核心中重新读取请求正文

c# - 如何将配置传递给 ASP.NET MVC6 中的非 Controller 类