没有cookie的ASP.NET Identity External Providers Web API

时间:2015-02-04 18:38:30

标签: asp.net cookies asp.net-web-api asp.net-identity

我已经看到了几种使用Identity在ASP.NET Web API中为身份验证设置外部提供程序支持的方法,但是所有这些方法都依赖于cookie,这是在用户被外部提供程序成功授权后设置的(调用& #34; AspNet.External"),然后必须转发到Web API本身的令牌端点。

有没有办法绕过这个并使用ASP.NET Web API进行外部身份验证而无需使用cookie?这个问题的原因是我想在我的移动应用程序中集成此身份验证,但用户可以随时禁用cookie,使我的应用程序无法使用。

1 个答案:

答案 0 :(得分:7)

使用OAuth2怎么样?

  1. 使用https://www.nuget.org/packages/Microsoft.Owin.Security.OAuth/
  2. 构建oauth2服务器
  3. 将您的服务器web api应用程序设置为资源服务器,并启用oauth bearer身份验证,该身份验证使用身份验证标头,而不是cookie。
  4. 从oauth2服务器获取access_token后,为客户端请求设置Authentication头。
  5. 你可以在这里查看代码:

    https://github.com/beginor/owin-samples