【发布时间】:2018-08-13 00:48:27
【问题描述】:
如何在 ASP.Net MVC Core 中为所有页面实现没有 cookie 和仅承载令牌的身份验证(和授权)?
我们还能使用 ASP.Net Identity 吗?
【问题讨论】:
标签: authentication asp.net-core asp.net-identity bearer-token
如何在 ASP.Net MVC Core 中为所有页面实现没有 cookie 和仅承载令牌的身份验证(和授权)?
我们还能使用 ASP.Net Identity 吗?
【问题讨论】:
标签: authentication asp.net-core asp.net-identity bearer-token
不,您不能将不记名令牌与 MVC 视图一起使用。仅适用于 WebAPI 式调用(由 JavaScript/Ajax 调用调用),因为对于承载令牌,您需要在 HTTP 请求中传递包含承载令牌的标头。
ASP.NET Core MVC 和 ASP.NET Core Identity 都没有提供生成 JWT 或不透明/刷新令牌的机制。您需要一个第三方库(ASOS、OpenIddict 或 IdentityServer4 - 或编写您自己的中间件)。
一般方法是使用 Cookie 进行 MVC(+AntiForgery 令牌 - 这些对于防止跨站点伪造请求 (XSRF) 攻击很重要)和 WebAPI 承载(存在使用 Cookie 运行 Ajax/Rest 调用的安全问题,因为您可以'然后像使用 AntiForgery 令牌做 MVC 一样不容易保护)。有疑问,谷歌关于条款;)
这对你有意义吗?
【讨论】:
这有点违背了拥有 JWT 的目的。
拥有包含大量 JWT 令牌数据的多个链接会加起来。此外,如果链接链中缺少一个,则 JWT 将被“丢弃”。可以将 JWT 保存在客户端 sessionStore 中,并在点击链接时让 javascript 动态地将 JWT 添加到链接中。
【讨论】: